]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
clk: imx: fracn-gppll: correct PLL initialization flow
authorPeng Fan <peng.fan@nxp.com>
Sun, 27 Oct 2024 12:00:08 +0000 (20:00 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 5 Dec 2024 12:53:37 +0000 (13:53 +0100)
[ Upstream commit 557be501c38e1864b948fc6ccdf4b035d610a2ea ]

Per i.MX93 Reference Mannual 22.4 Initialization information
1. Program appropriate value of DIV[ODIV], DIV[RDIV] and DIV[MFI]
   as per Integer mode.
2. Wait for 5 μs.
3. Program the following field in CTRL register.
   Set CTRL[POWERUP] to 1'b1 to enable PLL block.
4. Poll PLL_STATUS[PLL_LOCK] register, and wait till PLL_STATUS[PLL_LOCK]
   is 1'b1 and pll_lock output signal is 1'b1.
5. Set CTRL[CLKMUX_EN] to 1'b1 to enable PLL output clock.

So move the CLKMUX_EN operation after PLL locked.

Fixes: 1b26cb8a77a4 ("clk: imx: support fracn gppll")
Co-developed-by: Jacky Bai <ping.bai@nxp.com>
Signed-off-by: Jacky Bai <ping.bai@nxp.com>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
Reviewed-by: Abel Vesa <abel.vesa@linaro.org>
Link: https://lore.kernel.org/r/20241027-imx-clk-v1-v3-2-89152574d1d7@nxp.com
Signed-off-by: Abel Vesa <abel.vesa@linaro.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/clk/imx/clk-fracn-gppll.c

index 1becba2b62d0beb02fedcea912a073eadf14f525..f85dd8798f15c7edef2f83d555be1f8fb47af730 100644 (file)
@@ -301,13 +301,13 @@ static int clk_fracn_gppll_prepare(struct clk_hw *hw)
        val |= POWERUP_MASK;
        writel_relaxed(val, pll->base + PLL_CTRL);
 
-       val |= CLKMUX_EN;
-       writel_relaxed(val, pll->base + PLL_CTRL);
-
        ret = clk_fracn_gppll_wait_lock(pll);
        if (ret)
                return ret;
 
+       val |= CLKMUX_EN;
+       writel_relaxed(val, pll->base + PLL_CTRL);
+
        val &= ~CLKMUX_BYPASS;
        writel_relaxed(val, pll->base + PLL_CTRL);