[alsa-devel] Remap pin 0x16 of ASUS ROG G751 to Headphone
Takashi Iwai
tiwai at suse.de
Tue Oct 9 14:24:33 CEST 2018
On Mon, 08 Oct 2018 18:07:17 +0200,
Håvard wrote:
>
> Hi!
>
> On ASUS ROG G751 laptops the heaphone port is mapped to nothing, causing it
> to not function at all. I propose that we add a remap of pin 0x16 to
> Headphone in order to prevent this issue, and fix compability with the new
> mode=asus-g751.
>
> I don't know how to write patches, but this is what needs adding in
> sound/pci/hda/patch_realtek.c:
>
> [ALC668_FIXUP_ASUS_G751_PINS] = {
> .type = HDA_FIXUP_PINS,
> .v.pins = (const struct hda_pintbl[]) {
> { 0x16, 0x0421101f }, /* HP */
> {}
> },
> },
> [ALC668_FIXUP_ASUS_G751] = {
> .type = HDA_FIXUP_VERBS,
> .v.verbs = (const struct hda_verb[]) {
> { 0x20, AC_VERB_SET_COEF_INDEX, 0xc3 },
> { 0x20, AC_VERB_SET_PROC_COEF, 0x4000 },
> {}
> },
> .chained = true,
> .chain_id = ALC668_FIXUP_ASUS_G751_PINS
> },
>
> And declaring the function earlier.
Thanks. I prefer keeping the old COEF as a generic one, so let's move
ALC668_FIXUP_ASUS_G751 with the pin-config fix and chain to a new one
ALC668_FIXUP_MIC_COEF.
The fix patch is below.
Takashi
-- 8< --
From: Takashi Iwai <tiwai at suse.de>
Subject: [PATCH] ALSA: hda - Fix headphone pin config for ASUS G751
BIOS on ASUS G751 doesn't seem to map the headphone pin (NID 0x16)
correctly. Add a quirk to address it, as well as chaining to the
previous fix for the microphone.
Reported-by: Håvard <hovardslill at gmail.com>
Cc: <stable at vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai at suse.de>
---
sound/pci/hda/patch_realtek.c | 12 +++++++++++-
1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 3be7d7649525..b43149f95549 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -7738,6 +7738,7 @@ enum {
ALC662_FIXUP_ASUS_Nx50,
ALC668_FIXUP_ASUS_Nx51_HEADSET_MODE,
ALC668_FIXUP_ASUS_Nx51,
+ ALC668_FIXUP_MIC_COEF,
ALC668_FIXUP_ASUS_G751,
ALC891_FIXUP_HEADSET_MODE,
ALC891_FIXUP_DELL_MIC_NO_PRESENCE,
@@ -8008,7 +8009,7 @@ static const struct hda_fixup alc662_fixups[] = {
.chained = true,
.chain_id = ALC668_FIXUP_ASUS_Nx51_HEADSET_MODE,
},
- [ALC668_FIXUP_ASUS_G751] = {
+ [ALC668_FIXUP_MIC_COEF] = {
.type = HDA_FIXUP_VERBS,
.v.verbs = (const struct hda_verb[]) {
{ 0x20, AC_VERB_SET_COEF_INDEX, 0xc3 },
@@ -8016,6 +8017,15 @@ static const struct hda_fixup alc662_fixups[] = {
{}
},
},
+ [ALC668_FIXUP_ASUS_G751] = {
+ type = HDA_FIXUP_PINS,
+ .v.pins = (const struct hda_pintbl[]) {
+ { 0x16, 0x0421101f }, /* HP */
+ {}
+ },
+ .chained = true,
+ .chain_id = ALC668_FIXUP_MIC_COEF
+ },
[ALC891_FIXUP_HEADSET_MODE] = {
.type = HDA_FIXUP_FUNC,
.v.func = alc_fixup_headset_mode,
--
2.18.0
More information about the Alsa-devel
mailing list