Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp501809ybz; Wed, 15 Apr 2020 12:51:36 -0700 (PDT) X-Google-Smtp-Source: APiQypIw1owSBNdlmqkGTkED9sAbhzu8fmplXXHDE2fKCrhjAdMZD6MIMLuPcUR0fp+FaqB99ZGI X-Received: by 2002:a17:906:3048:: with SMTP id d8mr6582776ejd.97.1586980295965; Wed, 15 Apr 2020 12:51:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586980295; cv=none; d=google.com; s=arc-20160816; b=azKoV1E4h16IH0uGhywiaT9infL6YDvXvJe4IfZ/Rg/ZV7RlGD8Rhpg8SBvBEwaaWb wBl8e3kCVH/dWrTZti2YwJSO4S2vEVDeyjz+UvCufwm8eIxIRQdrfjLIwtHSRQlJIbL8 FGRxVGR4/mr5gjNLuaAO05kNpDYYmZjgLqOs1WOfN4S8ftxWlsF26nrZmVTCFAAd+Jx5 lbQwgKVRynhixFS2UqfAiuFUx17BKj74eQt2/4VwIF9UKElIeLVnazIH6sfmtvre7Kbm LdLXYTxwLwdOibH6Vs4oQCnPjIRm/c+a7I1ur6puFkF0EM3YZwr1CnvZs7cX5Psv8GWJ Iy+Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=CGoWGgXOolosSF6hkGjVvUHIRn3HAdaeZ2gk1sVmHug=; b=znelqzxUIVfwXE5QJlOUVWg/xMdlDV8hfsA6i8VLYNvb1AVjNzB8Ae3OFs2IqLxdml qiayhUTl6Ff06wG1j2xJKh6t5HKNff5sg3sdVMPYDXclXqo4pV0k1rUVuC7nr/O0yuJk 3mL3c4uZHaLdyf2rp/baG4rRS/XrBgMUMFEGsXy1Emdjj5dgOEX6WCayMZ4DXpF1zWDO lfEmT2KjlHa4WpAw1Ka6T1uBwpSBWK5NxbB1G2sZ5f8fCP2i+j0hMQLPoKmcdWPG90wJ zFlRzg+mC9e/djDvGxEE/RqvvBeCDDPm5LfO4xwsUUJT779Dk9Q+G1C1ThgIUEhIEA/o EbXQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ov7si10525671ejb.489.2020.04.15.12.51.11; Wed, 15 Apr 2020 12:51:35 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2437233AbgDNIy7 (ORCPT + 99 others); Tue, 14 Apr 2020 04:54:59 -0400 Received: from inva021.nxp.com ([92.121.34.21]:36880 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2437215AbgDNIy5 (ORCPT ); Tue, 14 Apr 2020 04:54:57 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 3D21420038D; Tue, 14 Apr 2020 10:54:55 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 300F5200358; Tue, 14 Apr 2020 10:54:55 +0200 (CEST) Received: from localhost (fsr-ub1664-175.ea.freescale.net [10.171.82.40]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id 1982B204D3; Tue, 14 Apr 2020 10:54:55 +0200 (CEST) Date: Tue, 14 Apr 2020 11:54:54 +0300 From: Abel Vesa To: peng.fan@nxp.com Cc: shawnguo@kernel.org, sboyd@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, aisheng.dong@nxp.com, Anson.Huang@nxp.com, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V3] clk: imx7ulp: make it easy to change ARM core clk Message-ID: <20200414085454.emvw6nlknniaeaug@fsr-ub1664-175> References: <1584347553-2654-1-git-send-email-peng.fan@nxp.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1584347553-2654-1-git-send-email-peng.fan@nxp.com> User-Agent: NeoMutt/20180622 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20-03-16 16:32:33, peng.fan@nxp.com wrote: > From: Peng Fan > > ARM clk could only source from divcore or hsrun_divcore. > > Follow what we already used on i.MX7D and i.MX8M SoCs, use > imx_clk_hw_cpu API. When ARM core is running normaly, > whether divcore or hwrun_divcore will finally source > from SPLL_PFD0. However SPLL_PFD0 is marked with CLK_SET_GATE, > so we need to disable SPLL_PFD0, when configure the rate. > So add CORE and HSRUN_CORE virtual clk to make it easy to > configure the clk using imx_clk_hw_cpu API. > > Since CORE and HSRUN_CORE already marked with CLK_IS_CRITICAL, no > need to set ARM as CLK_IS_CRITICAL. And when set the rate of ARM clk, > prograting it the parent with CLK_SET_RATE_PARENT will finally set > the SPLL_PFD0 clk. > > Signed-off-by: Peng Fan Reviewed-by: Abel Vesa > --- > > V3: > Update commit log. Make this a standalone patch from V2 > V2: > https://patchwork.kernel.org/patch/11390595/ > No change > > drivers/clk/imx/clk-imx7ulp.c | 6 ++++-- > include/dt-bindings/clock/imx7ulp-clock.h | 5 ++++- > 2 files changed, 8 insertions(+), 3 deletions(-) > > diff --git a/drivers/clk/imx/clk-imx7ulp.c b/drivers/clk/imx/clk-imx7ulp.c > index 3710aa0dee9b..634c0b6636b0 100644 > --- a/drivers/clk/imx/clk-imx7ulp.c > +++ b/drivers/clk/imx/clk-imx7ulp.c > @@ -29,7 +29,7 @@ static const char * const ddr_sels[] = { "apll_pfd_sel", "dummy", "dummy", "dum > static const char * const nic_sels[] = { "firc", "ddr_clk", }; > static const char * const periph_plat_sels[] = { "dummy", "nic1_bus_clk", "nic1_clk", "ddr_clk", "apll_pfd2", "apll_pfd1", "apll_pfd0", "upll", }; > static const char * const periph_bus_sels[] = { "dummy", "sosc_bus_clk", "dummy", "firc_bus_clk", "rosc", "nic1_bus_clk", "nic1_clk", "spll_bus_clk", }; > -static const char * const arm_sels[] = { "divcore", "dummy", "dummy", "hsrun_divcore", }; > +static const char * const arm_sels[] = { "core", "dummy", "dummy", "hsrun_core", }; > > /* used by sosc/sirc/firc/ddr/spll/apll dividers */ > static const struct clk_div_table ulp_div_table[] = { > @@ -121,7 +121,9 @@ static void __init imx7ulp_clk_scg1_init(struct device_node *np) > hws[IMX7ULP_CLK_DDR_SEL] = imx_clk_hw_mux_flags("ddr_sel", base + 0x30, 24, 2, ddr_sels, ARRAY_SIZE(ddr_sels), CLK_SET_RATE_PARENT | CLK_OPS_PARENT_ENABLE); > > hws[IMX7ULP_CLK_CORE_DIV] = imx_clk_hw_divider_flags("divcore", "scs_sel", base + 0x14, 16, 4, CLK_SET_RATE_PARENT); > + hws[IMX7ULP_CLK_CORE] = imx_clk_hw_cpu("core", "divcore", hws[IMX7ULP_CLK_CORE_DIV]->clk, hws[IMX7ULP_CLK_SYS_SEL]->clk, hws[IMX7ULP_CLK_SPLL_SEL]->clk, hws[IMX7ULP_CLK_FIRC]->clk); > hws[IMX7ULP_CLK_HSRUN_CORE_DIV] = imx_clk_hw_divider_flags("hsrun_divcore", "hsrun_scs_sel", base + 0x1c, 16, 4, CLK_SET_RATE_PARENT); > + hws[IMX7ULP_CLK_HSRUN_CORE] = imx_clk_hw_cpu("hsrun_core", "hsrun_divcore", hws[IMX7ULP_CLK_HSRUN_CORE_DIV]->clk, hws[IMX7ULP_CLK_HSRUN_SYS_SEL]->clk, hws[IMX7ULP_CLK_SPLL_SEL]->clk, hws[IMX7ULP_CLK_FIRC]->clk); > > hws[IMX7ULP_CLK_DDR_DIV] = imx_clk_hw_divider_gate("ddr_clk", "ddr_sel", CLK_SET_RATE_PARENT | CLK_IS_CRITICAL, base + 0x30, 0, 3, > 0, ulp_div_table, &imx_ccm_lock); > @@ -270,7 +272,7 @@ static void __init imx7ulp_clk_smc1_init(struct device_node *np) > base = of_iomap(np, 0); > WARN_ON(!base); > > - hws[IMX7ULP_CLK_ARM] = imx_clk_hw_mux_flags("arm", base + 0x10, 8, 2, arm_sels, ARRAY_SIZE(arm_sels), CLK_IS_CRITICAL); > + hws[IMX7ULP_CLK_ARM] = imx_clk_hw_mux_flags("arm", base + 0x10, 8, 2, arm_sels, ARRAY_SIZE(arm_sels), CLK_SET_RATE_PARENT); > > imx_check_clk_hws(hws, clk_data->num); > > diff --git a/include/dt-bindings/clock/imx7ulp-clock.h b/include/dt-bindings/clock/imx7ulp-clock.h > index 38145bdcd975..b58370d146e2 100644 > --- a/include/dt-bindings/clock/imx7ulp-clock.h > +++ b/include/dt-bindings/clock/imx7ulp-clock.h > @@ -58,7 +58,10 @@ > #define IMX7ULP_CLK_HSRUN_SYS_SEL 44 > #define IMX7ULP_CLK_HSRUN_CORE_DIV 45 > > -#define IMX7ULP_CLK_SCG1_END 46 > +#define IMX7ULP_CLK_CORE 46 > +#define IMX7ULP_CLK_HSRUN_CORE 47 > + > +#define IMX7ULP_CLK_SCG1_END 48 > > /* PCC2 */ > #define IMX7ULP_CLK_DMA1 0 > -- > 2.16.4 >