Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp2680594rdb; Fri, 8 Dec 2023 16:11:01 -0800 (PST) X-Google-Smtp-Source: AGHT+IEt+/V0Ki8NmvZKtnJWYOPT6EQGW7QaMuBIiz4bUY8cANUOGk0lUAzMFW2g3rc1pfBc+Y3Z X-Received: by 2002:a05:6602:2d95:b0:7b7:187d:cccc with SMTP id k21-20020a0566022d9500b007b7187dccccmr1361286iow.9.1702080661624; Fri, 08 Dec 2023 16:11:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702080661; cv=none; d=google.com; s=arc-20160816; b=e2NG5AuYIEV+voCOe88TBU1opKUlNFpGOz3YOWvrmIsgR9bkY0E4COzblQQCCdfFnh QWkxFL7VUa0SVkf8RWpNziktWvO29PiHelPbPs4fYxxZnmxIjZJIQWMJ8Hs3pN5vleWT jaRsiHe0yVkn1aqdNGKin8fwqS0dbzPs8IEzbcwZ7sF4Nd42CEdDaGKXxj0fLU0h1Rrp O1mGPbSnvJxLyvjMgvXY9Du7jmfEs8PNOAdySyRlMJlcd/AAfuHCgOnnYpQ5k7ctSdSq sUWQQpt55UbpshWhQXgVjtv1jd3iKxMI2FXdIvrkv/C1sC9Z72234T7S5SPPL1uozWMV VLyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=Fi0wk8szULHC24+7+kQs0AwlD1m9pTei8Q8P6J8xn90=; fh=7rweXtOkLDt/30P8JiDVGFDzHDXyJnggB4m8U8e7ynQ=; b=znnFsrLU500sVUS8Tk9Pir5BxhPEjP5VMKk9L5wwraMBrzj9MXLsBv1COT/pmaCnjw PGXfOHRFblNf+EtdAu7HeUuYM5CxAQmDveY9yMW+FY3Hto2AhsC+KeDckoW8xrSFX/DE Axd3/Wzbi7M3LfULbzvsezuY14MBz4zM06vkry/Z8HVuBgwSweFHy/gKwvxp7zNah2OR NE1Ts9N8FDR0cWv0Zd6fklNV6vTUhDJZjUNXphU6/+VSmuLGAZxqNH4ce9wDuIcKr9oa k5sGGAoD99vUWXKv/edArqNmpOQaB9E/U9Jwxkk+5yCeK3d6X2ilzg7P+ezliBrHY3RK kt2Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id h9-20020a056a00170900b006cc05bcf542si2222710pfc.319.2023.12.08.16.11.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 08 Dec 2023 16:11:01 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 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 howler.vger.email (Postfix) with ESMTP id 147EC8705EBB; Fri, 8 Dec 2023 16:10:59 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229986AbjLIAKh (ORCPT + 99 others); Fri, 8 Dec 2023 19:10:37 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51224 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229525AbjLIAKf (ORCPT ); Fri, 8 Dec 2023 19:10:35 -0500 Received: from pidgin.makrotopia.org (pidgin.makrotopia.org [185.142.180.65]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A6C0D1723; Fri, 8 Dec 2023 16:10:40 -0800 (PST) Received: from local by pidgin.makrotopia.org with esmtpsa (TLS1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.96.2) (envelope-from ) id 1rBkvE-00054i-1y; Sat, 09 Dec 2023 00:10:21 +0000 Date: Sat, 9 Dec 2023 00:10:13 +0000 From: Daniel Golle To: AngeloGioacchino Del Regno Cc: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Michael Turquette , Stephen Boyd , Matthias Brugger , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Sabrina Dubroca , Jianhui Zhao , Chen-Yu Tsai , "Garmin.Chang" , Sam Shih , Frank Wunderlich , Dan Carpenter , James Liao , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, netdev@vger.kernel.org Subject: Re: [PATCH v3 3/4] clk: mediatek: Add pcw_chg_shift control Message-ID: References: <23bc89d407e7797e97b703fa939b43bfe79296ce.1701823757.git.daniel@makrotopia.org> <40981d0bb722eb509628bcf82c31f632e4cf747a.1701823757.git.daniel@makrotopia.org> <0ebce75d-0074-4128-b35e-e86ee3ee546b@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <0ebce75d-0074-4128-b35e-e86ee3ee546b@collabora.com> X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.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 (howler.vger.email [0.0.0.0]); Fri, 08 Dec 2023 16:10:59 -0800 (PST) Hi Angelo, thank you for taking the time to review and for the helpful comments. On Wed, Dec 06, 2023 at 11:38:36AM +0100, AngeloGioacchino Del Regno wrote: > Il 06/12/23 01:57, Daniel Golle ha scritto: > > From: Sam Shih > > > > Introduce pcw_chg_shfit control to optionally use that instead of the > > hardcoded PCW_CHG_MASK macro. > > This will needed for clocks on the MT7988 SoC. > > > > Signed-off-by: Sam Shih > > Signed-off-by: Daniel Golle > > --- > > v3: use git --from ... > > v2: no changes > > > > drivers/clk/mediatek/clk-pll.c | 5 ++++- > > drivers/clk/mediatek/clk-pll.h | 1 + > > 2 files changed, 5 insertions(+), 1 deletion(-) > > > > diff --git a/drivers/clk/mediatek/clk-pll.c b/drivers/clk/mediatek/clk-pll.c > > index 513ab6b1b3229..9f08bc5d2a8a2 100644 > > --- a/drivers/clk/mediatek/clk-pll.c > > +++ b/drivers/clk/mediatek/clk-pll.c > > @@ -114,7 +114,10 @@ static void mtk_pll_set_rate_regs(struct mtk_clk_pll *pll, u32 pcw, > > pll->data->pcw_shift); > > val |= pcw << pll->data->pcw_shift; > > writel(val, pll->pcw_addr); > > - chg = readl(pll->pcw_chg_addr) | PCW_CHG_MASK; > > + if (pll->data->pcw_chg_shift) > > + chg = readl(pll->pcw_chg_addr) | BIT(pll->data->pcw_chg_shift); > > + else > > + chg = readl(pll->pcw_chg_addr) | PCW_CHG_MASK; > > writel(chg, pll->pcw_chg_addr); > > if (pll->tuner_addr) > > writel(val + 1, pll->tuner_addr); > > diff --git a/drivers/clk/mediatek/clk-pll.h b/drivers/clk/mediatek/clk-pll.h > > index f17278ff15d78..d28d317e84377 100644 > > --- a/drivers/clk/mediatek/clk-pll.h > > +++ b/drivers/clk/mediatek/clk-pll.h > > @@ -44,6 +44,7 @@ struct mtk_pll_data { > > u32 pcw_reg; > > int pcw_shift; > > u32 pcw_chg_reg; > > + int pcw_chg_shift; > > const struct mtk_pll_div_table *div_table; > > const char *parent_name; > > u32 en_reg; > > Hmm... no, this is not the best at all and can be improved. > > Okay, so, the situation here is that one or some PLL(s) on MT7988 have a different > PCW_CHG_MASK as far as I understand. Correct. *All* clocks of MT7988 have a different PCW_CHG_MASK, BIT(2) instead of BIT(31). > > Situation here is: > - Each PLL must be registered to clk-pll > - Each driver declaring a PLL does exactly so > - There's a function to register the PLL > > You definitely don't want to add a conditional in pll_set_rate(): even though > this is technically not a performance path on the current SoCs (and will probably > never be), it's simply useless to have this (very small) overhead there. > > The solution is to: > - Change that pcw_chg_shift to an unsigned short int type (or u8, your call): > you don't need 32 bits for this number, as the expected range of this member > is [0-31], and this can be expressed in just 4 bits (u8 is the smallest though) Ack will use u8 instead, despite the struct not being packed, so I wonder if it actually makes a difference. > - Add that to function mtk_clk_register_pll_ops() > - Change mtk_pll_set_rate_regs() to always do > chg = readl(pll->pcw_chg_addr) | BIT(pll->data->pcw_chg_shift); As mtk_pll_data is a read-only member of the mtk_pll struct, we can't set pcw_chg_shift to 31 in mtk_clk_register_pll_ops() in case it is set to 0. The only (much more intrusive change) would be to explicitely declare .pcw_chg_shift = 31 in all current drivers setting .pcs_chg_reg != 0. Should I do that instead?