clk: at91: fix recalc_rate implementation of PLL driver
authorBoris BREZILLON <boris.brezillon@free-electrons.com>
Tue, 2 Sep 2014 07:50:16 +0000 (09:50 +0200)
committerMike Turquette <mturquette@linaro.org>
Tue, 2 Sep 2014 22:37:17 +0000 (15:37 -0700)
Use the cached values to calculate PLL rate instead of the register values.
This is required to prevent erroneous PLL rate return when the PLL rate
has been configured but the PLL is not prepared yet.

Signed-off-by: Boris BREZILLON <boris.brezillon@free-electrons.com>
Reported-by: Gaël PORTAY <gael.portay@gmail.com>
Tested-by: Gaël PORTAY <gael.portay@gmail.com>
Signed-off-by: Mike Turquette <mturquette@linaro.org>
drivers/clk/at91/clk-pll.c

index a1adcf186023466bb000443fd57df5e71b313977..6ec79dbc0840ad8940e9e9ab599a0f865f1cd881 100644 (file)
@@ -151,16 +151,11 @@ static unsigned long clk_pll_recalc_rate(struct clk_hw *hw,
                                         unsigned long parent_rate)
 {
        struct clk_pll *pll = to_clk_pll(hw);
-       const struct clk_pll_layout *layout = pll->layout;
-       struct at91_pmc *pmc = pll->pmc;
-       int offset = PLL_REG(pll->id);
-       u32 tmp = pmc_read(pmc, offset) & layout->pllr_mask;
-       u8 div = PLL_DIV(tmp);
-       u16 mul = PLL_MUL(tmp, layout);
-       if (!div || !mul)
+
+       if (!pll->div || !pll->mul)
                return 0;
 
-       return (parent_rate * (mul + 1)) / div;
+       return (parent_rate / pll->div) * (pll->mul + 1);
 }
 
 static long clk_pll_get_best_div_mul(struct clk_pll *pll, unsigned long rate,