diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-06-19 13:34:14 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-06-19 13:34:14 -0400 |
commit | 9a10758c4475ea9576a62828b6097dcf79f6d3e2 (patch) | |
tree | 15cba175627ab9c349956d69d4bd5be9f6e7efc4 | |
parent | e640a280ccb9c448a3d9d522ea730ce00efa8cf0 (diff) | |
parent | 145c0e914d2cd0cf829b8c4cbe24736b3ee81a91 (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/Kconfig | 2 | ||||
-rw-r--r-- | sound/pci/hda/hda_intel.c | 2 | ||||
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 18 | ||||
-rw-r--r-- | sound/pci/hda/patch_sigmatel.c | 25 |
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 | |||
12 | config SND_SGI_O2 | 12 | config 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 | ||
18 | config SND_SGI_HAL2 | 19 | config 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 | ||
4520 | static const struct hda_fixup alc269_fixups[] = { | 4522 | static 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 | ||
5042 | static const struct snd_pci_quirk alc269_fixup_tbl[] = { | 5054 | static 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 | ||
2175 | static 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 | |||
2174 | static const struct hda_verb hp_bnb13_eq_verbs[] = { | 2191 | static 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, |