Received: by 2002:a05:7412:da14:b0:e2:908c:2ebd with SMTP id fe20csp1324125rdb; Sun, 8 Oct 2023 02:22:48 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHT8odf+9SPJ7HvQZnG1TQCfbujoclGqCDlKjitkZMYy7A1pHxfw66T5BCDJV7/0bACY85o X-Received: by 2002:a05:6870:71ce:b0:1d6:51aa:13a2 with SMTP id p14-20020a05687071ce00b001d651aa13a2mr14588993oag.10.1696756968302; Sun, 08 Oct 2023 02:22:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696756968; cv=none; d=google.com; s=arc-20160816; b=fcQRs3jZLsarwCULJri2PU1yknTZkuYUKLvxA7vs5qCUdYS9FYnLK1w5nG8/Up4Nbn QNxRR93Rf7U+mOoNZfswTrt5hmO6PbGShKiECYxkBtVtJCZ2lErJkyeylQvbJPEXwzIF fT/Ajgnk0CK5fiGwbKTSPdgZBkliANC7ZeZfmYja8kOg+vZXGmF8ONr8gDiCekr9ZLQu gxsznUjGRBDZOEKDBKKS7xYqqwHBD05oT/+rNN83YQe3VZbl5zsYAVDkvRNEdI/TrhkC Lfv5AGJFB70ndh0mWQUySMizqcMycG+1jnBPMT/yRsehYywyg89U+1tF/SyEHhSFwyUb eXBQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=mGgVKZZQj656cstWfPsLIbVZgwDpHbsTlizbZ8hZiDI=; fh=27ted43Wnrrq3+2xNx5qK0n5Kwjn9zOQunkdFaBl4OE=; b=nnMVopKZYGP+SVxCKHTKiOihDprcHgc1gStDc2qR+TFpNTmLITSOigeroNmvylLUVE +3qIEM9cdoE/9l3xf1twOxFCeCYS6mR/lFBgFqE5AWb5pS+YCyTgzEQH1eDlP/AOSMs0 vbBFRBfwhfDkD+CXKo5PBmC+pd0oDn/OoqNMmGBoQD7HgeK7goAtbYmYEKbI/r2t5zBT jhTGBsn/wr6Urgp36tLCn7r748OVTfy5CNsWsNNyAc2P50pdr8e+pfZv8rBn1+vLxwDd qJ1FZAh6yb/+bsvMzS7gdzn+S/k0XHhFVAo5llVJuNb1j8WUjYKuR6AJVk02n0d7hsPL a6PA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id c17-20020a170902d49100b001bc5a4f56fcsi7446574plg.554.2023.10.08.02.22.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 08 Oct 2023 02:22:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 9EB20805D5F1; Sun, 8 Oct 2023 02:22:45 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234274AbjJHJWd (ORCPT + 99 others); Sun, 8 Oct 2023 05:22:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43426 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234275AbjJHJWc (ORCPT ); Sun, 8 Oct 2023 05:22:32 -0400 Received: from ex01.ufhost.com (ex01.ufhost.com [61.152.239.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E761ECA; Sun, 8 Oct 2023 02:22:29 -0700 (PDT) Received: from EXMBX166.cuchost.com (unknown [175.102.18.54]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "EXMBX166", Issuer "EXMBX166" (not verified)) by ex01.ufhost.com (Postfix) with ESMTP id 58F5F24E2A4; Sun, 8 Oct 2023 17:22:28 +0800 (CST) Received: from EXMBX061.cuchost.com (172.16.6.61) by EXMBX166.cuchost.com (172.16.6.76) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Sun, 8 Oct 2023 17:22:25 +0800 Received: from [192.168.125.131] (183.27.97.165) by EXMBX061.cuchost.com (172.16.6.61) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Sun, 8 Oct 2023 17:22:24 +0800 Message-ID: <5efe573f-238b-778e-58a3-a3f8c04f71eb@starfivetech.com> Date: Sun, 8 Oct 2023 17:16:29 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 Subject: Re: [PATCH v2] clk: starfive: jh7110-sys: Fix lower rate of CPUfreq by setting PLL0 rate to 1.5GHz Content-Language: en-US To: Emil Renner Berthing CC: Michael Turquette , Stephen Boyd , Conor Dooley , Hal Feng , , References: <20230821152915.208366-1-xingyu.wu@starfivetech.com> <07ddac3c-eb6e-d187-b942-102f117f8d13@starfivetech.com> From: Xingyu Wu In-Reply-To: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [183.27.97.165] X-ClientProxiedBy: EXCAS062.cuchost.com (172.16.6.22) To EXMBX061.cuchost.com (172.16.6.61) X-YovoleRuleAgent: yovoleflag X-Spam-Status: No, score=1.0 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Sun, 08 Oct 2023 02:22:45 -0700 (PDT) On 2023/8/22 16:56, Emil Renner Berthing wrote: > On Tue, 22 Aug 2023 at 05:33, Xingyu Wu wrote: >> On 2023/8/21 23:38, Emil Renner Berthing wrote: >> > On Mon, 21 Aug 2023 at 17:29, Xingyu Wu wrote: >> >> >> >> CPUfreq supports 4 cpu frequency loads on 375/500/750/1500MHz. >> >> But now PLL0 rate is 1GHz and the cpu frequency loads become >> >> 333/500/500/1000MHz in fact. >> >> >> >> So PLL0 rate should be set to 1.5GHz. Change the parent of cpu_root clock >> >> and the divider of cpu_core before the setting. >> >> >> >> Reviewed-by: Hal Feng >> >> Fixes: e2c510d6d630 ("riscv: dts: starfive: Add cpu scaling for JH7110 SoC") >> >> Signed-off-by: Xingyu Wu >> >> --- >> >> >> >> Hi Stephen and Emil, >> >> >> >> This patch fixes the issue about lower rate of CPUfreq[1] >> >> and sets PLL0 rate to 1.5GHz. In order not to affect the cpu >> >> operation, the cpu_root's parent clock should be changed first. >> >> And the divider of the cpu_core clock should be set to 2 so they >> >> won't crash when setting 1.5GHz without voltage regulation. >> > >> > Hi Xingyu, >> > >> > It sounds like this is something the driver should handle >> > automatically whenever clk_set_rate() is called on the PLL0 clock. >> > Then we should be able to use regular assigned-clocks / >> > assigned-clock-rates stanzas in the device tree instead of having this >> > 1.5GHz rate hard-coded in the driver. >> > >> > /Emil >> >> Hi Emil, >> >> The frequency of PLL0 is set according to this process to avoid crash: >> 1. The divider of the cpu_core clock should be set to 2 if PLL0 is set to 1.5GHz. >> 2. The parent of cpu_root is changed from pll0 to osc. >> 3. The PLL0 is set to 1.5GHz. >> 4. The parent of cpu_root is changed from osc to pll0 back. >> I don't think assigned-clock-rates/assigned-clock-parents can do such a complicated job. > > Right, but what I'm saying is that if calling clk_set_rate() on the > PLL0 clock causes a crash, that sounds like a bug in the driver. If > you fix that bug, and make clk_set_rate() on the PLL0 clock do the > procedure above when changing the rate, then the PLL0 clock can work > just like any other clock and assigned-clock-rates would work. > > /Emil Yeah, if fix this bug, I should add there steps when setting rate in the PLL clock driver. But how to get and use the clocks of cpu_root and cpu_core in the PLL driver? It seem to be only two ways, clk_get() or ioremap(). If use clk_get(), the pll node should add syscrg clocks. It shows that the PLL driver depends on the SYSCRG driver, which seems confusing because normally the syscrg depends on the pll. Do you have a better suggestion? Thanks. Xingyu Wu > >> > >> >> [1]: https://github.com/starfive-tech/VisionFive2/issues/55 >> >> >> >> This patch is based on linux-next(20230818) which has merge PLL driver >> >> on the StarFive JH7110 SoC. >> >> >> >> Thanks, >> >> Xingyu Wu >> >> >> >> --- >> >> .../clk/starfive/clk-starfive-jh7110-sys.c | 47 ++++++++++++++++++- >> >> 1 file changed, 46 insertions(+), 1 deletion(-) >> >> >> >> diff --git a/drivers/clk/starfive/clk-starfive-jh7110-sys.c b/drivers/clk/starfive/clk-starfive-jh7110-sys.c >> >> index 3884eff9fe93..b6b9e967dfc7 100644 >> >> --- a/drivers/clk/starfive/clk-starfive-jh7110-sys.c >> >> +++ b/drivers/clk/starfive/clk-starfive-jh7110-sys.c >> >> @@ -501,7 +501,52 @@ static int __init jh7110_syscrg_probe(struct platform_device *pdev) >> >> if (ret) >> >> return ret; >> >> >> >> - return jh7110_reset_controller_register(priv, "rst-sys", 0); >> >> + ret = jh7110_reset_controller_register(priv, "rst-sys", 0); >> >> + if (ret) >> >> + return ret; >> >> + >> >> + /* >> >> + * Set PLL0 rate to 1.5GHz >> >> + * In order to not affect the cpu when the PLL0 rate is changing, >> >> + * we need to switch the parent of cpu_root clock to osc clock first, >> >> + * and then switch back after setting the PLL0 rate. >> >> + */ >> >> + pllclk = clk_get(priv->dev, "pll0_out"); >> >> + if (!IS_ERR(pllclk)) { >> >> + struct clk *osc = clk_get(&pdev->dev, "osc"); >> >> + struct clk *cpu_root = priv->reg[JH7110_SYSCLK_CPU_ROOT].hw.clk; >> >> + struct clk *cpu_core = priv->reg[JH7110_SYSCLK_CPU_CORE].hw.clk; >> >> + >> >> + if (IS_ERR(osc)) { >> >> + clk_put(pllclk); >> >> + return PTR_ERR(osc); >> >> + } >> >> + >> >> + /* >> >> + * CPU need voltage regulation by CPUfreq if set 1.5GHz. >> >> + * So in this driver, cpu_core need to be set the divider to be 2 first >> >> + * and will be 750M after setting parent. >> >> + */ >> >> + ret = clk_set_rate(cpu_core, clk_get_rate(cpu_core) / 2); >> >> + if (ret) >> >> + goto failed_set; >> >> + >> >> + ret = clk_set_parent(cpu_root, osc); >> >> + if (ret) >> >> + goto failed_set; >> >> + >> >> + ret = clk_set_rate(pllclk, 1500000000); >> >> + if (ret) >> >> + goto failed_set; >> >> + >> >> + ret = clk_set_parent(cpu_root, pllclk); >> >> + >> >> +failed_set: >> >> + clk_put(pllclk); >> >> + clk_put(osc); >> >> + } >> >> + >> >> + return ret; >> >> } >> >> >> >> static const struct of_device_id jh7110_syscrg_match[] = { >> >> -- >> >> 2.25.1 >> >> >>