* [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).