Received: by 2002:ac0:e34a:0:0:0:0:0 with SMTP id g10csp407133imn; Thu, 28 Jul 2022 04:34:10 -0700 (PDT) X-Google-Smtp-Source: AGRyM1v0N4D8Z4GNzjUXMilI6TCRLk0DJ4W/hLSaaEYcSoh5jTeQJax1rAYOcrvWI/YR1GuYpPsj X-Received: by 2002:a17:90b:4d11:b0:1f0:414b:586e with SMTP id mw17-20020a17090b4d1100b001f0414b586emr9854256pjb.111.1659008050305; Thu, 28 Jul 2022 04:34:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659008050; cv=none; d=google.com; s=arc-20160816; b=D964+E7aqOQ3H5WsxWMtaTzFet0HIjTWTSJpGdWzuVltnrny4igAVawaCsEbQgNL6g LhzUFGgwsOf7EZFb1BQW9iOcLH5f6xFy2hHR59/6yE8NcLq5r4ykaVXKF0Dm9U97Thw1 bElzqU18rdN4o4kGwX0Bw0cCU+U8Hz6DXcB4bJYqMFDADiToRDonHwmvkOQlQlMCogGh saR5Q2bQIBsufn031pj//uVDpyqkHPaBQlbVt+ZFzqD1mWv87ihforaakXK01aAFPVBs X5Cybrj+QjzXsrzq5KIyk9UU0k7t8AOkQX8fj0Zt+SEUrC17wwAG2/tDUSVf2asYCQKi 8YFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=GqGg00GJ++09EoLJB+wD1QV4WvRtScBrf/f2QDDfF18=; b=qSuOhp/9PUrtBw68zB+ETO0cVgwfUoWSzXKeVhSy1geqWK5q+ThOil9ShQjEovrWaT Hqfd5pMT1bh3mlALaeSsdVjKvokmi/Klg4JhxsU0Q7hHrBPTd+k4+xv8rQ6x026Z+M3J Buo1YAO8iR2Y14V5Pmfn3QCeNR5qY+p4/gWIE9bUljXQNbZaPIuBH5ybwe3Q4/rNrz+H WHFVYDttaiT+gfTub3K3UlVvp3QeQdRR8HnZ13Zd/y7ZOnQ1FMaCpL0eVo++2oyC51zI wu3GAaqT/q5w+FU32lsDFJ5Fja/26+clrgV0ix9RzODVc3QYMLMbPQh8plwkwZw3EYm0 xyEQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=h7d0hnf3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 203-20020a6214d4000000b0052acb294d94si433105pfu.100.2022.07.28.04.33.54; Thu, 28 Jul 2022 04:34:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=h7d0hnf3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236157AbiG1LVq (ORCPT + 99 others); Thu, 28 Jul 2022 07:21:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49288 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235731AbiG1LUQ (ORCPT ); Thu, 28 Jul 2022 07:20:16 -0400 Received: from mail.baikalelectronics.com (unknown [87.245.175.230]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id CB628675B5; Thu, 28 Jul 2022 04:19:35 -0700 (PDT) Received: from mail (mail.baikal.int [192.168.51.25]) by mail.baikalelectronics.com (Postfix) with ESMTP id 6481316D0; Thu, 28 Jul 2022 14:21:57 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.com 6481316D0 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1659007317; bh=GqGg00GJ++09EoLJB+wD1QV4WvRtScBrf/f2QDDfF18=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=h7d0hnf3SyVT6+BcP0yl82j3/McPBY5ungJuFPeeUY/p0E1/6fOAlv6r7k70r3zun eikJWOaFfSId7HvHPsP9tON+E3GE/1/0ZAzNwOJlwOetzkFdBPs6a6QkFRQHXPPyE/ ogTNhj8B0TiYU0kO8g2Tmx2RZt+en4t9VvMK0VEQ= Received: from localhost (192.168.53.207) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Thu, 28 Jul 2022 14:19:32 +0300 From: Serge Semin To: Damien Le Moal , Hans de Goede , Jens Axboe , Hannes Reinecke CC: Serge Semin , Serge Semin , Alexey Malahov , Pavel Parkhomenko , Rob Herring , , , Subject: [PATCH RESEND v6 18/23] ata: libahci_platform: Add function returning a clock-handle by id Date: Thu, 28 Jul 2022 14:18:59 +0300 Message-ID: <20220728111905.12427-19-Sergey.Semin@baikalelectronics.ru> In-Reply-To: <20220728111905.12427-1-Sergey.Semin@baikalelectronics.ru> References: <20220728111905.12427-1-Sergey.Semin@baikalelectronics.ru> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: MAIL.baikal.int (192.168.51.25) To mail (192.168.51.25) X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,T_SPF_PERMERROR autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since all the clocks are retrieved by the method ahci_platform_get_resources() there is no need for the LLD (glue) drivers to be looking for some particular of them in the kernel clocks table again. Instead we suggest to add a simple method returning a device-specific clock with passed connection ID if it is managed to be found. Otherwise the function will return NULL. Thus the glue-drivers won't need to either manually touching the hpriv->clks array or calling clk_get()-friends. The AHCI platform drivers will be able to use the new function right after the ahci_platform_get_resources() method invocation and up to the device removal. Note the method is left unused here, but will be utilized in the framework of the DWC AHCI SATA driver being added in the next commit. Signed-off-by: Serge Semin --- Changelog v2: - Fix some grammar mistakes in the method description. Changelog v4: - Add a note regarding the new method usage. Changelog v5: - Fix the ahci_platform_find_clk() declaration identations. (@Damien) - Simplify the ahci_platform_find_clk() method body by dropping the local poiter to clk structure. (@Damien) --- drivers/ata/libahci_platform.c | 24 ++++++++++++++++++++++++ include/linux/ahci_platform.h | 3 +++ 2 files changed, 27 insertions(+) diff --git a/drivers/ata/libahci_platform.c b/drivers/ata/libahci_platform.c index 5ddae5f5355e..83f1d67f003e 100644 --- a/drivers/ata/libahci_platform.c +++ b/drivers/ata/libahci_platform.c @@ -94,6 +94,30 @@ void ahci_platform_disable_phys(struct ahci_host_priv *hpriv) } EXPORT_SYMBOL_GPL(ahci_platform_disable_phys); +/** + * ahci_platform_find_clk - Find platform clock + * @hpriv: host private area to store config values + * @con_id: clock connection ID + * + * This function returns a pointer to the clock descriptor of the clock with + * the passed ID. + * + * RETURNS: + * Pointer to the clock descriptor on success otherwise NULL + */ +struct clk *ahci_platform_find_clk(struct ahci_host_priv *hpriv, const char *con_id) +{ + int i; + + for (i = 0; i < hpriv->n_clks; i++) { + if (!strcmp(hpriv->clks[i].id, con_id)) + return hpriv->clks[i].clk; + } + + return NULL; +} +EXPORT_SYMBOL_GPL(ahci_platform_find_clk); + /** * ahci_platform_enable_clks - Enable platform clocks * @hpriv: host private area to store config values diff --git a/include/linux/ahci_platform.h b/include/linux/ahci_platform.h index 6d7dd472d370..17fa26215292 100644 --- a/include/linux/ahci_platform.h +++ b/include/linux/ahci_platform.h @@ -13,6 +13,7 @@ #include +struct clk; struct device; struct ata_port_info; struct ahci_host_priv; @@ -21,6 +22,8 @@ struct scsi_host_template; int ahci_platform_enable_phys(struct ahci_host_priv *hpriv); void ahci_platform_disable_phys(struct ahci_host_priv *hpriv); +struct clk *ahci_platform_find_clk(struct ahci_host_priv *hpriv, + const char *con_id); int ahci_platform_enable_clks(struct ahci_host_priv *hpriv); void ahci_platform_disable_clks(struct ahci_host_priv *hpriv); int ahci_platform_deassert_rsts(struct ahci_host_priv *hpriv); -- 2.35.1