diff options
author | Shawn Guo <shawn.guo@linaro.org> | 2013-10-31 02:46:17 +0100 |
---|---|---|
committer | Shawn Guo <shawn.guo@linaro.org> | 2013-11-11 15:58:45 +0100 |
commit | 43c9b9e8a4c64b1dd3026ab233703a4321ac6d7c (patch) | |
tree | 214c780126ea7b8507dcb3f1e33d0dc824874386 | |
parent | ARM: imx: pllv3 needs relock in .set_rate() call (diff) | |
download | linux-43c9b9e8a4c64b1dd3026ab233703a4321ac6d7c.tar.xz linux-43c9b9e8a4c64b1dd3026ab233703a4321ac6d7c.zip |
ARM: imx: set up pllv3 POWER and BYPASS sequentially
Currently, POWER and BYPASS bits are set up in a single write to pllv3
register. This causes problem occasionally from the IPU/HDMI testing.
Let's follow FSL BSP code to set up POWER bit, relock, and then BYPASS
sequentially.
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
-rw-r--r-- | arch/arm/mach-imx/clk-pllv3.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/arch/arm/mach-imx/clk-pllv3.c b/arch/arm/mach-imx/clk-pllv3.c index df1736232961..61364050fccd 100644 --- a/arch/arm/mach-imx/clk-pllv3.c +++ b/arch/arm/mach-imx/clk-pllv3.c @@ -71,16 +71,24 @@ static int clk_pllv3_prepare(struct clk_hw *hw) { struct clk_pllv3 *pll = to_clk_pllv3(hw); u32 val; + int ret; val = readl_relaxed(pll->base); - val &= ~BM_PLL_BYPASS; if (pll->powerup_set) val |= BM_PLL_POWER; else val &= ~BM_PLL_POWER; writel_relaxed(val, pll->base); - return clk_pllv3_wait_lock(pll); + ret = clk_pllv3_wait_lock(pll); + if (ret) + return ret; + + val = readl_relaxed(pll->base); + val &= ~BM_PLL_BYPASS; + writel_relaxed(val, pll->base); + + return 0; } static void clk_pllv3_unprepare(struct clk_hw *hw) |