aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/wm8994.c
diff options
context:
space:
mode:
authorCharles Keepax <ckeepax@opensource.wolfsonmicro.com>2014-06-16 16:24:03 -0400
committerMark Brown <broonie@linaro.org>2014-06-17 10:48:04 -0400
commitb38314179c9ccb789e6fe967cff171fa817e8978 (patch)
tree10cfd970a63575f4557f67d990fb44568306184d /sound/soc/codecs/wm8994.c
parent7171511eaec5bf23fb06078f59784a3a0626b38f (diff)
ASoC: wm8994: Prevent double lock of accdet_lock mutex on wm1811
wm1811_micd_stop takes the accdet_lock mutex, and is called from two places, one of which is already holding the accdet_lock. This obviously causes a lock up. This patch fixes this issue by removing the lock from wm1811_micd_stop and ensuring that it is always locked externally. Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com> Signed-off-by: Mark Brown <broonie@linaro.org> Cc: stable@vger.kernel.org
Diffstat (limited to 'sound/soc/codecs/wm8994.c')
-rw-r--r--sound/soc/codecs/wm8994.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/sound/soc/codecs/wm8994.c b/sound/soc/codecs/wm8994.c
index 247b39013fba..9719d3ca8e47 100644
--- a/sound/soc/codecs/wm8994.c
+++ b/sound/soc/codecs/wm8994.c
@@ -3505,6 +3505,7 @@ static irqreturn_t wm8994_mic_irq(int irq, void *data)
3505 return IRQ_HANDLED; 3505 return IRQ_HANDLED;
3506} 3506}
3507 3507
3508/* Should be called with accdet_lock held */
3508static void wm1811_micd_stop(struct snd_soc_codec *codec) 3509static void wm1811_micd_stop(struct snd_soc_codec *codec)
3509{ 3510{
3510 struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec); 3511 struct wm8994_priv *wm8994 = snd_soc_codec_get_drvdata(codec);
@@ -3512,14 +3513,10 @@ static void wm1811_micd_stop(struct snd_soc_codec *codec)
3512 if (!wm8994->jackdet) 3513 if (!wm8994->jackdet)
3513 return; 3514 return;
3514 3515
3515 mutex_lock(&wm8994->accdet_lock);
3516
3517 snd_soc_update_bits(codec, WM8958_MIC_DETECT_1, WM8958_MICD_ENA, 0); 3516 snd_soc_update_bits(codec, WM8958_MIC_DETECT_1, WM8958_MICD_ENA, 0);
3518 3517
3519 wm1811_jackdet_set_mode(codec, WM1811_JACKDET_MODE_JACK); 3518 wm1811_jackdet_set_mode(codec, WM1811_JACKDET_MODE_JACK);
3520 3519
3521 mutex_unlock(&wm8994->accdet_lock);
3522
3523 if (wm8994->wm8994->pdata.jd_ext_cap) 3520 if (wm8994->wm8994->pdata.jd_ext_cap)
3524 snd_soc_dapm_disable_pin(&codec->dapm, 3521 snd_soc_dapm_disable_pin(&codec->dapm,
3525 "MICBIAS2"); 3522 "MICBIAS2");
@@ -3560,10 +3557,10 @@ static void wm8958_open_circuit_work(struct work_struct *work)
3560 open_circuit_work.work); 3557 open_circuit_work.work);
3561 struct device *dev = wm8994->wm8994->dev; 3558 struct device *dev = wm8994->wm8994->dev;
3562 3559
3563 wm1811_micd_stop(wm8994->hubs.codec);
3564
3565 mutex_lock(&wm8994->accdet_lock); 3560 mutex_lock(&wm8994->accdet_lock);
3566 3561
3562 wm1811_micd_stop(wm8994->hubs.codec);
3563
3567 dev_dbg(dev, "Reporting open circuit\n"); 3564 dev_dbg(dev, "Reporting open circuit\n");
3568 3565
3569 wm8994->jack_mic = false; 3566 wm8994->jack_mic = false;