|
@@ -3398,8 +3398,10 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec)
|
|
|
for (;;) {
|
|
|
badness = fill_and_eval_dacs(codec, fill_hardwired,
|
|
|
fill_mio_first);
|
|
|
- if (badness < 0)
|
|
|
+ if (badness < 0) {
|
|
|
+ kfree(best_cfg);
|
|
|
return badness;
|
|
|
+ }
|
|
|
debug_badness("==> lo_type=%d, wired=%d, mio=%d, badness=0x%x\n",
|
|
|
cfg->line_out_type, fill_hardwired, fill_mio_first,
|
|
|
badness);
|
|
@@ -3434,7 +3436,7 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec)
|
|
|
cfg->line_out_type = AUTO_PIN_SPEAKER_OUT;
|
|
|
fill_hardwired = true;
|
|
|
continue;
|
|
|
- }
|
|
|
+ }
|
|
|
if (cfg->hp_outs > 0 &&
|
|
|
cfg->line_out_type == AUTO_PIN_SPEAKER_OUT) {
|
|
|
cfg->speaker_outs = cfg->line_outs;
|
|
@@ -3448,7 +3450,7 @@ static int alc_auto_fill_dac_nids(struct hda_codec *codec)
|
|
|
cfg->line_out_type = AUTO_PIN_HP_OUT;
|
|
|
fill_hardwired = true;
|
|
|
continue;
|
|
|
- }
|
|
|
+ }
|
|
|
break;
|
|
|
}
|
|
|
|
|
@@ -4423,7 +4425,7 @@ static int alc_parse_auto_config(struct hda_codec *codec,
|
|
|
static int alc880_parse_auto_config(struct hda_codec *codec)
|
|
|
{
|
|
|
static const hda_nid_t alc880_ignore[] = { 0x1d, 0 };
|
|
|
- static const hda_nid_t alc880_ssids[] = { 0x15, 0x1b, 0x14, 0 };
|
|
|
+ static const hda_nid_t alc880_ssids[] = { 0x15, 0x1b, 0x14, 0 };
|
|
|
return alc_parse_auto_config(codec, alc880_ignore, alc880_ssids);
|
|
|
}
|
|
|
|
|
@@ -5269,7 +5271,9 @@ static const struct alc_fixup alc882_fixups[] = {
|
|
|
{ 0x16, 0x99130111 }, /* CLFE speaker */
|
|
|
{ 0x17, 0x99130112 }, /* surround speaker */
|
|
|
{ }
|
|
|
- }
|
|
|
+ },
|
|
|
+ .chained = true,
|
|
|
+ .chain_id = ALC882_FIXUP_GPIO1,
|
|
|
},
|
|
|
[ALC882_FIXUP_ACER_ASPIRE_8930G] = {
|
|
|
.type = ALC_FIXUP_PINS,
|
|
@@ -5312,7 +5316,9 @@ static const struct alc_fixup alc882_fixups[] = {
|
|
|
{ 0x20, AC_VERB_SET_COEF_INDEX, 0x07 },
|
|
|
{ 0x20, AC_VERB_SET_PROC_COEF, 0x3050 },
|
|
|
{ }
|
|
|
- }
|
|
|
+ },
|
|
|
+ .chained = true,
|
|
|
+ .chain_id = ALC882_FIXUP_GPIO1,
|
|
|
},
|
|
|
[ALC885_FIXUP_MACPRO_GPIO] = {
|
|
|
.type = ALC_FIXUP_FUNC,
|
|
@@ -5359,6 +5365,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
|
|
ALC882_FIXUP_ACER_ASPIRE_4930G),
|
|
|
SND_PCI_QUIRK(0x1025, 0x0155, "Packard-Bell M5120", ALC882_FIXUP_PB_M5210),
|
|
|
SND_PCI_QUIRK(0x1025, 0x0259, "Acer Aspire 5935", ALC889_FIXUP_DAC_ROUTE),
|
|
|
+ SND_PCI_QUIRK(0x1025, 0x026b, "Acer Aspire 8940G", ALC882_FIXUP_ACER_ASPIRE_8930G),
|
|
|
SND_PCI_QUIRK(0x1025, 0x0296, "Acer Aspire 7736z", ALC882_FIXUP_ACER_ASPIRE_7736),
|
|
|
SND_PCI_QUIRK(0x1043, 0x13c2, "Asus A7M", ALC882_FIXUP_EAPD),
|
|
|
SND_PCI_QUIRK(0x1043, 0x1873, "ASUS W90V", ALC882_FIXUP_ASUS_W90V),
|
|
@@ -5384,6 +5391,7 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
|
|
SND_PCI_QUIRK(0x106b, 0x3f00, "Macbook 5,1", ALC889_FIXUP_IMAC91_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC889_FIXUP_IMAC91_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x4100, "Macmini 3,1", ALC889_FIXUP_IMAC91_VREF),
|
|
|
+ SND_PCI_QUIRK(0x106b, 0x4200, "Mac Pro 5,1", ALC885_FIXUP_MACPRO_GPIO),
|
|
|
SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC889_FIXUP_IMAC91_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x4900, "iMac 9,1 Aluminum", ALC889_FIXUP_IMAC91_VREF),
|
|
|
SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC889_FIXUP_IMAC91_VREF),
|
|
@@ -5399,6 +5407,13 @@ static const struct snd_pci_quirk alc882_fixup_tbl[] = {
|
|
|
{}
|
|
|
};
|
|
|
|
|
|
+static const struct alc_model_fixup alc882_fixup_models[] = {
|
|
|
+ {.id = ALC882_FIXUP_ACER_ASPIRE_4930G, .name = "acer-aspire-4930g"},
|
|
|
+ {.id = ALC882_FIXUP_ACER_ASPIRE_8930G, .name = "acer-aspire-8930g"},
|
|
|
+ {.id = ALC883_FIXUP_ACER_EAPD, .name = "acer-aspire"},
|
|
|
+ {}
|
|
|
+};
|
|
|
+
|
|
|
/*
|
|
|
* BIOS auto configuration
|
|
|
*/
|
|
@@ -5439,7 +5454,8 @@ static int patch_alc882(struct hda_codec *codec)
|
|
|
if (err < 0)
|
|
|
goto error;
|
|
|
|
|
|
- alc_pick_fixup(codec, NULL, alc882_fixup_tbl, alc882_fixups);
|
|
|
+ alc_pick_fixup(codec, alc882_fixup_models, alc882_fixup_tbl,
|
|
|
+ alc882_fixups);
|
|
|
alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE);
|
|
|
|
|
|
alc_auto_parse_customize_define(codec);
|
|
@@ -6079,7 +6095,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
|
|
* Basically the device should work as is without the fixup table.
|
|
|
* If BIOS doesn't give a proper info, enable the corresponding
|
|
|
* fixup entry.
|
|
|
- */
|
|
|
+ */
|
|
|
SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A",
|
|
|
ALC269_FIXUP_AMIC),
|
|
|
SND_PCI_QUIRK(0x1043, 0x1013, "ASUS N61Da", ALC269_FIXUP_AMIC),
|
|
@@ -6296,7 +6312,7 @@ static void alc_fixup_no_jack_detect(struct hda_codec *codec,
|
|
|
{
|
|
|
if (action == ALC_FIXUP_ACT_PRE_PROBE)
|
|
|
codec->no_jack_detect = 1;
|
|
|
-}
|
|
|
+}
|
|
|
|
|
|
static const struct alc_fixup alc861_fixups[] = {
|
|
|
[ALC861_FIXUP_FSC_AMILO_PI1505] = {
|
|
@@ -6714,7 +6730,7 @@ static const struct snd_pci_quirk alc662_fixup_tbl[] = {
|
|
|
* Basically the device should work as is without the fixup table.
|
|
|
* If BIOS doesn't give a proper info, enable the corresponding
|
|
|
* fixup entry.
|
|
|
- */
|
|
|
+ */
|
|
|
SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC662_FIXUP_ASUS_MODE1),
|
|
|
SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC662_FIXUP_ASUS_MODE3),
|
|
|
SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC662_FIXUP_ASUS_MODE1),
|