snd_soc_update_bits(codec, WM8958_MIC_DETECT_1,
                                            WM8958_MICD_ENA, 0);
 
-                       wm1811_jackdet_set_mode(codec,
-                                               WM1811_JACKDET_MODE_JACK);
-
                        if (wm8994->pdata->jd_ext_cap) {
                                mutex_lock(&codec->mutex);
                                snd_soc_dapm_disable_pin(&codec->dapm,
                                snd_soc_dapm_sync(&codec->dapm);
                                mutex_unlock(&codec->mutex);
                        }
+
+                       wm1811_jackdet_set_mode(codec,
+                                               WM1811_JACKDET_MODE_JACK);
                }
        }
 
                snd_soc_update_bits(codec, WM8958_MICBIAS2,
                                    WM8958_MICB2_DISCH, 0);
 
-               /* If required for an external cap force MICBIAS on */
-               if (wm8994->pdata->jd_ext_cap) {
-                       mutex_lock(&codec->mutex);
-                       snd_soc_dapm_force_enable_pin(&codec->dapm,
-                                                     "MICBIAS2");
-                       snd_soc_dapm_sync(&codec->dapm);
-                       mutex_unlock(&codec->mutex);
-               }
-
                /*
                 * Start off measument of microphone impedence to find
                 * out what's actually there.
                 */
                wm8994->mic_detecting = true;
                wm1811_jackdet_set_mode(codec, WM1811_JACKDET_MODE_MIC);
+
                snd_soc_update_bits(codec, WM8958_MIC_DETECT_1,
                                    WM8958_MICD_ENA, WM8958_MICD_ENA);
+
+               /* If required for an external cap force MICBIAS on */
+               if (wm8994->pdata->jd_ext_cap) {
+                       mutex_lock(&codec->mutex);
+                       snd_soc_dapm_force_enable_pin(&codec->dapm,
+                                                     "MICBIAS2");
+                       snd_soc_dapm_sync(&codec->dapm);
+                       mutex_unlock(&codec->mutex);
+               }
        } else {
                dev_dbg(codec->dev, "Jack not detected\n");