lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID:
 <DB9PR04MB84613DADFD29C8592F7D511D88F42@DB9PR04MB8461.eurprd04.prod.outlook.com>
Date: Tue, 4 Feb 2025 00:31:50 +0000
From: Peng Fan <peng.fan@....com>
To: Cristian Marussi <cristian.marussi@....com>, "Peng Fan (OSS)"
	<peng.fan@....nxp.com>
CC: Stephen Boyd <sboyd@...nel.org>, Michael Turquette
	<mturquette@...libre.com>, Russell King <linux@...linux.org.uk>, Sudeep Holla
	<sudeep.holla@....com>, "linux-clk@...r.kernel.org"
	<linux-clk@...r.kernel.org>, "linux-kernel@...r.kernel.org"
	<linux-kernel@...r.kernel.org>, "arm-scmi@...r.kernel.org"
	<arm-scmi@...r.kernel.org>, "linux-arm-kernel@...ts.infradead.org"
	<linux-arm-kernel@...ts.infradead.org>, Rob Herring <robh@...nel.org>,
	Krzysztof Kozlowski <krzk@...nel.org>, Dario Binacchi
	<dario.binacchi@...rulasolutions.com>, Shawn Guo <shawnguo@...nel.org>,
	Sascha Hauer <s.hauer@...gutronix.de>, Pengutronix Kernel Team
	<kernel@...gutronix.de>, Fabio Estevam <festevam@...il.com>,
	"imx@...ts.linux.dev" <imx@...ts.linux.dev>
Subject: RE: [PATCH 1/3] clk: Introduce clk_set_spread_spectrum

