diff mbox series

ALSA: hda/realtek - Couldn't detect Mic if booting with headset plugged

Message ID 20200914065118.19238-1-hui.wang@canonical.com
State New
Headers show
Series ALSA: hda/realtek - Couldn't detect Mic if booting with headset plugged | expand

Commit Message

Hui Wang Sept. 14, 2020, 6:51 a.m. UTC
We found a Mic detection issue on many Lenovo laptops, those laptops
belong to differnt models and they have different audio design like
internal mic connects to the codec or PCH, they all have this problem,
the problem is if plugging a headset before powerup/reboot the
machine, after booting up, the headphone could be detected but Mic
couldn't. If we plug out and plug in the headset, both headphone and
Mic could be detected then.

Through debugging we found the codec on those laptops are same, it is
alc257, and if we don't disable the 3k pulldown in alc256_shutup(),
the issue will be fixed. So far there is no pop noise or power
consumption regression on those laptops after this change.

Cc: Kailang Yang <kailang@realtek.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Hui Wang <hui.wang@canonical.com>
---
 sound/pci/hda/patch_realtek.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

Comments

Sasha Levin Sept. 17, 2020, 3:53 p.m. UTC | #1
Hi

[This is an automated email]

This commit has been processed because it contains a -stable tag.
The stable tag indicates that it's relevant for the following trees: all

The bot has tested the following trees: v5.8.9, v5.4.65, v4.19.145, v4.14.198, v4.9.236, v4.4.236.

v5.8.9: Build OK!
v5.4.65: Build OK!
v4.19.145: Build OK!
v4.14.198: Build OK!
v4.9.236: Failed to apply! Possible dependencies:
    0a6f0600efc3 ("ALSA: hda/realtek - New codecs support for ALC215/ALC285/ALC289")
    1078bef0cd92 ("ALSA: hda/realtek - Support ALC300")
    1c9609e3a8cf ("ALSA: hda - Reduce the suspend time consumption for ALC256")
    3aabf94c2d95 ("ALSA: hda/realtek - Fix ALC275 no sound issue")
    4a219ef8f370 ("ALSA: hda/realtek - Add ALC256 HP depop function")
    532a7784c376 ("ALSA: hda/realtek - There is no loopback mixer in the ALC234/274/294")
    693abe11aa6b ("ALSA: hda/realtek - Fixed hp_pin no value")
    71683c32dee6 ("ALSA: hda/realtek - Support headset mode for ALC234/ALC274/ALC294")
    bde1a7459623 ("ALSA: hda/realtek - Fixed headphone issue for ALC700")
    c0ca5eced222 ("ALSA: hda/realtek - Reduce click noise on Dell Precision 5820 headphone")
    c2d6af53a43f ("ALSA: hda/realtek - Add default procedure for suspend and resume state")

v4.4.236: Failed to apply! Possible dependencies:
    0a6f0600efc3 ("ALSA: hda/realtek - New codecs support for ALC215/ALC285/ALC289")
    1078bef0cd92 ("ALSA: hda/realtek - Support ALC300")
    1c9609e3a8cf ("ALSA: hda - Reduce the suspend time consumption for ALC256")
    3aabf94c2d95 ("ALSA: hda/realtek - Fix ALC275 no sound issue")
    4a219ef8f370 ("ALSA: hda/realtek - Add ALC256 HP depop function")
    532a7784c376 ("ALSA: hda/realtek - There is no loopback mixer in the ALC234/274/294")
    693abe11aa6b ("ALSA: hda/realtek - Fixed hp_pin no value")
    71683c32dee6 ("ALSA: hda/realtek - Support headset mode for ALC234/ALC274/ALC294")
    bde1a7459623 ("ALSA: hda/realtek - Fixed headphone issue for ALC700")
    c0ca5eced222 ("ALSA: hda/realtek - Reduce click noise on Dell Precision 5820 headphone")
    c2d6af53a43f ("ALSA: hda/realtek - Add default procedure for suspend and resume state")


NOTE: The patch will not be queued to stable trees until it is upstream.

How should we proceed with this patch?

-- 
Thanks
Sasha
Takashi Iwai Sept. 21, 2020, 8:25 a.m. UTC | #2
On Mon, 14 Sep 2020 08:51:18 +0200,
Hui Wang wrote:
> 

> We found a Mic detection issue on many Lenovo laptops, those laptops

> belong to differnt models and they have different audio design like

> internal mic connects to the codec or PCH, they all have this problem,

> the problem is if plugging a headset before powerup/reboot the

> machine, after booting up, the headphone could be detected but Mic

> couldn't. If we plug out and plug in the headset, both headphone and

> Mic could be detected then.

> 

> Through debugging we found the codec on those laptops are same, it is

> alc257, and if we don't disable the 3k pulldown in alc256_shutup(),

> the issue will be fixed. So far there is no pop noise or power

> consumption regression on those laptops after this change.

> 

> Cc: Kailang Yang <kailang@realtek.com>

> Cc: <stable@vger.kernel.org>

> Signed-off-by: Hui Wang <hui.wang@canonical.com>


Applied now.  Thanks.


Takashi
diff mbox series

Patch

diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 85e207173f5d..b6dc47da1d7b 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -3428,7 +3428,11 @@  static void alc256_shutup(struct hda_codec *codec)
 
 	/* 3k pull low control for Headset jack. */
 	/* NOTE: call this before clearing the pin, otherwise codec stalls */
-	alc_update_coef_idx(codec, 0x46, 0, 3 << 12);
+	/* If disable 3k pulldown control for alc257, the Mic detection will not work correctly
+	 * when booting with headset plugged. So skip setting it for the codec alc257
+	 */
+	if (codec->core.vendor_id != 0x10ec0257)
+		alc_update_coef_idx(codec, 0x46, 0, 3 << 12);
 
 	if (!spec->no_shutup_pins)
 		snd_hda_codec_write(codec, hp_pin, 0,