diff options
author | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2010-12-03 11:02:10 -0500 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2010-12-03 11:45:12 -0500 |
commit | 4514e8997fbefd5befd6176ac9785e287b4daed4 (patch) | |
tree | d0f94af96bce10bd79aac2735af4a4aa3f87e202 | |
parent | 062869382bb2821bb8482db1e67850dfd11296fb (diff) |
ASoC: When disabling WM8994 FLL force a source selection
When we disable the WM8994 FLL code path sharing means that we end up
writing out a configuration. Currently this is the currently active
input and output frequency (which causes snd_soc_update_bits() to
suppress actual writes both immediately and in the common case where
we reenable the same configuration later) but we allow machine drivers
to pass through a source of zero. Since the register values written
are one less than the source constants this causes corruption of other
bitfields in the register.
Fix this by using the most recently configured FLL source when none is
provided.
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Cc: stable@kernel.org
-rw-r--r-- | sound/soc/codecs/wm8994.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/sound/soc/codecs/wm8994.c b/sound/soc/codecs/wm8994.c index af3a98ae0579..b37e95c4e7c7 100644 --- a/sound/soc/codecs/wm8994.c +++ b/sound/soc/codecs/wm8994.c | |||
@@ -1677,6 +1677,7 @@ static int _wm8994_set_fll(struct snd_soc_codec *codec, int id, int src, | |||
1677 | /* Allow no source specification when stopping */ | 1677 | /* Allow no source specification when stopping */ |
1678 | if (freq_out) | 1678 | if (freq_out) |
1679 | return -EINVAL; | 1679 | return -EINVAL; |
1680 | src = wm8994->fll[id].src; | ||
1680 | break; | 1681 | break; |
1681 | case WM8994_FLL_SRC_MCLK1: | 1682 | case WM8994_FLL_SRC_MCLK1: |
1682 | case WM8994_FLL_SRC_MCLK2: | 1683 | case WM8994_FLL_SRC_MCLK2: |