stable.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines
@ 2017-12-22  3:17 Hui Wang
  2017-12-22  3:17 ` [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine Hui Wang
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Hui Wang @ 2017-12-22  3:17 UTC (permalink / raw)
  To: alsa-devel, tiwai; +Cc: stable, hui.wang

There is a headset jack on the front panel, when we plug a headset
into it, the headset mic can't trigger unsol events, and
read_pin_sense() can't detect its presence too. So add this fixup
to fix this issue.

Cc: <stable@vger.kernel.org>
Signed-off-by: Hui Wang <hui.wang@canonical.com>
---
 sound/pci/hda/patch_conexant.c | 29 +++++++++++++++++++++++++++++
 1 file changed, 29 insertions(+)

diff --git a/sound/pci/hda/patch_conexant.c b/sound/pci/hda/patch_conexant.c
index a81aacf..37e1cf8 100644
--- a/sound/pci/hda/patch_conexant.c
+++ b/sound/pci/hda/patch_conexant.c
@@ -271,6 +271,8 @@ enum {
 	CXT_FIXUP_HP_SPECTRE,
 	CXT_FIXUP_HP_GATE_MIC,
 	CXT_FIXUP_MUTE_LED_GPIO,
+	CXT_FIXUP_HEADSET_MIC,
+	CXT_FIXUP_HP_MIC_NO_PRESENCE,
 };
 
 /* for hda_fixup_thinkpad_acpi() */
@@ -350,6 +352,18 @@ static void cxt_fixup_headphone_mic(struct hda_codec *codec,
 	}
 }
 
+static void cxt_fixup_headset_mic(struct hda_codec *codec,
+				    const struct hda_fixup *fix, int action)
+{
+	struct conexant_spec *spec = codec->spec;
+
+	switch (action) {
+	case HDA_FIXUP_ACT_PRE_PROBE:
+		spec->parse_flags |= HDA_PINCFG_HEADSET_MIC;
+		break;
+	}
+}
+
 /* OPLC XO 1.5 fixup */
 
 /* OLPC XO-1.5 supports DC input mode (e.g. for use with analog sensors)
@@ -880,6 +894,19 @@ static const struct hda_fixup cxt_fixups[] = {
 		.type = HDA_FIXUP_FUNC,
 		.v.func = cxt_fixup_mute_led_gpio,
 	},
+	[CXT_FIXUP_HEADSET_MIC] = {
+		.type = HDA_FIXUP_FUNC,
+		.v.func = cxt_fixup_headset_mic,
+	},
+	[CXT_FIXUP_HP_MIC_NO_PRESENCE] = {
+		.type = HDA_FIXUP_PINS,
+		.v.pins = (const struct hda_pintbl[]) {
+			{ 0x1a, 0x02a1113c },
+			{ }
+		},
+		.chained = true,
+		.chain_id = CXT_FIXUP_HEADSET_MIC,
+	},
 };
 
 static const struct snd_pci_quirk cxt5045_fixups[] = {
@@ -934,6 +961,8 @@ static const struct snd_pci_quirk cxt5066_fixups[] = {
 	SND_PCI_QUIRK(0x103c, 0x8115, "HP Z1 Gen3", CXT_FIXUP_HP_GATE_MIC),
 	SND_PCI_QUIRK(0x103c, 0x814f, "HP ZBook 15u G3", CXT_FIXUP_MUTE_LED_GPIO),
 	SND_PCI_QUIRK(0x103c, 0x822e, "HP ProBook 440 G4", CXT_FIXUP_MUTE_LED_GPIO),
+	SND_PCI_QUIRK(0x103c, 0x8299, "HP 800 G3 SFF", CXT_FIXUP_HP_MIC_NO_PRESENCE),
+	SND_PCI_QUIRK(0x103c, 0x829a, "HP 800 G3 DM", CXT_FIXUP_HP_MIC_NO_PRESENCE),
 	SND_PCI_QUIRK(0x1043, 0x138d, "Asus", CXT_FIXUP_HEADPHONE_MIC_PIN),
 	SND_PCI_QUIRK(0x152d, 0x0833, "OLPC XO-1.5", CXT_FIXUP_OLPC_XO),
 	SND_PCI_QUIRK(0x17aa, 0x20f2, "Lenovo T400", CXT_PINCFG_LENOVO_TP410),
-- 
2.7.4

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine
  2017-12-22  3:17 [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Hui Wang
@ 2017-12-22  3:17 ` Hui Wang
  2017-12-22  9:27   ` Takashi Iwai
  2017-12-22  3:17 ` [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine Hui Wang
  2017-12-22  9:27 ` [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Takashi Iwai
  2 siblings, 1 reply; 6+ messages in thread
From: Hui Wang @ 2017-12-22  3:17 UTC (permalink / raw)
  To: alsa-devel, tiwai; +Cc: stable, hui.wang

It has the codec alc256, and add its pin definition to pin quirk
table to let it apply ALC255_FIXUP_DELL1_MIC_NO_PRESENCE.

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

diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 921a10e..31d88fe 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -6550,6 +6550,11 @@ static const struct snd_hda_pin_quirk alc269_pin_fixup_tbl[] = {
 		{0x1b, 0x01011020},
 		{0x21, 0x02211010}),
 	SND_HDA_PIN_QUIRK(0x10ec0256, 0x1028, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE,
+		{0x12, 0x90a60130},
+		{0x14, 0x90170110},
+		{0x1b, 0x01011020},
+		{0x21, 0x0221101f}),
+	SND_HDA_PIN_QUIRK(0x10ec0256, 0x1028, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE,
 		{0x12, 0x90a60160},
 		{0x14, 0x90170120},
 		{0x21, 0x02211030}),
-- 
2.7.4

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine
  2017-12-22  3:17 [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Hui Wang
  2017-12-22  3:17 ` [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine Hui Wang
@ 2017-12-22  3:17 ` Hui Wang
  2017-12-22  9:28   ` Takashi Iwai
  2017-12-22  9:27 ` [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Takashi Iwai
  2 siblings, 1 reply; 6+ messages in thread
From: Hui Wang @ 2017-12-22  3:17 UTC (permalink / raw)
  To: alsa-devel, tiwai; +Cc: stable, hui.wang

There are two front mics on this machine, and current driver assign
the same name Mic to both of them, but pulseaudio can't handle them.
As a workaround, we change the location for one of them, then the
driver will assign "Front Mic" and "Mic" for them.

Cc: <stable@vger.kernel.org>
Signed-off-by: Hui Wang <hui.wang@canonical.com>
---
 sound/pci/hda/patch_realtek.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 31d88fe..096f5ef 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -6292,6 +6292,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
 	SND_PCI_QUIRK(0x17aa, 0x30bb, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY),
 	SND_PCI_QUIRK(0x17aa, 0x30e2, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY),
 	SND_PCI_QUIRK(0x17aa, 0x310c, "ThinkCentre Station", ALC294_FIXUP_LENOVO_MIC_LOCATION),
+	SND_PCI_QUIRK(0x17aa, 0x313c, "ThinkCentre Station", ALC294_FIXUP_LENOVO_MIC_LOCATION),
 	SND_PCI_QUIRK(0x17aa, 0x3112, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY),
 	SND_PCI_QUIRK(0x17aa, 0x3902, "Lenovo E50-80", ALC269_FIXUP_DMIC_THINKPAD_ACPI),
 	SND_PCI_QUIRK(0x17aa, 0x3977, "IdeaPad S210", ALC283_FIXUP_INT_MIC),
-- 
2.7.4

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines
  2017-12-22  3:17 [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Hui Wang
  2017-12-22  3:17 ` [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine Hui Wang
  2017-12-22  3:17 ` [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine Hui Wang
@ 2017-12-22  9:27 ` Takashi Iwai
  2 siblings, 0 replies; 6+ messages in thread
From: Takashi Iwai @ 2017-12-22  9:27 UTC (permalink / raw)
  To: Hui Wang; +Cc: alsa-devel, stable

On Fri, 22 Dec 2017 04:17:44 +0100,
Hui Wang wrote:
> 
> There is a headset jack on the front panel, when we plug a headset
> into it, the headset mic can't trigger unsol events, and
> read_pin_sense() can't detect its presence too. So add this fixup
> to fix this issue.
> 
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Hui Wang <hui.wang@canonical.com>

Applied now.  Thanks.


Takashi

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine
  2017-12-22  3:17 ` [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine Hui Wang
@ 2017-12-22  9:27   ` Takashi Iwai
  0 siblings, 0 replies; 6+ messages in thread
From: Takashi Iwai @ 2017-12-22  9:27 UTC (permalink / raw)
  To: Hui Wang; +Cc: alsa-devel, stable

On Fri, 22 Dec 2017 04:17:45 +0100,
Hui Wang wrote:
> 
> It has the codec alc256, and add its pin definition to pin quirk
> table to let it apply ALC255_FIXUP_DELL1_MIC_NO_PRESENCE.
> 
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Hui Wang <hui.wang@canonical.com>

Applied now.  Thanks.


Takashi

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine
  2017-12-22  3:17 ` [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine Hui Wang
@ 2017-12-22  9:28   ` Takashi Iwai
  0 siblings, 0 replies; 6+ messages in thread
From: Takashi Iwai @ 2017-12-22  9:28 UTC (permalink / raw)
  To: Hui Wang; +Cc: alsa-devel, stable

On Fri, 22 Dec 2017 04:17:46 +0100,
Hui Wang wrote:
> 
> There are two front mics on this machine, and current driver assign
> the same name Mic to both of them, but pulseaudio can't handle them.
> As a workaround, we change the location for one of them, then the
> driver will assign "Front Mic" and "Mic" for them.
> 
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Hui Wang <hui.wang@canonical.com>

Applied now.  Thanks.


Takashi

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2017-12-22  9:28 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-12-22  3:17 [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Hui Wang
2017-12-22  3:17 ` [PATCH 2/3] ALSA: hda - fix headset mic detection issue on a Dell machine Hui Wang
2017-12-22  9:27   ` Takashi Iwai
2017-12-22  3:17 ` [PATCH 3/3] ALSA: hda - change the location for one mic on a Lenovo machine Hui Wang
2017-12-22  9:28   ` Takashi Iwai
2017-12-22  9:27 ` [PATCH 1/3] ALSA: hda - Add MIC_NO_PRESENCE fixup for 2 HP machines Takashi Iwai

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).