ARM: mach-shmobile: sh73a0 CPGA fix for PLL CFG bit
authorMagnus Damm <damm@opensource.se>
Thu, 20 Jan 2011 08:11:11 +0000 (08:11 +0000)
committerPaul Mundt <lethal@linux-sh.org>
Thu, 20 Jan 2011 12:34:31 +0000 (21:34 +0900)
PLL1 and PLL2 in the sh73a0 CPGA has a CFG bit that
must be taken into account to correctly calculate the
frequency.

Signed-off-by: Magnus Damm <damm@opensource.se>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/arm/mach-shmobile/clock-sh73a0.c

index 08fb878ef063a7456131743d609789e1f1ead81f..bcaf58a9c153e8d0b5c6d66397226c11d219fbfd 100644 (file)
@@ -118,8 +118,16 @@ static unsigned long pll_recalc(struct clk *clk)
 {
        unsigned long mult = 1;
 
-       if (__raw_readl(PLLECR) & (1 << clk->enable_bit))
+       if (__raw_readl(PLLECR) & (1 << clk->enable_bit)) {
                mult = (((__raw_readl(clk->enable_reg) >> 24) & 0x3f) + 1);
+               /* handle CFG bit for PLL1 and PLL2 */
+               switch (clk->enable_bit) {
+               case 1:
+               case 2:
+                       if (__raw_readl(clk->enable_reg) & (1 << 20))
+                               mult *= 2;
+               }
+       }
 
        return clk->parent->rate * mult;
 }