From: Adam Ford <aford173@gmail.com>
To: Peng Fan <peng.fan@nxp.com>
Cc: Krzysztof Kozlowski <krzk@kernel.org>,
Dario Binacchi <dario.binacchi@amarulasolutions.com>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-amarula@amarulasolutions.com"
<linux-amarula@amarulasolutions.com>,
Abel Vesa <abelvesa@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
Fabio Estevam <festevam@gmail.com>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Michael Turquette <mturquette@baylibre.com>,
Pengutronix Kernel Team <kernel@pengutronix.de>,
Rob Herring <robh@kernel.org>,
Sascha Hauer <s.hauer@pengutronix.de>,
Shawn Guo <shawnguo@kernel.org>, Stephen Boyd <sboyd@kernel.org>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"imx@lists.linux.dev" <imx@lists.linux.dev>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"linux-clk@vger.kernel.org" <linux-clk@vger.kernel.org>
Subject: Re: [PATCH v3 1/8] dt-bindings: clock: imx8m-clock: support spread spectrum clocking
Date: Fri, 8 Nov 2024 18:56:56 -0600 [thread overview]
Message-ID: <CAHCN7xLSw7sBywVJ0ZcoOy4ao8x8GxpVwg8=4h-HoOxEsz565w@mail.gmail.com> (raw)
In-Reply-To: <PAXPR04MB8459B6F8D5C623D19CCF6B39885E2@PAXPR04MB8459.eurprd04.prod.outlook.com>
On Fri, Nov 8, 2024 at 6:37 PM Peng Fan <peng.fan@nxp.com> wrote:
>
> > Subject: Re: [PATCH v3 1/8] dt-bindings: clock: imx8m-clock: support
> > spread spectrum clocking
> >
> > On 08/11/2024 13:50, Peng Fan wrote:
> > >> Subject: Re: [PATCH v3 1/8] dt-bindings: clock: imx8m-clock:
> > support
> > >> spread spectrum clocking
> > >>
> > >> On 07/11/2024 15:57, Dario Binacchi wrote:
> > >>> clocks = <&osc_32k>, <&osc_24m>, <&clk_ext1>, <&clk_ext2>,
> > >>> <&clk_ext3>, <&clk_ext4>;
> > >>> clock-names = "osc_32k", "osc_24m", "clk_ext1", "clk_ext2",
> > >>> "clk_ext3", "clk_ext4";
> > >>> assigned-clocks = <&clk IMX8MN_CLK_A53_SRC>,
> > >>> <&clk IMX8MN_CLK_A53_CORE>,
> > >>> <&clk IMX8MN_CLK_NOC>,
> > >>> <&clk IMX8MN_CLK_AUDIO_AHB>,
> > >>> <&clk IMX8MN_CLK_IPG_AUDIO_ROOT>,
> > >>> <&clk IMX8MN_SYS_PLL3>,
> > >>> <&clk IMX8MN_AUDIO_PLL1>,
> > >>> <&clk IMX8MN_AUDIO_PLL2>;
> > >>> assigned-clock-parents = <&clk IMX8MN_SYS_PLL1_800M>,
> > >>> <&clk IMX8MN_ARM_PLL_OUT>,
> > >>> <&clk IMX8MN_SYS_PLL3_OUT>,
> > >>> <&clk IMX8MN_SYS_PLL1_800M>;
> > >>> assigned-clock-rates = <0>, <0>, <0>,
> > >>> <400000000>,
> > >>> <400000000>,
> > >>> <600000000>,
> > >>> <393216000>,
> > >>> <361267200>; };
> > >>>
> > >>> The spread spectrum is not configurable on these clocks or, more
> > >>> generally, may not be configurable (only 4 PLLs have this
> > capability).
> > >>> Therefore, I need the "fsl,ssc-clocks"
> > >>
> > >> No. That's not true. You do not need it.
> > >>
> > >
> > > i.MX8M clock hardware is similar as:
> > >
> > > OSC->ANATOP->CCM
> > >
> > > ANATOP will produce PLLs.
> > > CCM use PLLs as input source.
> > >
> > > Currently there is no dedicated ANATOP driver in linux.
> > > The CCM linux driver will parse the ANATOP node and register clk_hw
> > > for the PLLs.
> >
> > I do not know what is CCM and how does it fit here. What's more, I
> > don't get driver context here. We talk about bindings.
>
>
> CCM: Clock Control Module, it accepts PLL from anatop as inputs,
> and outputs clocks to various modules, I2C, CAN, NET, SAI and ...
>
> >
> >
> > >
> > >
> > >> First, the clock inputs for this device are listed in clocks *only*.
> > >> What is no there, is not an input to the device. Including also Linux
> > >> aspect (missing devlinks etc). Therefore how can you configure
> > spread
> > >> spectrum on clocks which are not connected to this device?
> > >
> > > I not understand this well, you mean
> > > add clocks = <xx CLK_IMX8MM_VIDEO_PLL> in the ccm dtb node?
> >
> > Yes. Let me re-iterate and please respond to this exactly comment
> > instead of ignoring it.
> >
> > How a device can care about spread spectrum of a clock which is not
> > supplied to this device?
>
> I hope we are on same page of what spread spectrum means.
> spread spectrum of a clock is the clock could produce freq in a range,
> saying [500MHz - 100KHz, 500MHz + 100KHz]. software only need
> to configure the middle frequency and choose the up/down border
> range(100KHz here) and enable spread spectrum.
>
> device: I suppose you mean the Clock Control Module(CCM) here.
> CCM does not care, it just accepts the PLL as input, and output
> divided clock to various IPs(Video here). The video IPs care about
> the spread spectrum of the clock.
>
> The clock hardware path is as below:
>
> OSC(24M) --> Anatop(produce PLL with spread spectrum) ->
> Clock Control Module(output clock to modules) -> Video IP
>
> From hardware perspective, Clock Control Module does not
> care spread spectrum. Video IP cares spread spectrum.
>
>
> >
> > Why would you care about spread spectrum of some clock which is not
> > coming to this device?
>
> device, I suppose you mean clock control module(CCM).
>
> There is no 'clocks = <&ccm CLK_IMX8M_VIDEO_PLL>' under ccm node.
> Because in current design, ccm is taken as producer of
> CLK_IMX8M_VIDEO_PLL, not consumer.
>
> >
> > Please address these precisely because we talk about this for weeks in
> > multiple places.
>
> Sorry for coming into this feature in late stage.
>
> Dario, thanks for working on such feature, good to see. Spread Spectrum
> is indeed good feature what makes clock quality high.
I am also excited to see the spread-spectum clocks enabled. We've
struggled with EMC testing in the past, and I want to reevaluate at
least one board with the spread-spectrum enabled to see how it
compares.
Thank you for working on this.
adam
>
> Thanks,
> Peng.
>
> I finish with this patchset if you do not provide such
> > context.
> >
> > Best regards,
> > Krzysztof
>
next prev parent reply other threads:[~2024-11-09 0:57 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-06 8:57 [PATCH v3 0/8] Support spread spectrum clocking for i.MX8{M,N,P} PLLs Dario Binacchi
2024-11-06 8:57 ` [PATCH v3 1/8] dt-bindings: clock: imx8m-clock: support spread spectrum clocking Dario Binacchi
2024-11-06 14:10 ` Krzysztof Kozlowski
2024-11-06 14:13 ` Krzysztof Kozlowski
2024-11-07 14:57 ` Dario Binacchi
2024-11-08 12:12 ` Krzysztof Kozlowski
2024-11-08 12:50 ` Peng Fan
2024-11-08 14:10 ` Krzysztof Kozlowski
2024-11-09 0:37 ` Peng Fan
2024-11-09 0:56 ` Adam Ford [this message]
2024-11-09 10:05 ` Krzysztof Kozlowski
2024-11-09 10:20 ` Krzysztof Kozlowski
2024-11-11 1:49 ` Peng Fan
2024-11-11 11:57 ` Dario Binacchi
2024-11-11 13:45 ` Dario Binacchi
2024-11-17 10:59 ` Peng Fan
2024-11-19 13:53 ` Krzysztof Kozlowski
2024-11-19 14:07 ` Krzysztof Kozlowski
2024-11-20 10:11 ` Peng Fan
2024-11-06 8:57 ` [PATCH v3 2/8] clk: imx: pll14xx: support spread spectrum clock generation Dario Binacchi
2024-11-06 8:57 ` [PATCH v3 3/8] clk: imx: imx8mm: distinguish between ccm and anatop references Dario Binacchi
2024-11-06 8:58 ` [PATCH v3 4/8] clk: imx8mm: support spread spectrum clock generation Dario Binacchi
2024-11-06 8:58 ` [PATCH v3 5/8] clk: imx: imx8mn: distinguish between ccm and anatop references Dario Binacchi
2024-11-06 8:58 ` [PATCH v3 6/8] clk: imx8mn: support spread spectrum clock generation Dario Binacchi
2024-11-06 8:58 ` [PATCH v3 7/8] clk: imx8mp: don't lose the anatop device node Dario Binacchi
2024-11-06 8:58 ` [PATCH v3 8/8] clk: imx8mp: support spread spectrum clock generation Dario Binacchi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='CAHCN7xLSw7sBywVJ0ZcoOy4ao8x8GxpVwg8=4h-HoOxEsz565w@mail.gmail.com' \
--to=aford173@gmail.com \
--cc=abelvesa@kernel.org \
--cc=conor+dt@kernel.org \
--cc=dario.binacchi@amarulasolutions.com \
--cc=devicetree@vger.kernel.org \
--cc=festevam@gmail.com \
--cc=imx@lists.linux.dev \
--cc=kernel@pengutronix.de \
--cc=krzk+dt@kernel.org \
--cc=krzk@kernel.org \
--cc=linux-amarula@amarulasolutions.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-clk@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mturquette@baylibre.com \
--cc=peng.fan@nxp.com \
--cc=robh@kernel.org \
--cc=s.hauer@pengutronix.de \
--cc=sboyd@kernel.org \
--cc=shawnguo@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox