imx: mx7ulp: Fix SPLL/APLL clock rate calculation issue
The num/denom is a float value, but in the calculation it is convert to integer 0, and wrong result. Signed-off-by: Ye Li <ye.li@nxp.com> Signed-off-by: Peng Fan <peng.fan@nxp.com> Cc: Stefano Babic <sbabic@denx.de>
This commit is contained in:
@ -504,7 +504,9 @@ u32 decode_pll(enum pll_clocks pll)
|
|||||||
num = readl(&scg1_regs->spllnum);
|
num = readl(&scg1_regs->spllnum);
|
||||||
denom = readl(&scg1_regs->splldenom);
|
denom = readl(&scg1_regs->splldenom);
|
||||||
|
|
||||||
return (infreq / pre_div) * (mult + num / denom);
|
infreq = infreq / pre_div;
|
||||||
|
|
||||||
|
return infreq * mult + infreq * num / denom;
|
||||||
|
|
||||||
case PLL_A7_APLL:
|
case PLL_A7_APLL:
|
||||||
reg = readl(&scg1_regs->apllcsr);
|
reg = readl(&scg1_regs->apllcsr);
|
||||||
@ -531,7 +533,9 @@ u32 decode_pll(enum pll_clocks pll)
|
|||||||
num = readl(&scg1_regs->apllnum);
|
num = readl(&scg1_regs->apllnum);
|
||||||
denom = readl(&scg1_regs->aplldenom);
|
denom = readl(&scg1_regs->aplldenom);
|
||||||
|
|
||||||
return (infreq / pre_div) * (mult + num / denom);
|
infreq = infreq / pre_div;
|
||||||
|
|
||||||
|
return infreq * mult + infreq * num / denom;
|
||||||
|
|
||||||
case PLL_USB:
|
case PLL_USB:
|
||||||
reg = readl(&scg1_regs->upllcsr);
|
reg = readl(&scg1_regs->upllcsr);
|
||||||
|
|||||||
Reference in New Issue
Block a user