Am Dienstag, 7. Oktober 2014, 10:03:19 schrieb Doug Anderson: > Kever, > > On Tue, Oct 7, 2014 at 2:33 AM, Kever Yang <kever.yang at rock-chips.com> wrote: > > We need to initialize PLL rate and some of bus clock rate while > > kernel init, for there is no other module will do that. > > > > Signed-off-by: Kever Yang <kever.yang at rock-chips.com> > > --- > > > > arch/arm/boot/dts/rk3288.dtsi | 10 ++++++++++ > > 1 file changed, 10 insertions(+) > > > > diff --git a/arch/arm/boot/dts/rk3288.dtsi b/arch/arm/boot/dts/rk3288.dtsi > > index 874e66d..2f4519b 100644 > > --- a/arch/arm/boot/dts/rk3288.dtsi > > +++ b/arch/arm/boot/dts/rk3288.dtsi > > @@ -455,6 +455,16 @@ > > > > rockchip,grf = <&grf>; > > #clock-cells = <1>; > > #reset-cells = <1>; > > > > + assigned-clocks = <&cru PLL_GPLL>, <&cru PLL_CPLL>, > > + <&cru PLL_NPLL>, <&cru ACLK_CPU>, > > + <&cru HCLK_CPU>, <&cru PCLK_CPU>, > > + <&cru ACLK_PERI>, <&cru HCLK_PERI>, > > + <&cru PCLK_PERI>; > > + assigned-clock-rates = <594000000>, <400000000>, > > + <500000000>, <300000000>, > > When I boot up, I see that ACLK_CPU was 297000000. You specified > 300000000. Did you expect to get 300? If you expected 297, I think > you should put 297. If you expected 300 then we have some debugging > to do. Note: I'm not quite sure how you'd expect to get 300 given > that none of the PLLs divide evenly to 300... I'd think 300 is simply the target value. I.e. take the closest rate <= 300 MHz, same for 150 etc. I somehow like the approach of specifying what the rate _should_ ideally be :-) . Also reduces the amount of thougths necessary (and possible head-scratching) when adapting the pll rates to some other constraints (child-clocks already have the target rates and cannot drop to some even stranger value). Heiko > > > + <150000000>, <75000000>, > > Similarly, I see 148500000, 74250000 > > > + <300000000>, <150000000>, > > 297000000, 148500000 > > > + <75000000>; > > 74250000 > > > }; > > > > grf: syscon at ff770000 { > > > > -- > > 1.9.1