summaryrefslogtreecommitdiffstats
path: root/sound/soc
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2011-07-15 20:12:18 +0200
committerMark Brown <broonie@opensource.wolfsonmicro.com>2011-07-17 06:15:00 +0200
commitf0f5039c3dcc6f80756128aa38f2a4f5b895bbf1 (patch)
treeac129fd3a0e51030fd3071396a47ba0acfc8be66 /sound/soc
parentASoC: Handle spurious wm_hubs DC servo done interrupts (diff)
downloadlinux-f0f5039c3dcc6f80756128aa38f2a4f5b895bbf1.tar.xz
linux-f0f5039c3dcc6f80756128aa38f2a4f5b895bbf1.zip
ASoC: Handle failed WM8994 FLL lock waits
Try the completion before we start the FLL so that if an interrupt was delayed long enough for us to miss it we don't wait for the completion it signalled. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc')
-rw-r--r--sound/soc/codecs/wm8994.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/sound/soc/codecs/wm8994.c b/sound/soc/codecs/wm8994.c
index ee64be2d9942..c749ef339665 100644
--- a/sound/soc/codecs/wm8994.c
+++ b/sound/soc/codecs/wm8994.c
@@ -1713,6 +1713,9 @@ static int _wm8994_set_fll(struct snd_soc_codec *codec, int id, int src,
(fll.clk_ref_div << WM8994_FLL1_REFCLK_DIV_SHIFT) |
(src - 1));
+ /* Clear any pending completion from a previous failure */
+ try_wait_for_completion(&wm8994->fll_locked[id]);
+
/* Enable (with fractional mode if required) */
if (freq_out) {
if (fll.k)