Commit 61719db8 authored by Charles Keepax's avatar Charles Keepax Committed by Mark Brown

ASoC: arizona: Move set of OUTDIV in to arizona_apply_fll

Since we know in arizona_apply_fll if we are setting the sync or ref
path there is no need to set the outdiv seperately anymore. This patch
moves this from arizona_enable_fll to arizona_apply_fll.
Signed-off-by: default avatarCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: default avatarMark Brown <broonie@linaro.org>
parent 87383ac5
...@@ -1502,14 +1502,18 @@ static void arizona_apply_fll(struct arizona *arizona, unsigned int base, ...@@ -1502,14 +1502,18 @@ static void arizona_apply_fll(struct arizona *arizona, unsigned int base,
cfg->refdiv << ARIZONA_FLL1_CLK_REF_DIV_SHIFT | cfg->refdiv << ARIZONA_FLL1_CLK_REF_DIV_SHIFT |
source << ARIZONA_FLL1_CLK_REF_SRC_SHIFT); source << ARIZONA_FLL1_CLK_REF_SRC_SHIFT);
if (sync) if (sync) {
regmap_update_bits_async(arizona->regmap, base + 0x7, regmap_update_bits(arizona->regmap, base + 0x7,
ARIZONA_FLL1_GAIN_MASK, ARIZONA_FLL1_GAIN_MASK,
cfg->gain << ARIZONA_FLL1_GAIN_SHIFT); cfg->gain << ARIZONA_FLL1_GAIN_SHIFT);
else } else {
regmap_update_bits_async(arizona->regmap, base + 0x9, regmap_update_bits(arizona->regmap, base + 0x5,
ARIZONA_FLL1_GAIN_MASK, ARIZONA_FLL1_OUTDIV_MASK,
cfg->gain << ARIZONA_FLL1_GAIN_SHIFT); cfg->outdiv << ARIZONA_FLL1_OUTDIV_SHIFT);
regmap_update_bits(arizona->regmap, base + 0x9,
ARIZONA_FLL1_GAIN_MASK,
cfg->gain << ARIZONA_FLL1_GAIN_SHIFT);
}
regmap_update_bits_async(arizona->regmap, base + 2, regmap_update_bits_async(arizona->regmap, base + 2,
ARIZONA_FLL1_CTRL_UPD | ARIZONA_FLL1_N_MASK, ARIZONA_FLL1_CTRL_UPD | ARIZONA_FLL1_N_MASK,
...@@ -1546,10 +1550,6 @@ static void arizona_enable_fll(struct arizona_fll *fll, ...@@ -1546,10 +1550,6 @@ static void arizona_enable_fll(struct arizona_fll *fll,
*/ */
if (fll->ref_src >= 0 && fll->ref_freq && if (fll->ref_src >= 0 && fll->ref_freq &&
fll->ref_src != fll->sync_src) { fll->ref_src != fll->sync_src) {
regmap_update_bits_async(arizona->regmap, fll->base + 5,
ARIZONA_FLL1_OUTDIV_MASK,
ref->outdiv << ARIZONA_FLL1_OUTDIV_SHIFT);
arizona_apply_fll(arizona, fll->base, ref, fll->ref_src, arizona_apply_fll(arizona, fll->base, ref, fll->ref_src,
false); false);
if (fll->sync_src >= 0) { if (fll->sync_src >= 0) {
...@@ -1558,10 +1558,6 @@ static void arizona_enable_fll(struct arizona_fll *fll, ...@@ -1558,10 +1558,6 @@ static void arizona_enable_fll(struct arizona_fll *fll,
use_sync = true; use_sync = true;
} }
} else if (fll->sync_src >= 0) { } else if (fll->sync_src >= 0) {
regmap_update_bits_async(arizona->regmap, fll->base + 5,
ARIZONA_FLL1_OUTDIV_MASK,
sync->outdiv << ARIZONA_FLL1_OUTDIV_SHIFT);
arizona_apply_fll(arizona, fll->base, sync, arizona_apply_fll(arizona, fll->base, sync,
fll->sync_src, false); fll->sync_src, false);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment