clk: sprd: fix to get a correct ibias of pll
The current driver is getting a wrong ibias index of pll clocks from
number 1. This patch fix that issue, then getting ibias index from 0.
Fixes: 3e37b00558
("clk: sprd: add adjustable pll support")
Signed-off-by: Chunyan Zhang <chunyan.zhang@unisoc.com>
Link: https://lkml.kernel.org/r/20200330021640.14133-1-zhang.lyra@gmail.com
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
This commit is contained in:
Родитель
0e4b8a2349
Коммит
39d1c90665
|
@ -87,11 +87,12 @@ static u32 pll_get_ibias(u64 rate, const u64 *table)
|
||||||
{
|
{
|
||||||
u32 i, num = table[0];
|
u32 i, num = table[0];
|
||||||
|
|
||||||
for (i = 1; i < num + 1; i++)
|
/* table[0] indicates the number of items in this table */
|
||||||
if (rate <= table[i])
|
for (i = 0; i < num; i++)
|
||||||
|
if (rate <= table[i + 1])
|
||||||
break;
|
break;
|
||||||
|
|
||||||
return (i == num + 1) ? num : i;
|
return i == num ? num - 1 : i;
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned long _sprd_pll_recalc_rate(const struct sprd_pll *pll,
|
static unsigned long _sprd_pll_recalc_rate(const struct sprd_pll *pll,
|
||||||
|
|
Загрузка…
Ссылка в новой задаче