|
@@ -1780,6 +1780,7 @@ enum {
|
|
|
ALC889_FIXUP_DAC_ROUTE,
|
|
|
ALC889_FIXUP_MBP_VREF,
|
|
|
ALC889_FIXUP_IMAC91_VREF,
|
|
|
+ ALC889_FIXUP_MBA21_VREF,
|
|
|
ALC882_FIXUP_INV_DMIC,
|
|
|
ALC882_FIXUP_NO_PRIMARY_HP,
|
|
|
ALC887_FIXUP_ASUS_BASS,
|
|
@@ -1884,17 +1885,13 @@ static void alc889_fixup_mbp_vref(struct hda_codec *codec,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-/* Set VREF on speaker pins on imac91 */
|
|
|
-static void alc889_fixup_imac91_vref(struct hda_codec *codec,
|
|
|
- const struct hda_fixup *fix, int action)
|
|
|
+static void alc889_fixup_mac_pins(struct hda_codec *codec,
|
|
|
+ const hda_nid_t *nids, int num_nids)
|
|
|
{
|
|
|
struct alc_spec *spec = codec->spec;
|
|
|
- static hda_nid_t nids[2] = { 0x18, 0x1a };
|
|
|
int i;
|
|
|
|
|
|
- if (action != HDA_FIXUP_ACT_INIT)
|
|
|
- return;
|
|
|
- for (i = 0; i < ARRAY_SIZE(nids); i++) {
|
|
|
+ for (i = 0; i < num_nids; i++) {
|
|
|
unsigned int val;
|
|
|
val = snd_hda_codec_get_pin_target(codec, nids[i]);
|
|
|
val |= AC_PINCTL_VREF_50;
|
|
@@ -1903,6 +1900,26 @@ static void alc889_fixup_imac91_vref(struct hda_codec *codec,
|
|
|
spec->gen.keep_vref_in_automute = 1;
|
|
|
}
|
|
|
|
|
|
+/* Set VREF on speaker pins on imac91 */
|
|
|
+static void alc889_fixup_imac91_vref(struct hda_codec *codec,
|
|
|
+ const struct hda_fixup *fix, int action)
|
|
|
+{
|
|
|
+ static hda_nid_t nids[2] = { 0x18, 0x1a };
|
|
|
+
|
|
|
+ if (action == HDA_FIXUP_ACT_INIT)
|
|
|
+ alc889_fixup_mac_pins(codec, nids, ARRAY_SIZE(nids));
|
|
|
+}
|
|
|
+
|
|
|
+/* Set VREF on speaker pins on mba21 */
|
|
|
+static void alc889_fixup_mba21_vref(struct hda_codec *codec,
|
|
|
+ const struct hda_fixup *fix, int action)
|
|
|
+{
|
|
|
+ static hda_nid_t nids[2] = { 0x18, 0x19 };
|
|
|
+
|
|
|
+ if (action == HDA_FIXUP_ACT_INIT)
|
|
|
+ alc889_fixup_mac_pins(codec, nids, ARRAY_SIZE(nids));
|
|
|
+}
|
|
|
+
|
|
|
/* Don't take HP output as primary
|
|
|
* Strangely, the speaker output doesn't work on Vaio Z and some Vaio
|
|
|
* all-in-one desktop PCs (for example VGC-LN51JGB) through DAC 0x05
|
|
@@ -2102,6 +2119,12 @@ static const struct hda_fixup alc882_fixups[] = {
|
|
|
.chained = true,
|
|
|
.chain_id = ALC882_FIXUP_GPIO1,
|
|
|
},
|
|
|
+ [ALC889_FIXUP_MBA21_VREF] = {
|
|
|
+ .type = HDA_FIXUP_FUNC,
|
|
|
+ .v.func = alc889_fixup_mba21_vref,
|
|
|
+ .chained = true,
|
|
|
+ .chain_id = ALC889_FIXUP_MBP_VREF,
|
|
|
+ },
|
|
|
[ALC882_FIXUP_INV_DMIC] = {
|
|
|
.type = HDA_FIXUP_FUNC,
|
|
|
.v.func = alc_fixup_inv_dmic_0x12,
|
|
@@ -2172,7 +2195,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
|
|
SND_PCI_QUIRK(0x106b, 0x3000, "iMac", ALC889_FIXUP_MBP_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x3200, "iMac 7,1 Aluminum", ALC882_FIXUP_EAPD),
|
|
|
SND_PCI_QUIRK(0x106b, 0x3400, "MacBookAir 1,1", ALC889_FIXUP_MBP_VREF),
|
|
|
- SND_PCI_QUIRK(0x106b, 0x3500, "MacBookAir 2,1", ALC889_FIXUP_MBP_VREF),
|
|
|
+ SND_PCI_QUIRK(0x106b, 0x3500, "MacBookAir 2,1", ALC889_FIXUP_MBA21_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x3600, "Macbook 3,1", ALC889_FIXUP_MBP_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x3800, "MacbookPro 4,1", ALC889_FIXUP_MBP_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x3e00, "iMac 24 Aluminum", ALC885_FIXUP_MACPRO_GPIO),
|
|
@@ -3287,6 +3310,7 @@ static void alc_headset_mode_ctia(struct hda_codec *codec)
|
|
|
alc_write_coef_idx(codec, 0x18, 0x7388);
|
|
|
break;
|
|
|
case 0x10ec0668:
|
|
|
+ alc_write_coef_idx(codec, 0x11, 0x0001);
|
|
|
alc_write_coef_idx(codec, 0x15, 0x0d60);
|
|
|
alc_write_coef_idx(codec, 0xc3, 0x0000);
|
|
|
break;
|
|
@@ -3315,6 +3339,7 @@ static void alc_headset_mode_omtp(struct hda_codec *codec)
|
|
|
alc_write_coef_idx(codec, 0x18, 0x7388);
|
|
|
break;
|
|
|
case 0x10ec0668:
|
|
|
+ alc_write_coef_idx(codec, 0x11, 0x0001);
|
|
|
alc_write_coef_idx(codec, 0x15, 0x0d50);
|
|
|
alc_write_coef_idx(codec, 0xc3, 0x0000);
|
|
|
break;
|
|
@@ -3600,11 +3625,6 @@ static void alc283_hp_automute_hook(struct hda_codec *codec,
|
|
|
vref);
|
|
|
}
|
|
|
|
|
|
-static void alc283_chromebook_caps(struct hda_codec *codec)
|
|
|
-{
|
|
|
- snd_hda_override_wcaps(codec, 0x03, 0);
|
|
|
-}
|
|
|
-
|
|
|
static void alc283_fixup_chromebook(struct hda_codec *codec,
|
|
|
const struct hda_fixup *fix, int action)
|
|
|
{
|
|
@@ -3613,9 +3633,26 @@ static void alc283_fixup_chromebook(struct hda_codec *codec,
|
|
|
|
|
|
switch (action) {
|
|
|
case HDA_FIXUP_ACT_PRE_PROBE:
|
|
|
- alc283_chromebook_caps(codec);
|
|
|
+ snd_hda_override_wcaps(codec, 0x03, 0);
|
|
|
/* Disable AA-loopback as it causes white noise */
|
|
|
spec->gen.mixer_nid = 0;
|
|
|
+ break;
|
|
|
+ case HDA_FIXUP_ACT_INIT:
|
|
|
+ /* Enable Line1 input control by verb */
|
|
|
+ val = alc_read_coef_idx(codec, 0x1a);
|
|
|
+ alc_write_coef_idx(codec, 0x1a, val | (1 << 4));
|
|
|
+ break;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+static void alc283_fixup_sense_combo_jack(struct hda_codec *codec,
|
|
|
+ const struct hda_fixup *fix, int action)
|
|
|
+{
|
|
|
+ struct alc_spec *spec = codec->spec;
|
|
|
+ int val;
|
|
|
+
|
|
|
+ switch (action) {
|
|
|
+ case HDA_FIXUP_ACT_PRE_PROBE:
|
|
|
spec->gen.hp_automute_hook = alc283_hp_automute_hook;
|
|
|
break;
|
|
|
case HDA_FIXUP_ACT_INIT:
|
|
@@ -3623,9 +3660,6 @@ static void alc283_fixup_chromebook(struct hda_codec *codec,
|
|
|
/* Set to manual mode */
|
|
|
val = alc_read_coef_idx(codec, 0x06);
|
|
|
alc_write_coef_idx(codec, 0x06, val & ~0x000c);
|
|
|
- /* Enable Line1 input control by verb */
|
|
|
- val = alc_read_coef_idx(codec, 0x1a);
|
|
|
- alc_write_coef_idx(codec, 0x1a, val | (1 << 4));
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
@@ -3821,6 +3855,7 @@ enum {
|
|
|
ALC269_FIXUP_LIMIT_INT_MIC_BOOST_MUTE_LED,
|
|
|
ALC269VB_FIXUP_ORDISSIMO_EVE2,
|
|
|
ALC283_FIXUP_CHROME_BOOK,
|
|
|
+ ALC283_FIXUP_SENSE_COMBO_JACK,
|
|
|
ALC282_FIXUP_ASUS_TX300,
|
|
|
ALC283_FIXUP_INT_MIC,
|
|
|
ALC290_FIXUP_MONO_SPEAKERS,
|
|
@@ -4120,6 +4155,12 @@ static const struct hda_fixup alc269_fixups[] = {
|
|
|
.type = HDA_FIXUP_FUNC,
|
|
|
.v.func = alc283_fixup_chromebook,
|
|
|
},
|
|
|
+ [ALC283_FIXUP_SENSE_COMBO_JACK] = {
|
|
|
+ .type = HDA_FIXUP_FUNC,
|
|
|
+ .v.func = alc283_fixup_sense_combo_jack,
|
|
|
+ .chained = true,
|
|
|
+ .chain_id = ALC283_FIXUP_CHROME_BOOK,
|
|
|
+ },
|
|
|
[ALC282_FIXUP_ASUS_TX300] = {
|
|
|
.type = HDA_FIXUP_FUNC,
|
|
|
.v.func = alc282_fixup_asus_tx300,
|
|
@@ -4202,6 +4243,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
|
|
SND_PCI_QUIRK(0x1028, 0x0614, "Dell Inspiron 3135", ALC269_FIXUP_DELL1_MIC_NO_PRESENCE),
|
|
|
SND_PCI_QUIRK(0x1028, 0x0616, "Dell Vostro 5470", ALC290_FIXUP_MONO_SPEAKERS),
|
|
|
SND_PCI_QUIRK(0x1028, 0x061f, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE),
|
|
|
+ SND_PCI_QUIRK(0x1028, 0x0638, "Dell Inspiron 5439", ALC290_FIXUP_MONO_SPEAKERS),
|
|
|
SND_PCI_QUIRK(0x1028, 0x063f, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE),
|
|
|
SND_PCI_QUIRK(0x1028, 0x15cc, "Dell X5 Precision", ALC269_FIXUP_DELL2_MIC_NO_PRESENCE),
|
|
|
SND_PCI_QUIRK(0x1028, 0x15cd, "Dell X5 Precision", ALC269_FIXUP_DELL2_MIC_NO_PRESENCE),
|
|
@@ -4210,7 +4252,6 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
|
|
SND_PCI_QUIRK(0x103c, 0x1973, "HP Pavilion", ALC269_FIXUP_HP_MUTE_LED_MIC1),
|
|
|
SND_PCI_QUIRK(0x103c, 0x1983, "HP Pavilion", ALC269_FIXUP_HP_MUTE_LED_MIC1),
|
|
|
SND_PCI_QUIRK(0x103c, 0x218b, "HP", ALC269_FIXUP_LIMIT_INT_MIC_BOOST_MUTE_LED),
|
|
|
- SND_PCI_QUIRK(0x103c, 0x21ed, "HP Falco Chromebook", ALC283_FIXUP_CHROME_BOOK),
|
|
|
SND_PCI_QUIRK_VENDOR(0x103c, "HP", ALC269_FIXUP_HP_MUTE_LED),
|
|
|
SND_PCI_QUIRK(0x1043, 0x103f, "ASUS TX300", ALC282_FIXUP_ASUS_TX300),
|
|
|
SND_PCI_QUIRK(0x1043, 0x106d, "Asus K53BE", ALC269_FIXUP_LIMIT_INT_MIC_BOOST),
|
|
@@ -4318,6 +4359,8 @@ static const struct hda_model_fixup alc269_fixup_models[] = {
|
|
|
{.id = ALC269_FIXUP_HP_GPIO_LED, .name = "hp-gpio-led"},
|
|
|
{.id = ALC269_FIXUP_DELL1_MIC_NO_PRESENCE, .name = "dell-headset-multi"},
|
|
|
{.id = ALC269_FIXUP_DELL2_MIC_NO_PRESENCE, .name = "dell-headset-dock"},
|
|
|
+ {.id = ALC283_FIXUP_CHROME_BOOK, .name = "alc283-chrome"},
|
|
|
+ {.id = ALC283_FIXUP_SENSE_COMBO_JACK, .name = "alc283-sense-combo"},
|
|
|
{}
|
|
|
};
|
|
|
|
|
@@ -4493,6 +4536,7 @@ enum {
|
|
|
ALC861_FIXUP_AMP_VREF_0F,
|
|
|
ALC861_FIXUP_NO_JACK_DETECT,
|
|
|
ALC861_FIXUP_ASUS_A6RP,
|
|
|
+ ALC660_FIXUP_ASUS_W7J,
|
|
|
};
|
|
|
|
|
|
/* On some laptops, VREF of pin 0x0f is abused for controlling the main amp */
|
|
@@ -4542,10 +4586,22 @@ static const struct hda_fixup alc861_fixups[] = {
|
|
|
.v.func = alc861_fixup_asus_amp_vref_0f,
|
|
|
.chained = true,
|
|
|
.chain_id = ALC861_FIXUP_NO_JACK_DETECT,
|
|
|
+ },
|
|
|
+ [ALC660_FIXUP_ASUS_W7J] = {
|
|
|
+ .type = HDA_FIXUP_VERBS,
|
|
|
+ .v.verbs = (const struct hda_verb[]) {
|
|
|
+ /* ASUS W7J needs a magic pin setup on unused NID 0x10
|
|
|
+ * for enabling outputs
|
|
|
+ */
|
|
|
+ {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
|
|
|
+ { }
|
|
|
+ },
|
|
|
}
|
|
|
};
|
|
|
|
|
|
static const struct snd_pci_quirk alc861_fixup_tbl[] = {
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1253, "ASUS W7J", ALC660_FIXUP_ASUS_W7J),
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1263, "ASUS Z35HL", ALC660_FIXUP_ASUS_W7J),
|
|
|
SND_PCI_QUIRK(0x1043, 0x1393, "ASUS A6Rp", ALC861_FIXUP_ASUS_A6RP),
|
|
|
SND_PCI_QUIRK_VENDOR(0x1043, "ASUS laptop", ALC861_FIXUP_AMP_VREF_0F),
|
|
|
SND_PCI_QUIRK(0x1462, 0x7254, "HP DX2200", ALC861_FIXUP_NO_JACK_DETECT),
|