On Wed, 07 Sep 2016 19:58:31 +0200, Heiko Stuebner wrote: > Am Mittwoch, 7. September 2016, 17:53:29 CEST schrieb John Keeping: > > To minimize jitter on the I2S clocks, it is important that the > > denominator in the fractional divider is much greater than the > > numerator. Add identifiers for these internal clocks so that the > > specific clock topology and rates can be specified in the device tree. > > The TRM states that the denominator must be bigger than 20. Is this the one > you found or did you find further constraints? Is it not that the denominator must be bigger than 20 times the numerator? That's what we found, although it seems that the greater the divisor the better, so our aim is dividing down from 594MHz from GPLL to the target rate in i2s_frac. > Did you try teaching the fractional divider to handle these constraints before > going this way? No, I hadn't looked at doing that. I'm not sure how that would work, we'd need to add support for fractional divider changing the parent rate wouldn't we? > Exporting the internal clocks really would be sort of plan d or e, after > handling this in the clock framework failed. Especially as i2s rates are > probably dependant on the media being handled (frequencies and such), so > setting fractional rates statically in the dts won't help you much in the > general case, as any new playback could trigger a clk_set_rate call anyway? We're not setting the fractional rate specifically, instead we're setting the i2s_pre rate and parent explicitly and banning the i2s_src mux setting to i2s_pre, which means that clk_set_rate on sclk_i2s0 will always change i2s_frac but leave i2s_pre alone. > > Signed-off-by: John Keeping <john at metanate.com> > > --- > > include/dt-bindings/clock/rk3288-cru.h | 3 +++ > > 1 file changed, 3 insertions(+) > > > > diff --git a/include/dt-bindings/clock/rk3288-cru.h > > b/include/dt-bindings/clock/rk3288-cru.h index 9a586e2d9c91..9526653383d9 > > 100644 > > --- a/include/dt-bindings/clock/rk3288-cru.h > > +++ b/include/dt-bindings/clock/rk3288-cru.h > > @@ -88,6 +88,9 @@ > > #define SCLK_PVTM_GPU 124 > > #define SCLK_CRYPTO 125 > > #define SCLK_MIPIDSI_24M 126 > > +#define SCLK_I2S_PRE 127 > > +#define SCLK_I2S_SRC 128 > > +#define SCLK_I2S_FRAC 129 > > > > #define SCLK_MAC 151 > > #define SCLK_MACREF_OUT 152 > >