Received: by 2002:a05:7208:9594:b0:7e:5202:c8b4 with SMTP id gs20csp1146230rbb; Sun, 25 Feb 2024 23:14:11 -0800 (PST) X-Forwarded-Encrypted: i=2; AJvYcCVzb/6UBTSTQctw9OV9i7Ly+LNzmWxyMSF8mrMfga1KwYAeeu9ci5GLFkCJwTE9MWlXufT4bXzGe+jvELblVxUbsT7whlDOiN58aIUHIw== X-Google-Smtp-Source: AGHT+IGVwnZFbKxRWE4q6Rin7TRJfm4rPtAlqZ98IDPJTe2RGxuC5MYgbykhtyl+v1OS82++y/xf X-Received: by 2002:a05:6a00:14d5:b0:6e5:3372:7c0c with SMTP id w21-20020a056a0014d500b006e533727c0cmr1114354pfu.2.1708931651170; Sun, 25 Feb 2024 23:14:11 -0800 (PST) Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id h7-20020a635747000000b005dc4f115f26si3142074pgm.537.2024.02.25.23.14.10 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 25 Feb 2024 23:14:11 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-80621-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@oltmanns.dev header.s=MBO0001 header.b=h4iQJH1p; arc=fail (body hash mismatch); spf=pass (google.com: domain of linux-kernel+bounces-80621-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-80621-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oltmanns.dev Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id E4560B20BB6 for ; Mon, 26 Feb 2024 07:14:08 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7755B1BC5A; Mon, 26 Feb 2024 07:14:02 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=oltmanns.dev header.i=@oltmanns.dev header.b="h4iQJH1p" Received: from mout-p-101.mailbox.org (mout-p-101.mailbox.org [80.241.56.151]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 8BE821B80A; Mon, 26 Feb 2024 07:13:58 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=80.241.56.151 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708931641; cv=none; b=S6XnLILG8QtSVrfwdcEvvwcnGupYYGazwo035qYFRMIEJ7HKaA7NvLnoOXcWdKNV7VupIkRz6Qlm5rY4KLbChjmKBA9emp3SNq1fNBhBlNTRB8MdCzTe0JIGQIvofR1KtwvBmaSHYGG5ufytimFSUL8tX55Fx0EBuT4T4Ee88yU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708931641; c=relaxed/simple; bh=dxCz/fFDsibRBYNTwj8zHc7Wwo+Ib9d/+RgKF2FD2V0=; h=From:To:Cc:Subject:In-Reply-To:References:Date:Message-ID: MIME-Version:Content-Type; b=DK9+rQNdu/oxyYY9v8GD/ceetb7zvhP5kC673KYuwj7rBCAfRpdhw3cg2X5Iq/lU2VNqQqKMskpNt6UTc22dAp7qMtbY1pUgYPG2noSQaZtRewhIKdBUbxtAnDRpjEIZkVT9E80PIgW/OyX7RB9J7PlC3hVKZC8FH0D/QX7YpLU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oltmanns.dev; spf=pass smtp.mailfrom=oltmanns.dev; dkim=pass (2048-bit key) header.d=oltmanns.dev header.i=@oltmanns.dev header.b=h4iQJH1p; arc=none smtp.client-ip=80.241.56.151 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oltmanns.dev Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oltmanns.dev Received: from smtp202.mailbox.org (smtp202.mailbox.org [10.196.197.202]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mout-p-101.mailbox.org (Postfix) with ESMTPS id 4TjsKt4YWpz9sbt; Mon, 26 Feb 2024 08:13:54 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oltmanns.dev; s=MBO0001; t=1708931634; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=VTNzJE39BOCLxRf5yDybxYlsEYOjYJ1HoUGDaE1emkM=; b=h4iQJH1pX3SvxW6V7z9hXlqCXIbWAeLPNT3wxiy4N90j+/N2zyD6McxlNvBjNDr484R6Mq wF6ESHtna34N7RYcWnC3o/c0uh3IxuhhA8tkKSctDHt11DX0HxHJ3SHvIJlzUfPMdXOt6u 5+kZB8i7vJ9SEUrXDBc7JjbiU8oVVKoxU4KWPMU2CCFjTfTMUgP8k6U3rHK6NAqztCU4iM 6/uVmerY7fldINja0maN89muOi4rLUWKfCZ3OU/jYQIAltyumG9kZUYvbY0vQcdMuwJR5f 92+PvdW4bNSmMpOk3qLU7D4+u16EZNlO2EJG0SIj6vB9rbUk6Fa9bXQJUVhdEA== From: Frank Oltmanns To: =?utf-8?Q?Ond=C5=99ej?= Jirman , Jernej Skrabec , Maxime Ripard Cc: Michael Turquette , Stephen Boyd , Chen-Yu Tsai , Samuel Holland , Guido =?utf-8?Q?G=C3=BCnther?= , Purism Kernel Team , Neil Armstrong , Jessica Zhang , Sam Ravnborg , Maarten Lankhorst , Thomas Zimmermann , David Airlie , Daniel Vetter , Rob Herring , Krzysztof Kozlowski , Conor Dooley , linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-sunxi@lists.linux.dev, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org Subject: Re: [PATCH v2 0/6] Pinephone video out fixes (flipping between two frames) In-Reply-To: <87r0h8n64g.fsf@oltmanns.dev> (Frank Oltmanns's message of "Mon, 19 Feb 2024 10:41:19 +0100") References: <20240205-pinephone-pll-fixes-v2-0-96a46a2d8c9b@oltmanns.dev> <87wmrbxckj.fsf@oltmanns.dev> <87r0h8n64g.fsf@oltmanns.dev> Date: Mon, 26 Feb 2024 08:13:42 +0100 Message-ID: <875xybr93t.fsf@oltmanns.dev> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Hi Jernej, hi Maxime, hi Ond=C5=99ej, On 2024-02-19 at 10:41:19 +0100, Frank Oltmanns wrote: > Hi Ond=C5=99ej, > > On 2024-02-11 at 20:25:29 +0100, Ond=C5=99ej Jirman wrote: >> Hi Frank, >> >> On Sun, Feb 11, 2024 at 04:09:16PM +0100, Frank Oltmanns wrote: >>> Hi Ond=C5=99ej, >>> >>> On 2024-02-05 at 17:02:00 +0100, Ond=C5=99ej Jirman wrote: >>> > On Mon, Feb 05, 2024 at 04:54:07PM +0100, Ond=C5=99ej Jirman wrote: >>> >> On Mon, Feb 05, 2024 at 04:22:23PM +0100, Frank Oltmanns wrote: >>> >> >>> >> [...] >>> >> >>> >> Also sunxi-ng clk driver does apply NM factors at once to PLL_GPU cl= ock, >>> >> which can cause sudden frequency increase beyond intended output fre= quency, >>> >> because division is applied immediately while multiplication is refl= ected >>> >> slowly. >>> >> >>> >> Eg. if you're changing divider from 7 to 1, you can get a sudden 7x = output >>> >> frequency spike, before PLL VCO manages to lower the frequency throu= gh N clk >>> >> divider feedback loop and lock on again. This can mess up whatever's= connected >>> >> to the output quite badly. >>> >> >>> >> You'd have to put logging on kernel writes to PLL_GPU register to se= e what >>> >> is written in there and if divider is lowered significantly on some = GPU >>> >> devfreq frequency transitions. >>> >>> By looking at the clocks in clk_summary in debugfs, the rate of PLL-GPU >>> always matches the rate of the GPU (at least at 120, 312, and 432 MHz). >>> This is further underlined by the fact, that none of the rates can be >>> achieved by integer dividing one of the other rates. sunxi-ng would >>> only favor a different rate for pll-gpu than the one that is requested >>> for the gpu, if pll-gpu is already running at a rate such that there >>> exists an M =E2=88=88 {1, 2, 3, 4, 5, 6, 7, 8}, where >>> rate of pll-gpu / M =3D requested gpu rate >>> or if the requested rate could not be reached directly by pll-gpu. Both >>> is not the case for the rates in question (120, 192, 312, and 432 MHz). >>> >>> This means that the following divisor/multipliers are used by sunxi-ng's >>> ccu_nm: >>> N =3D 5, M =3D 1 for 120 MHz (min value without PATCH 6) >>> N =3D 8, M =3D 1 for 192 MHz (min value after applying PATCH 6) >>> N =3D 13, M =3D 1 for 312 MHz >>> N =3D 18, M =3D 1 for 432 MHz >>> >>> So, with or without PATCH 6, the divider stays constant and it's only >>> the multiplier that changes. This means, there should be no unexpected >>> frequency spikes, right? >> >> Maybe. Thanks for giving it a try. There may still be other kinds of gli= tches >> even if the divisor stays the same. It all depends how the register upda= te is >> implemented in the PLL block. It's hard to say. I guess, unless Allwinner >> guarantees glitchless output from a given PLL when changing its paramete= rs, >> you can't rely on the output being clean during changes. >> >>> >> It's also unclear what happens when FRAC_CLK_OUT or PLL_MODE_SEL cha= nges. >>> >>> Those are not changed once the clock is initialized. The bug however >>> occurs hours or days after booting. IMO, this makes it unlikely that th= is >>> could be the culprit. >>> >>> >> Maybe not much because M is supposed to be set to 1, but you still n= eed to >>> >> care when enabling fractional mode, and setting M to 1 because that'= s exactly >>> >> the bad scenario if M was previously higher than 1. >>> >> >>> >> It's tricky. >>> >> >>> >> Having GPU module clock gated during PLL config changes may help! Yo= u can >>> >> do that without locking yourself out, unlike with the CPU PLL. >>> >> >>> >> There's a gate enable bit for it at GPU_CLK_REG.SCLK_GATING. (page 1= 22) >>> >>> The GPU should already be properly gated: >>> https://elixir.bootlin.com/linux/v6.7.4/source/drivers/clk/sunxi-ng/ccu= -sun50i-a64.c#L599 >> >> How so? That's just clock declaration. How does it guarantee the clock t= o the >> module is gated during parent PLL configuration changes? >> > > You're of course right. > > I now tried using a similar approach like the one for changes for on > PLL-CPU. It's using a notifier to connect the CPU to the 24 MHz > oscillator and, after PLL-CPU is at its new rate, connecting it back to > PLL-CPU. > > For the GPU my approach was to disable the GPU prior to changing > PLL-GPU's rate and then re-enabling it, once the rate change is > complete. I think, that's what you were proposing, right? > > Unfortunately, this results in a frozen phone even more quickly. > > Below is my code. Again, it doesn't solve the problem, but maybe > somebody can spot what I'm doing wrong. It seems to me that all options for changing the GPU's rate in a stable manner have been exhausted. There seems to be no common interpretation what the phrase "Clock output of PLL_GPU can be used for GPU;and dynamic frequency scaling is not supported" in the Allwinner A64 manual (chapter 3.3.3) means. The BSP uses a fixed rate of 432 MHz. Unless one of you has a clever idea, I suggest to remove the OPPs from the device tree and set the GPU to 432 MHz. What are your thoughts on that? Best regards, Frank > > Best regards, > Frank > > diff --git a/drivers/clk/sunxi-ng/ccu-sun50i-a64.c b/drivers/clk/sunxi-ng= /ccu-sun50i-a64.c > index d68bdf7dd342..74538259d67a 100644 > --- a/drivers/clk/sunxi-ng/ccu-sun50i-a64.c > +++ b/drivers/clk/sunxi-ng/ccu-sun50i-a64.c > @@ -977,6 +977,11 @@ static struct ccu_rate_reset_nb sun50i_a64_pll_video= 0_reset_tcon0_nb =3D { > > #define CCU_MIPI_DSI_CLK 0x168 > > +static struct ccu_div_nb sun50i_a64_gpu_nb =3D { > + .common =3D &gpu_clk.common, > + .delay_us =3D 1, /* ??? */ > +}; > + > static int sun50i_a64_ccu_probe(struct platform_device *pdev) > { > void __iomem *reg; > @@ -1025,6 +1030,10 @@ static int sun50i_a64_ccu_probe(struct platform_de= vice *pdev) > sun50i_a64_pll_video0_reset_tcon0_nb.target_clk =3D tcon0_clk.common.hw= clk; > ccu_rate_reset_notifier_register(&sun50i_a64_pll_video0_reset_tcon0_nb); > > + /* Gate then ungate GPU on PLL-GPU changes */ > + ccu_div_notifier_register(pll_gpu_clk.common.hw.clk, > + &sun50i_a64_gpu_nb); > + > return 0; > } > > diff --git a/drivers/clk/sunxi-ng/ccu_div.c b/drivers/clk/sunxi-ng/ccu_di= v.c > index cb10a3ea23f9..83813c54fb2f 100644 > --- a/drivers/clk/sunxi-ng/ccu_div.c > +++ b/drivers/clk/sunxi-ng/ccu_div.c > @@ -4,7 +4,9 @@ > * Maxime Ripard > */ > > +#include > #include > +#include > #include > > #include "ccu_gate.h" > @@ -142,3 +144,37 @@ const struct clk_ops ccu_div_ops =3D { > .set_rate =3D ccu_div_set_rate, > }; > EXPORT_SYMBOL_NS_GPL(ccu_div_ops, SUNXI_CCU); > + > +static int ccu_div_notifier_cb(struct notifier_block *nb, > + unsigned long event, void *data) > +{ > + struct ccu_div_nb *div_nb =3D to_ccu_div_nb(nb); > + > + if (event =3D=3D PRE_RATE_CHANGE) { > + div_nb->original_enable =3D ccu_div_is_enabled(&div_nb->common->hw); > + if (div_nb->original_enable) { > + ccu_div_disable(&div_nb->common->hw); > + udelay(div_nb->delay_us); > + } > + } else if (event =3D=3D POST_RATE_CHANGE) { > + if (div_nb->original_enable) { > + ccu_div_enable(&div_nb->common->hw); > + udelay(div_nb->delay_us); > + } > + } > + > + return NOTIFY_OK; > +} > + > +int ccu_div_notifier_register(struct clk *clk, struct ccu_div_nb *div_nb) > +{ > + div_nb->clk_nb.notifier_call =3D ccu_div_notifier_cb; > + > + return clk_notifier_register(clk, &div_nb->clk_nb); > +} > diff --git a/drivers/clk/sunxi-ng/ccu_div.h b/drivers/clk/sunxi-ng/ccu_di= v.h > index 90d49ee8e0cc..e096c7be5dca 100644 > --- a/drivers/clk/sunxi-ng/ccu_div.h > +++ b/drivers/clk/sunxi-ng/ccu_div.h > @@ -283,4 +283,16 @@ static inline struct ccu_div *hw_to_ccu_div(struct c= lk_hw *hw) > > extern const struct clk_ops ccu_div_ops; > > +struct ccu_div_nb { > + struct notifier_block clk_nb; > + struct ccu_common *common; > + > + u32 delay_us; /* us to wait after changing parent rate */ > + int original_enable;/* This is set by the notifier callback */ > +}; > + > +#define to_ccu_div_nb(_nb) container_of(_nb, struct ccu_div_nb, clk_nb) > + > +int ccu_div_notifier_register(struct clk *clk, struct ccu_div_nb *mux_nb= ); > + > #endif /* _CCU_DIV_H_ */ > > > >> >> CLK_SET_RATE_PARENT only gates output on re-parenting, not on parent rat= e changes, >> according to the header: >> >> https://elixir.bootlin.com/linux/v6.7.4/source/include/linux/clk-provi= der.h#L19 >> >> You'd need perhaps CLK_SET_RATE_GATE *and* still verify that it actually= works >> as expected via some tracing of gpu clock enable/disable/set_rate and pl= l-gpu >> set_rate. CLK_SET_RATE_GATE seems confusingly docummented: >> >> https://elixir.bootlin.com/linux/v6.7.4/source/drivers/clk/clk.c#L1034 >> >> so I don't particularly trust it does exaclty what the header claims and= what >> would be needed to test the theory that gating gpu clock during rate cha= nge >> might help. >> >> kind regards, >> o. >> >>> Thank you for your detailed proposal! It was insightful to read. But >>> while those were all great ideas, they have all already been taken care >>> of. I'm fresh out of ideas again (except for pinning the GPU rate). >>> >>> Again, thank you so much, >>> Frank >>> >>> >> >>> >> Kind regards, >>> >> o. >>> >> >>> >> > I very much appreciate your feedback! >>> >> > >>> >> > [1] https://gitlab.com/postmarketOS/pmaports/-/issues/805 >>> >> > >>> >> > Signed-off-by: Frank Oltmanns >>> >> > --- >>> >> > Changes in v2: >>> >> > - dts: Increase minimum GPU frequency to 192 MHz. >>> >> > - nkm and a64: Add minimum and maximum rate for PLL-MIPI. >>> >> > - nkm: Use the same approach for skipping invalid rates in >>> >> > ccu_nkm_find_best() as in ccu_nkm_find_best_with_parent_adj(). >>> >> > - nkm: Improve names for ratio struct members and hence get rid of >>> >> > describing comments. >>> >> > - nkm and a64: Correct description in the commit messages: M/N <= =3D 3 >>> >> > - Remove patches for nm as they were not needed. >>> >> > - st7703: Rework the commit message to cover more background for t= he >>> >> > change. >>> >> > - Link to v1: https://lore.kernel.org/r/20231218-pinephone-pll-fix= es-v1-0-e238b6ed6dc1@oltmanns.dev >>> >> > >>> >> > --- >>> >> > Frank Oltmanns (6): >>> >> > clk: sunxi-ng: nkm: Support constraints on m/n ratio and par= ent rate >>> >> > clk: sunxi-ng: a64: Add constraints on PLL-MIPI's n/m ratio = and parent rate >>> >> > clk: sunxi-ng: nkm: Support minimum and maximum rate >>> >> > clk: sunxi-ng: a64: Set minimum and maximum rate for PLL-MIPI >>> >> > drm/panel: st7703: Drive XBD599 panel at higher clock rate >>> >> > arm64: dts: allwinner: a64: Fix minimum GPU OPP rate >>> >> > >>> >> > arch/arm64/boot/dts/allwinner/sun50i-a64.dtsi | 4 ++-- >>> >> > drivers/clk/sunxi-ng/ccu-sun50i-a64.c | 14 +++++++---- >>> >> > drivers/clk/sunxi-ng/ccu_nkm.c | 34 ++++++++++++++= +++++++++++++ >>> >> > drivers/clk/sunxi-ng/ccu_nkm.h | 4 ++++ >>> >> > drivers/gpu/drm/panel/panel-sitronix-st7703.c | 14 +++++------ >>> >> > 5 files changed, 56 insertions(+), 14 deletions(-) >>> >> > --- >>> >> > base-commit: 059c53e877ca6e723e10490c27c1487a63e66efe >>> >> > change-id: 20231218-pinephone-pll-fixes-0ccdfde273e4 >>> >> > >>> >> > Best regards, >>> >> > -- >>> >> > Frank Oltmanns >>> >> >