ASoC: arizona: Correct relationship between VCO corner and Fref

When configuring the FLL we must ensure that the reference clock passed
to the FLL is under a certain limit. This limit was specified
incorrectly in the current code, this patch corrects this. Although the
error will only be encountered in some edge cases.

Reported-by: Ryo Tsutsui <ryo.tsutsui@wolfsonmicro.com>
Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
This commit is contained in:
Charles Keepax 2014-07-09 17:41:45 +01:00 committed by Mark Brown
parent 29fee82940
commit 35a730a079

View File

@ -1578,8 +1578,8 @@ static int arizona_calc_fratio(struct arizona_fll *fll,
while (div <= ARIZONA_FLL_MAX_REFDIV) { while (div <= ARIZONA_FLL_MAX_REFDIV) {
for (ratio = init_ratio; ratio <= ARIZONA_FLL_MAX_FRATIO; for (ratio = init_ratio; ratio <= ARIZONA_FLL_MAX_FRATIO;
ratio++) { ratio++) {
if (ARIZONA_FLL_VCO_CORNER / (fll->vco_mult * ratio) < if ((ARIZONA_FLL_VCO_CORNER / 2) /
Fref) (fll->vco_mult * ratio) < Fref)
break; break;
if (target % (ratio * Fref)) { if (target % (ratio * Fref)) {