|
@@ -3030,19 +3030,34 @@ static irqreturn_t wm8958_mic_irq(int irq, void *data)
|
|
{
|
|
{
|
|
struct wm8994_priv *wm8994 = data;
|
|
struct wm8994_priv *wm8994 = data;
|
|
struct snd_soc_codec *codec = wm8994->codec;
|
|
struct snd_soc_codec *codec = wm8994->codec;
|
|
- int reg;
|
|
|
|
|
|
+ int reg, count;
|
|
|
|
|
|
- reg = snd_soc_read(codec, WM8958_MIC_DETECT_3);
|
|
|
|
- if (reg < 0) {
|
|
|
|
- dev_err(codec->dev, "Failed to read mic detect status: %d\n",
|
|
|
|
- reg);
|
|
|
|
- return IRQ_NONE;
|
|
|
|
- }
|
|
|
|
|
|
+ /* We may occasionally read a detection without an impedence
|
|
|
|
+ * range being provided - if that happens loop again.
|
|
|
|
+ */
|
|
|
|
+ count = 10;
|
|
|
|
+ do {
|
|
|
|
+ reg = snd_soc_read(codec, WM8958_MIC_DETECT_3);
|
|
|
|
+ if (reg < 0) {
|
|
|
|
+ dev_err(codec->dev,
|
|
|
|
+ "Failed to read mic detect status: %d\n",
|
|
|
|
+ reg);
|
|
|
|
+ return IRQ_NONE;
|
|
|
|
+ }
|
|
|
|
|
|
- if (!(reg & WM8958_MICD_VALID)) {
|
|
|
|
- dev_dbg(codec->dev, "Mic detect data not valid\n");
|
|
|
|
- goto out;
|
|
|
|
- }
|
|
|
|
|
|
+ if (!(reg & WM8958_MICD_VALID)) {
|
|
|
|
+ dev_dbg(codec->dev, "Mic detect data not valid\n");
|
|
|
|
+ goto out;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (!(reg & WM8958_MICD_STS) || (reg & WM8958_MICD_LVL_MASK))
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ msleep(1);
|
|
|
|
+ } while (count--);
|
|
|
|
+
|
|
|
|
+ if (count == 0)
|
|
|
|
+ dev_warn(codec->dev, "No impedence range reported for jack\n");
|
|
|
|
|
|
#ifndef CONFIG_SND_SOC_WM8994_MODULE
|
|
#ifndef CONFIG_SND_SOC_WM8994_MODULE
|
|
trace_snd_soc_jack_irq(dev_name(codec->dev));
|
|
trace_snd_soc_jack_irq(dev_name(codec->dev));
|