aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2013-05-30 08:42:29 -0400
committerMark Brown <broonie@linaro.org>2013-06-01 14:28:58 -0400
commit2da1c4bf765cb32024e5db6fa75dab92916fa3b1 (patch)
treedbf9c6619cb1c0257398959c4a58d4b30f52b850 /sound/soc/codecs
parent2d01e39b9073361317eb72b390dc2a4a3d76e192 (diff)
ASoC: wm8994: Allow debounce before MICDET identification
For systems which do not have a jack detection feature allow some debounce to be specified before we perform accessory identification, improving robustness without impacting button detection responsiveness. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/codecs')
-rw-r--r--sound/soc/codecs/wm8994.c35
-rw-r--r--sound/soc/codecs/wm8994.h2
2 files changed, 35 insertions, 2 deletions
diff --git a/sound/soc/codecs/wm8994.c b/sound/soc/codecs/wm8994.c
index 5d046b1c5a7e..0f58f003dc1a 100644
--- a/sound/soc/codecs/wm8994.c
+++ b/sound/soc/codecs/wm8994.c
@@ -3660,6 +3660,8 @@ static irqreturn_t wm1811_jackdet_irq(int irq, void *data)
3660 3660
3661 pm_runtime_get_sync(codec->dev); 3661 pm_runtime_get_sync(codec->dev);
3662 3662
3663 cancel_delayed_work_sync(&wm8994->mic_complete_work);
3664
3663 mutex_lock(&wm8994->accdet_lock); 3665 mutex_lock(&wm8994->accdet_lock);
3664 3666
3665 reg = snd_soc_read(codec, WM1811_JACKDET_CTRL); 3667 reg = snd_soc_read(codec, WM1811_JACKDET_CTRL);
@@ -3842,11 +3844,33 @@ int wm8958_mic_detect(struct snd_soc_codec *codec, struct snd_soc_jack *jack,
3842} 3844}
3843EXPORT_SYMBOL_GPL(wm8958_mic_detect); 3845EXPORT_SYMBOL_GPL(wm8958_mic_detect);
3844 3846
3847static void wm8958_mic_work(struct work_struct *work)
3848{
3849 struct wm8994_priv *wm8994 = container_of(work,
3850 struct wm8994_priv,
3851 mic_complete_work.work);
3852 struct snd_soc_codec *codec = wm8994->hubs.codec;
3853
3854 dev_crit(codec->dev, "MIC WORK %x\n", wm8994->mic_status);
3855
3856 pm_runtime_get_sync(codec->dev);
3857
3858 mutex_lock(&wm8994->accdet_lock);
3859
3860 wm8994->mic_id_cb(wm8994->mic_id_cb_data, wm8994->mic_status);
3861
3862 mutex_unlock(&wm8994->accdet_lock);
3863
3864 pm_runtime_put(codec->dev);
3865
3866 dev_crit(codec->dev, "MIC WORK %x DONE\n", wm8994->mic_status);
3867}
3868
3845static irqreturn_t wm8958_mic_irq(int irq, void *data) 3869static irqreturn_t wm8958_mic_irq(int irq, void *data)
3846{ 3870{
3847 struct wm8994_priv *wm8994 = data; 3871 struct wm8994_priv *wm8994 = data;
3848 struct snd_soc_codec *codec = wm8994->hubs.codec; 3872 struct snd_soc_codec *codec = wm8994->hubs.codec;
3849 int reg, count, ret; 3873 int reg, count, ret, id_delay;
3850 3874
3851 /* 3875 /*
3852 * Jack detection may have detected a removal simulataneously 3876 * Jack detection may have detected a removal simulataneously
@@ -3856,6 +3880,7 @@ static irqreturn_t wm8958_mic_irq(int irq, void *data)
3856 if (!(snd_soc_read(codec, WM8958_MIC_DETECT_1) & WM8958_MICD_ENA)) 3880 if (!(snd_soc_read(codec, WM8958_MIC_DETECT_1) & WM8958_MICD_ENA))
3857 return IRQ_HANDLED; 3881 return IRQ_HANDLED;
3858 3882
3883 cancel_delayed_work_sync(&wm8994->mic_complete_work);
3859 cancel_delayed_work_sync(&wm8994->open_circuit_work); 3884 cancel_delayed_work_sync(&wm8994->open_circuit_work);
3860 3885
3861 pm_runtime_get_sync(codec->dev); 3886 pm_runtime_get_sync(codec->dev);
@@ -3904,8 +3929,12 @@ static irqreturn_t wm8958_mic_irq(int irq, void *data)
3904 } 3929 }
3905 } 3930 }
3906 3931
3932 wm8994->mic_status = reg;
3933 id_delay = wm8994->wm8994->pdata.mic_id_delay;
3934
3907 if (wm8994->mic_detecting) 3935 if (wm8994->mic_detecting)
3908 wm8994->mic_id_cb(wm8994->mic_id_cb_data, reg); 3936 schedule_delayed_work(&wm8994->mic_complete_work,
3937 msecs_to_jiffies(id_delay));
3909 else 3938 else
3910 wm8958_button_det(codec, reg); 3939 wm8958_button_det(codec, reg);
3911 3940
@@ -3971,6 +4000,8 @@ static int wm8994_codec_probe(struct snd_soc_codec *codec)
3971 break; 4000 break;
3972 } 4001 }
3973 4002
4003 INIT_DELAYED_WORK(&wm8994->mic_complete_work, wm8958_mic_work);
4004
3974 for (i = 0; i < ARRAY_SIZE(wm8994->fll_locked); i++) 4005 for (i = 0; i < ARRAY_SIZE(wm8994->fll_locked); i++)
3975 init_completion(&wm8994->fll_locked[i]); 4006 init_completion(&wm8994->fll_locked[i]);
3976 4007
diff --git a/sound/soc/codecs/wm8994.h b/sound/soc/codecs/wm8994.h
index 9d19a9185d35..6536f8d45ac6 100644
--- a/sound/soc/codecs/wm8994.h
+++ b/sound/soc/codecs/wm8994.h
@@ -135,6 +135,8 @@ struct wm8994_priv {
135 struct wm8994_micdet micdet[2]; 135 struct wm8994_micdet micdet[2];
136 struct delayed_work mic_work; 136 struct delayed_work mic_work;
137 struct delayed_work open_circuit_work; 137 struct delayed_work open_circuit_work;
138 struct delayed_work mic_complete_work;
139 u16 mic_status;
138 bool mic_detecting; 140 bool mic_detecting;
139 bool jack_mic; 141 bool jack_mic;
140 int btn_mask; 142 int btn_mask;