]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
ALSA: hda/realtek: Update ALC225 depop procedure
authorKailang Yang <kailang@realtek.com>
Thu, 14 Nov 2024 07:08:07 +0000 (15:08 +0800)
committerTakashi Iwai <tiwai@suse.de>
Tue, 26 Nov 2024 07:48:46 +0000 (08:48 +0100)
Old procedure has a chance to meet Headphone no output.

Fixes: da911b1f5e98 ("ALSA: hda/realtek - update ALC225 depop optimize")
Signed-off-by: Kailang Yang <kailang@realtek.com>
Cc: <stable@vger.kernel.org>
Link: https://lore.kernel.org/5a27b016ba9d42b4a4e6dadce50a3ba4@realtek.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/patch_realtek.c

index 290c0710f24dcee49bac92b8dc4422c43a8c3430..c53a5f8d1559e444ca67532dc6662185377bc21c 100644 (file)
@@ -3768,33 +3768,28 @@ static void alc225_init(struct hda_codec *codec)
        hp1_pin_sense = snd_hda_jack_detect(codec, hp_pin);
        hp2_pin_sense = snd_hda_jack_detect(codec, 0x16);
 
-       if (hp1_pin_sense || hp2_pin_sense)
+       if (hp1_pin_sense || hp2_pin_sense) {
                msleep(2);
+               alc_update_coefex_idx(codec, 0x57, 0x04, 0x0007, 0x1); /* Low power */
 
-       alc_update_coefex_idx(codec, 0x57, 0x04, 0x0007, 0x1); /* Low power */
-
-       if (hp1_pin_sense || spec->ultra_low_power)
-               snd_hda_codec_write(codec, hp_pin, 0,
-                           AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
-       if (hp2_pin_sense)
-               snd_hda_codec_write(codec, 0x16, 0,
-                           AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
-
-       if (hp1_pin_sense || hp2_pin_sense || spec->ultra_low_power)
-               msleep(85);
-
-       if (hp1_pin_sense || spec->ultra_low_power)
-               snd_hda_codec_write(codec, hp_pin, 0,
-                           AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
-       if (hp2_pin_sense)
-               snd_hda_codec_write(codec, 0x16, 0,
-                           AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
+               if (hp1_pin_sense)
+                       snd_hda_codec_write(codec, hp_pin, 0,
+                                   AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
+               if (hp2_pin_sense)
+                       snd_hda_codec_write(codec, 0x16, 0,
+                                   AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
+               msleep(75);
 
-       if (hp1_pin_sense || hp2_pin_sense || spec->ultra_low_power)
-               msleep(100);
+               if (hp1_pin_sense)
+                       snd_hda_codec_write(codec, hp_pin, 0,
+                                   AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE);
+               if (hp2_pin_sense)
+                       snd_hda_codec_write(codec, 0x16, 0,
+                                   AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE);
 
-       alc_update_coef_idx(codec, 0x4a, 3 << 10, 0);
-       alc_update_coefex_idx(codec, 0x57, 0x04, 0x0007, 0x4); /* Hight power */
+               msleep(75);
+               alc_update_coefex_idx(codec, 0x57, 0x04, 0x0007, 0x4); /* Hight power */
+       }
 }
 
 static void alc225_shutup(struct hda_codec *codec)
@@ -3806,36 +3801,35 @@ static void alc225_shutup(struct hda_codec *codec)
        if (!hp_pin)
                hp_pin = 0x21;
 
-       alc_disable_headset_jack_key(codec);
-       /* 3k pull low control for Headset jack. */
-       alc_update_coef_idx(codec, 0x4a, 0, 3 << 10);
-
        hp1_pin_sense = snd_hda_jack_detect(codec, hp_pin);
        hp2_pin_sense = snd_hda_jack_detect(codec, 0x16);
 
-       if (hp1_pin_sense || hp2_pin_sense)
+       if (hp1_pin_sense || hp2_pin_sense) {
+               alc_disable_headset_jack_key(codec);
+               /* 3k pull low control for Headset jack. */
+               alc_update_coef_idx(codec, 0x4a, 0, 3 << 10);
                msleep(2);
 
-       if (hp1_pin_sense || spec->ultra_low_power)
-               snd_hda_codec_write(codec, hp_pin, 0,
-                           AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
-       if (hp2_pin_sense)
-               snd_hda_codec_write(codec, 0x16, 0,
-                           AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
-
-       if (hp1_pin_sense || hp2_pin_sense || spec->ultra_low_power)
-               msleep(85);
+               if (hp1_pin_sense)
+                       snd_hda_codec_write(codec, hp_pin, 0,
+                                   AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
+               if (hp2_pin_sense)
+                       snd_hda_codec_write(codec, 0x16, 0,
+                                   AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
 
-       if (hp1_pin_sense || spec->ultra_low_power)
-               snd_hda_codec_write(codec, hp_pin, 0,
-                           AC_VERB_SET_PIN_WIDGET_CONTROL, 0x0);
-       if (hp2_pin_sense)
-               snd_hda_codec_write(codec, 0x16, 0,
-                           AC_VERB_SET_PIN_WIDGET_CONTROL, 0x0);
+               msleep(75);
 
-       if (hp1_pin_sense || hp2_pin_sense || spec->ultra_low_power)
-               msleep(100);
+               if (hp1_pin_sense)
+                       snd_hda_codec_write(codec, hp_pin, 0,
+                                   AC_VERB_SET_PIN_WIDGET_CONTROL, 0x0);
+               if (hp2_pin_sense)
+                       snd_hda_codec_write(codec, 0x16, 0,
+                                   AC_VERB_SET_PIN_WIDGET_CONTROL, 0x0);
 
+               msleep(75);
+               alc_update_coef_idx(codec, 0x4a, 3 << 10, 0);
+               alc_enable_headset_jack_key(codec);
+       }
        alc_auto_setup_eapd(codec, false);
        alc_shutup_pins(codec);
        if (spec->ultra_low_power) {
@@ -3846,9 +3840,6 @@ static void alc225_shutup(struct hda_codec *codec)
                alc_update_coef_idx(codec, 0x4a, 3<<4, 2<<4);
                msleep(30);
        }
-
-       alc_update_coef_idx(codec, 0x4a, 3 << 10, 0);
-       alc_enable_headset_jack_key(codec);
 }
 
 static void alc_default_init(struct hda_codec *codec)