mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 21:53:44 +00:00
clk: imx: fracn-gppll: fix fractional part of PLL getting lost
Fractional part of PLL gets lost after re-enabling the PLL. the
MFN can NOT be automatically loaded when doing frac PLL enable/disable,
So when re-enable PLL, configure mfn explicitly.
Fixes: 1b26cb8a77
("clk: imx: support fracn gppll")
Signed-off-by: Pengfei Li <pengfei.li_1@nxp.com>
Reviewed-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/20240607133347.3291040-5-peng.fan@oss.nxp.com
Signed-off-by: Abel Vesa <abel.vesa@linaro.org>
This commit is contained in:
parent
4717ccadb5
commit
7622f888fc
@ -291,6 +291,10 @@ static int clk_fracn_gppll_prepare(struct clk_hw *hw)
|
|||||||
if (val & POWERUP_MASK)
|
if (val & POWERUP_MASK)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (pll->flags & CLK_FRACN_GPPLL_FRACN)
|
||||||
|
writel_relaxed(readl_relaxed(pll->base + PLL_NUMERATOR),
|
||||||
|
pll->base + PLL_NUMERATOR);
|
||||||
|
|
||||||
val |= CLKMUX_BYPASS;
|
val |= CLKMUX_BYPASS;
|
||||||
writel_relaxed(val, pll->base + PLL_CTRL);
|
writel_relaxed(val, pll->base + PLL_CTRL);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user