aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-06-19 13:34:14 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-06-19 13:34:14 -0400
commit9a10758c4475ea9576a62828b6097dcf79f6d3e2 (patch)
tree15cba175627ab9c349956d69d4bd5be9f6e7efc4
parente640a280ccb9c448a3d9d522ea730ce00efa8cf0 (diff)
parent145c0e914d2cd0cf829b8c4cbe24736b3ee81a91 (diff)
Merge tag 'sound-4.1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound
Pull sound fixes from Takashi Iwai: "Nothing looks scary, just a few usual HD-audio regression fixes and fixup, in addition to a minor Kconfig dependency fix for the old MIPS drivers" * tag 'sound-4.1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: hda - Fix unused label skip_i915 ALSA: hda - Fix noisy outputs on Dell XPS13 (2015 model) ALSA: mips: let SND_SGI_O2 select SND_PCM ALSA: hda - Fix audio crackles on Dell Latitude E7x40 ALSA: hda - adding a DAC/pin preference map for a HP Envy TS machine
-rw-r--r--sound/mips/Kconfig2
-rw-r--r--sound/pci/hda/hda_intel.c2
-rw-r--r--sound/pci/hda/patch_realtek.c18
-rw-r--r--sound/pci/hda/patch_sigmatel.c25
4 files changed, 45 insertions, 2 deletions
diff --git a/sound/mips/Kconfig b/sound/mips/Kconfig
index d2f615ab177a..2153d31fb663 100644
--- a/sound/mips/Kconfig
+++ b/sound/mips/Kconfig
@@ -12,12 +12,14 @@ if SND_MIPS
12config SND_SGI_O2 12config SND_SGI_O2
13 tristate "SGI O2 Audio" 13 tristate "SGI O2 Audio"
14 depends on SGI_IP32 14 depends on SGI_IP32
15 select SND_PCM
15 help 16 help
16 Sound support for the SGI O2 Workstation. 17 Sound support for the SGI O2 Workstation.
17 18
18config SND_SGI_HAL2 19config SND_SGI_HAL2
19 tristate "SGI HAL2 Audio" 20 tristate "SGI HAL2 Audio"
20 depends on SGI_HAS_HAL2 21 depends on SGI_HAS_HAL2
22 select SND_PCM
21 help 23 help
22 Sound support for the SGI Indy and Indigo2 Workstation. 24 Sound support for the SGI Indy and Indigo2 Workstation.
23 25
diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c
index a244ba706317..b6db25b23dd3 100644
--- a/sound/pci/hda/hda_intel.c
+++ b/sound/pci/hda/hda_intel.c
@@ -1879,7 +1879,9 @@ static int azx_probe_continue(struct azx *chip)
1879#endif 1879#endif
1880 } 1880 }
1881 1881
1882#ifdef CONFIG_SND_HDA_I915
1882 skip_i915: 1883 skip_i915:
1884#endif
1883 err = azx_first_init(chip); 1885 err = azx_first_init(chip);
1884 if (err < 0) 1886 if (err < 0)
1885 goto out_free; 1887 goto out_free;
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 0320cb523d9e..6d010452c1f5 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -4515,6 +4515,8 @@ enum {
4515 ALC288_FIXUP_DELL_HEADSET_MODE, 4515 ALC288_FIXUP_DELL_HEADSET_MODE,
4516 ALC288_FIXUP_DELL1_MIC_NO_PRESENCE, 4516 ALC288_FIXUP_DELL1_MIC_NO_PRESENCE,
4517 ALC288_FIXUP_DELL_XPS_13_GPIO6, 4517 ALC288_FIXUP_DELL_XPS_13_GPIO6,
4518 ALC292_FIXUP_DELL_E7X,
4519 ALC292_FIXUP_DISABLE_AAMIX,
4518}; 4520};
4519 4521
4520static const struct hda_fixup alc269_fixups[] = { 4522static const struct hda_fixup alc269_fixups[] = {
@@ -5037,6 +5039,16 @@ static const struct hda_fixup alc269_fixups[] = {
5037 .chained = true, 5039 .chained = true,
5038 .chain_id = ALC288_FIXUP_DELL1_MIC_NO_PRESENCE 5040 .chain_id = ALC288_FIXUP_DELL1_MIC_NO_PRESENCE
5039 }, 5041 },
5042 [ALC292_FIXUP_DISABLE_AAMIX] = {
5043 .type = HDA_FIXUP_FUNC,
5044 .v.func = alc_fixup_disable_aamix,
5045 },
5046 [ALC292_FIXUP_DELL_E7X] = {
5047 .type = HDA_FIXUP_FUNC,
5048 .v.func = alc_fixup_dell_xps13,
5049 .chained = true,
5050 .chain_id = ALC292_FIXUP_DISABLE_AAMIX
5051 },
5040}; 5052};
5041 5053
5042static const struct snd_pci_quirk alc269_fixup_tbl[] = { 5054static const struct snd_pci_quirk alc269_fixup_tbl[] = {
@@ -5049,6 +5061,8 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
5049 SND_PCI_QUIRK(0x1025, 0x0775, "Acer Aspire E1-572", ALC271_FIXUP_HP_GATE_MIC_JACK_E1_572), 5061 SND_PCI_QUIRK(0x1025, 0x0775, "Acer Aspire E1-572", ALC271_FIXUP_HP_GATE_MIC_JACK_E1_572),
5050 SND_PCI_QUIRK(0x1025, 0x079b, "Acer Aspire V5-573G", ALC282_FIXUP_ASPIRE_V5_PINS), 5062 SND_PCI_QUIRK(0x1025, 0x079b, "Acer Aspire V5-573G", ALC282_FIXUP_ASPIRE_V5_PINS),
5051 SND_PCI_QUIRK(0x1028, 0x0470, "Dell M101z", ALC269_FIXUP_DELL_M101Z), 5063 SND_PCI_QUIRK(0x1028, 0x0470, "Dell M101z", ALC269_FIXUP_DELL_M101Z),
5064 SND_PCI_QUIRK(0x1028, 0x05ca, "Dell Latitude E7240", ALC292_FIXUP_DELL_E7X),
5065 SND_PCI_QUIRK(0x1028, 0x05cb, "Dell Latitude E7440", ALC292_FIXUP_DELL_E7X),
5052 SND_PCI_QUIRK(0x1028, 0x05da, "Dell Vostro 5460", ALC290_FIXUP_SUBWOOFER), 5066 SND_PCI_QUIRK(0x1028, 0x05da, "Dell Vostro 5460", ALC290_FIXUP_SUBWOOFER),
5053 SND_PCI_QUIRK(0x1028, 0x05f4, "Dell", ALC269_FIXUP_DELL1_MIC_NO_PRESENCE), 5067 SND_PCI_QUIRK(0x1028, 0x05f4, "Dell", ALC269_FIXUP_DELL1_MIC_NO_PRESENCE),
5054 SND_PCI_QUIRK(0x1028, 0x05f5, "Dell", ALC269_FIXUP_DELL1_MIC_NO_PRESENCE), 5068 SND_PCI_QUIRK(0x1028, 0x05f5, "Dell", ALC269_FIXUP_DELL1_MIC_NO_PRESENCE),
@@ -5058,6 +5072,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
5058 SND_PCI_QUIRK(0x1028, 0x0638, "Dell Inspiron 5439", ALC290_FIXUP_MONO_SPEAKERS_HSJACK), 5072 SND_PCI_QUIRK(0x1028, 0x0638, "Dell Inspiron 5439", ALC290_FIXUP_MONO_SPEAKERS_HSJACK),
5059 SND_PCI_QUIRK(0x1028, 0x064a, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), 5073 SND_PCI_QUIRK(0x1028, 0x064a, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE),
5060 SND_PCI_QUIRK(0x1028, 0x064b, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), 5074 SND_PCI_QUIRK(0x1028, 0x064b, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE),
5075 SND_PCI_QUIRK(0x1028, 0x0665, "Dell XPS 13", ALC292_FIXUP_DELL_E7X),
5061 SND_PCI_QUIRK(0x1028, 0x06c7, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE), 5076 SND_PCI_QUIRK(0x1028, 0x06c7, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE),
5062 SND_PCI_QUIRK(0x1028, 0x06d9, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), 5077 SND_PCI_QUIRK(0x1028, 0x06d9, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE),
5063 SND_PCI_QUIRK(0x1028, 0x06da, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), 5078 SND_PCI_QUIRK(0x1028, 0x06da, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE),
@@ -5637,8 +5652,7 @@ static int patch_alc269(struct hda_codec *codec)
5637 5652
5638 spec = codec->spec; 5653 spec = codec->spec;
5639 spec->gen.shared_mic_vref_pin = 0x18; 5654 spec->gen.shared_mic_vref_pin = 0x18;
5640 if (codec->core.vendor_id != 0x10ec0292) 5655 codec->power_save_node = 1;
5641 codec->power_save_node = 1;
5642 5656
5643 snd_hda_pick_fixup(codec, alc269_fixup_models, 5657 snd_hda_pick_fixup(codec, alc269_fixup_models,
5644 alc269_fixup_tbl, alc269_fixups); 5658 alc269_fixup_tbl, alc269_fixups);
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
index 6833c74ed6ff..6c66d7e16439 100644
--- a/sound/pci/hda/patch_sigmatel.c
+++ b/sound/pci/hda/patch_sigmatel.c
@@ -100,6 +100,7 @@ enum {
100 STAC_HP_ENVY_BASS, 100 STAC_HP_ENVY_BASS,
101 STAC_HP_BNB13_EQ, 101 STAC_HP_BNB13_EQ,
102 STAC_HP_ENVY_TS_BASS, 102 STAC_HP_ENVY_TS_BASS,
103 STAC_HP_ENVY_TS_DAC_BIND,
103 STAC_92HD83XXX_GPIO10_EAPD, 104 STAC_92HD83XXX_GPIO10_EAPD,
104 STAC_92HD83XXX_MODELS 105 STAC_92HD83XXX_MODELS
105}; 106};
@@ -2171,6 +2172,22 @@ static void stac92hd83xxx_fixup_gpio10_eapd(struct hda_codec *codec,
2171 spec->eapd_switch = 0; 2172 spec->eapd_switch = 0;
2172} 2173}
2173 2174
2175static void hp_envy_ts_fixup_dac_bind(struct hda_codec *codec,
2176 const struct hda_fixup *fix,
2177 int action)
2178{
2179 struct sigmatel_spec *spec = codec->spec;
2180 static hda_nid_t preferred_pairs[] = {
2181 0xd, 0x13,
2182 0
2183 };
2184
2185 if (action != HDA_FIXUP_ACT_PRE_PROBE)
2186 return;
2187
2188 spec->gen.preferred_dacs = preferred_pairs;
2189}
2190
2174static const struct hda_verb hp_bnb13_eq_verbs[] = { 2191static const struct hda_verb hp_bnb13_eq_verbs[] = {
2175 /* 44.1KHz base */ 2192 /* 44.1KHz base */
2176 { 0x22, 0x7A6, 0x3E }, 2193 { 0x22, 0x7A6, 0x3E },
@@ -2686,6 +2703,12 @@ static const struct hda_fixup stac92hd83xxx_fixups[] = {
2686 {} 2703 {}
2687 }, 2704 },
2688 }, 2705 },
2706 [STAC_HP_ENVY_TS_DAC_BIND] = {
2707 .type = HDA_FIXUP_FUNC,
2708 .v.func = hp_envy_ts_fixup_dac_bind,
2709 .chained = true,
2710 .chain_id = STAC_HP_ENVY_TS_BASS,
2711 },
2689 [STAC_92HD83XXX_GPIO10_EAPD] = { 2712 [STAC_92HD83XXX_GPIO10_EAPD] = {
2690 .type = HDA_FIXUP_FUNC, 2713 .type = HDA_FIXUP_FUNC,
2691 .v.func = stac92hd83xxx_fixup_gpio10_eapd, 2714 .v.func = stac92hd83xxx_fixup_gpio10_eapd,
@@ -2764,6 +2787,8 @@ static const struct snd_pci_quirk stac92hd83xxx_fixup_tbl[] = {
2764 "HP bNB13", STAC_HP_BNB13_EQ), 2787 "HP bNB13", STAC_HP_BNB13_EQ),
2765 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x190e, 2788 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x190e,
2766 "HP ENVY TS", STAC_HP_ENVY_TS_BASS), 2789 "HP ENVY TS", STAC_HP_ENVY_TS_BASS),
2790 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1967,
2791 "HP ENVY TS", STAC_HP_ENVY_TS_DAC_BIND),
2767 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1940, 2792 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1940,
2768 "HP bNB13", STAC_HP_BNB13_EQ), 2793 "HP bNB13", STAC_HP_BNB13_EQ),
2769 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1941, 2794 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1941,