> Subject: Re: [PATCH 1/3] clk: Introduce clk_set_spread_spectrum
> 
> On Mon, Feb 03, 2025 at 07:47:22PM +0800, Peng Fan wrote:
> > On Mon, Feb 03, 2025 at 09:43:39AM +0000, Cristian Marussi wrote:
> > >On Sun, Feb 02, 2025 at 06:42:56PM +0800, Peng Fan wrote:
> > >> On Tue, Jan 28, 2025 at 12:25:28PM -0800, Stephen Boyd wrote:
> > >> >Quoting Peng Fan (OSS) (2025-01-24 06:25:17)
> > >> >> diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c index
> > >> >>
> cf7720b9172ff223d86227aad144e15375ddfd86..a4fe4a60f839244b7
> 36e3c
> > >> >> 2751eeb38dc4577b1f 100644
> > >> >> --- a/drivers/clk/clk.c
> > >> >> +++ b/drivers/clk/clk.c
> 
> Hi Peng,
> 
> > >> >> @@ -2790,6 +2790,45 @@ int clk_set_max_rate(struct clk *clk,
> > >> >> unsigned long rate)  }  EXPORT_SYMBOL_GPL(clk_set_max_rate);
> 
> [snip]
> 
> > >> >
> > >> >> + *
> > >> >> + * Configure the spread spectrum parameters for a clock.
> > >> >> + *
> > >> >> + * Returns success (0) or negative errno.
> > >> >> + */
> > >> >> +int clk_set_spread_spectrum(struct clk *clk, unsigned int
> modfreq,
> > >> >
> > >> >Does this need to be a consumer API at all? Usually SSC is figured
> out
> > >> >when making a board and you have to pass some certification
> testing
> > >> >because some harmonics are interfering. Is the DT property
> sufficient
> > >> >for now and then we can do it when the driver probes in the
> framework?
> > >>
> > >> I suppose 'DT property' you are refering the stm32 and i.MX8M
> SSC patchsets.
> > >> I am proposing a generic interface for drivers to enable SSC.
> > >> Otherwise we need to introduce vendor properties for each
> vendor.
> > >> And looking at clk-scmi.c, we need a generic way to enable SSC, I
> think SCMI
> > >> maintainers not agree to add vendor properties for it.
> > >>
> > >
> > >To clarify, from the SCMI point of view, I expressed the idea that it
> > >would make sense to have a common SSC interface on the SCMI
> backend too
> > >instead of a custom NXP since you are adding a common CLK
> framework feature,
> > >BUT only if it turns out, from this discussion, that a common general
> way of
> > >configuring SSC can be found...and I dont know that, so I am waiting
> to see
> > >what this discussion with CLK framework and iMX maintainers goes
> before
> > >excluding the SCMI CLK vendor OEM types scenario...it would be
> ideal and
> > >easier NOT to use SCMI vendor extensions BUT ONLY if this NXP
> SSC/config generic
> > >solution is deemed to be really generic and usable by any other
> vendor.
> >
> > You may misunderstand. Using DT properties for clk-scmi.c to
> configure SSC
> > of a single clock means to add properties under clk scmi node, such
> > as:
> > "arm,modfreq = <x>, <y>, <z>;
> >  arm,moddepth = <a>, <b>, <c>;
> >  arm,modmethod = <j>, <l>, <m>;"
> >
> > And during probe in clk-scmi.c, the properties needs to be parsed and
> when
> > clk is configured, the ssc settings need to be passed to scmi platform.
> >
> > But per the i.MX8M SSC patchset that DT maintainers raised,
> > the properties(fsl,modfreq and etc) needs to in consumer side,
> > not provider side.
> >
> > So it is not feasible to add properties here.
> >
> 
> Thanks for the clarification.
> 
> > "assigned-clock-sscs" could be put under consumer node and clocks
> > could be configured with SSC when needed. This is a generic property.
> >
> 
> Yes I understood this, the property that describes SSC that you are
> adding is generic BUT are also the related params needed to describe
> effectively the SSC
> 
> IOW, if we add, as desirable, a generic new SSC type in extended
> configs
> instead of using a vendor oem, will these info down below passed to
> the SCMI:
> 
> +       /*
> +        * extConfigValue[7:0]   - spread percentage (%)
> +        * extConfigValue[23:8]  - Modulation Frequency (KHz)
> +        * extConfigValue[24]    - Enable/Disable
> +        * extConfigValue[31:25] - Reserved
> +        */

>From SSC view, spread percent(depth),  modulation freq, modulation
method is required to be passed to SCMI server. Enable maybe
optional(depth set to 0 should be same as disable).

The upper encodings using extConfig is NXP defined, we could
update following spec.

> 
> 
> ... be enough to describe the required SSC config to any generic SCMI
> server
> from any vendor using any HW ?
> 
> ... or is it plausible and maybe frequent/usual that other vendors could
> need additional specific params to be fed to the server, so that we
> will end up using the new standard SSC only for NXP ?

I checked TI/STM32/Renesas spec.
https://www.ti.com/lit/an/spraby0a/spraby0a.pdf?ts=1738492934158&ref_url=https%253A%252F%252Fwww.google.com.hk%252F
https://www.st.com/resource/en/application_note/an4850-stm32-mcus-spreadspectrum-clock-generation-principles-properties-and-implementation-stmicroelectronics.pdf
https://www.renesas.com/en/products/clocks-timing/application-specific-clocks/spread-spectrum-clocks?srsltid=AfmBOoqSceW72dYO41RZVhT1YxhyKeXNhWUTfSrSCpfZt2A2cy7JgaGv

same parameters are required.

>From ADI:
https://www.analog.com/en/resources/technical-articles/clock-generation-with-spread-spectrum.html
"
Creating a spread-spectrum CLK by dithering the CLK frequency is not as
straightforward as it might appear. We begin by defining parameters that
comprise a spread-spectrum CLK: spreading rate, spreading style,
modulation rate, and modulation waveform. Spreading rate is the ratio
of the range of dithering (or spreading) frequency over the original CLK
frequency, fC. Spreading style is down-spreading, center-spreading, or up-spreading.
If we assume that the spreading frequency range is Δf, the spreading rate, δ, is defined as:

Down spreading: δ = -Δf /fC x 100%

Center spreading: δ = ±1/2Δf/fC x 100%

Up spreading: δ = Δf/fC x 100%
"

fC is same as spread percentage/depth.

> 
> IOW the property is generic, agreed, but are the described params
> above
> generic enough too ? ... 

I think so.

Thanks,
Peng.

that was my concern from an UN-educated
> point
> of view...of course, I am talking about the most common scenarios, if
> some other vendor ends up needing some arcane/magic specific param
> that
> cannot fit the above, they will be relegated to the OEM custom spaces
> even if this common SSC is available.
> 
> > Back to NXP SCMI vendor extension, if SCMI spec could include SSC,
> NXP
> > SCMI could move to align with spec and not use vendor extension.
> >
> 
> Agreed, conditional to the above doubts.
> 
> Apologies if I have asked dumb/obvious questions, but I am not
> familiar
> with the subject matter enough...
> 
> Thanks,
> Cristian

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