aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Documentation/sound/alsa/HD-Audio-Models.txt1
-rw-r--r--sound/pci/hda/patch_sigmatel.c44
2 files changed, 39 insertions, 6 deletions
diff --git a/Documentation/sound/alsa/HD-Audio-Models.txt b/Documentation/sound/alsa/HD-Audio-Models.txt
index 8eec05bc079e..36c97126d17d 100644
--- a/Documentation/sound/alsa/HD-Audio-Models.txt
+++ b/Documentation/sound/alsa/HD-Audio-Models.txt
@@ -347,6 +347,7 @@ STAC92HD71B*
347 hp-m4 HP mini 1000 347 hp-m4 HP mini 1000
348 hp-dv5 HP dv series 348 hp-dv5 HP dv series
349 hp-hdx HP HDX series 349 hp-hdx HP HDX series
350 hp-dv4-1222nr HP dv4-1222nr (with LED support)
350 auto BIOS setup (default) 351 auto BIOS setup (default)
351 352
352STAC92HD73* 353STAC92HD73*
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
index 917bc5d3ac2c..76487de33c84 100644
--- a/sound/pci/hda/patch_sigmatel.c
+++ b/sound/pci/hda/patch_sigmatel.c
@@ -100,6 +100,7 @@ enum {
100 STAC_HP_M4, 100 STAC_HP_M4,
101 STAC_HP_DV5, 101 STAC_HP_DV5,
102 STAC_HP_HDX, 102 STAC_HP_HDX,
103 STAC_HP_DV4_1222NR,
103 STAC_92HD71BXX_MODELS 104 STAC_92HD71BXX_MODELS
104}; 105};
105 106
@@ -1836,6 +1837,7 @@ static unsigned int *stac92hd71bxx_brd_tbl[STAC_92HD71BXX_MODELS] = {
1836 [STAC_HP_M4] = NULL, 1837 [STAC_HP_M4] = NULL,
1837 [STAC_HP_DV5] = NULL, 1838 [STAC_HP_DV5] = NULL,
1838 [STAC_HP_HDX] = NULL, 1839 [STAC_HP_HDX] = NULL,
1840 [STAC_HP_DV4_1222NR] = NULL,
1839}; 1841};
1840 1842
1841static const char *stac92hd71bxx_models[STAC_92HD71BXX_MODELS] = { 1843static const char *stac92hd71bxx_models[STAC_92HD71BXX_MODELS] = {
@@ -1847,6 +1849,7 @@ static const char *stac92hd71bxx_models[STAC_92HD71BXX_MODELS] = {
1847 [STAC_HP_M4] = "hp-m4", 1849 [STAC_HP_M4] = "hp-m4",
1848 [STAC_HP_DV5] = "hp-dv5", 1850 [STAC_HP_DV5] = "hp-dv5",
1849 [STAC_HP_HDX] = "hp-hdx", 1851 [STAC_HP_HDX] = "hp-hdx",
1852 [STAC_HP_DV4_1222NR] = "hp-dv4-1222nr",
1850}; 1853};
1851 1854
1852static struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = { 1855static struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = {
@@ -1855,6 +1858,8 @@ static struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = {
1855 "DFI LanParty", STAC_92HD71BXX_REF), 1858 "DFI LanParty", STAC_92HD71BXX_REF),
1856 SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, 1859 SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1857 "DFI LanParty", STAC_92HD71BXX_REF), 1860 "DFI LanParty", STAC_92HD71BXX_REF),
1861 SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30fb,
1862 "HP dv4-1222nr", STAC_HP_DV4_1222NR),
1858 SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3080, 1863 SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3080,
1859 "HP", STAC_HP_DV5), 1864 "HP", STAC_HP_DV5),
1860 SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x30f0, 1865 SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x30f0,
@@ -4520,27 +4525,38 @@ static int stac92xx_resume(struct hda_codec *codec)
4520 return 0; 4525 return 0;
4521} 4526}
4522 4527
4523
4524/* 4528/*
4525 * using power check for controlling mute led of HP HDX notebooks 4529 * using power check for controlling mute led of HP notebooks
4526 * check for mute state only on Speakers (nid = 0x10) 4530 * check for mute state only on Speakers (nid = 0x10)
4527 * 4531 *
4528 * For this feature CONFIG_SND_HDA_POWER_SAVE is needed, otherwise 4532 * For this feature CONFIG_SND_HDA_POWER_SAVE is needed, otherwise
4529 * the LED is NOT working properly ! 4533 * the LED is NOT working properly !
4534 *
4535 * Changed name to reflect that it now works for any designated
4536 * model, not just HP HDX.
4530 */ 4537 */
4531 4538
4532#ifdef CONFIG_SND_HDA_POWER_SAVE 4539#ifdef CONFIG_SND_HDA_POWER_SAVE
4533static int stac92xx_hp_hdx_check_power_status(struct hda_codec *codec, 4540static int stac92xx_hp_check_power_status(struct hda_codec *codec,
4534 hda_nid_t nid) 4541 hda_nid_t nid)
4535{ 4542{
4536 struct sigmatel_spec *spec = codec->spec; 4543 struct sigmatel_spec *spec = codec->spec;
4544 unsigned int gpio_bit = 0; /* gets rid of compiler warning */
4545
4546 switch (spec->board_config) {
4547 case STAC_HP_DV4_1222NR:
4548 gpio_bit = 0x01;
4549 break;
4550 case STAC_HP_HDX:
4551 gpio_bit = 0x08;
4552 }
4537 4553
4538 if (nid == 0x10) { 4554 if (nid == 0x10) {
4539 if (snd_hda_codec_amp_read(codec, nid, 0, HDA_OUTPUT, 0) & 4555 if (snd_hda_codec_amp_read(codec, nid, 0, HDA_OUTPUT, 0) &
4540 HDA_AMP_MUTE) 4556 HDA_AMP_MUTE)
4541 spec->gpio_data &= ~0x08; /* orange */ 4557 spec->gpio_data &= ~gpio_bit; /* orange */
4542 else 4558 else
4543 spec->gpio_data |= 0x08; /* white */ 4559 spec->gpio_data |= gpio_bit; /* white */
4544 4560
4545 stac_gpio_set(codec, spec->gpio_mask, 4561 stac_gpio_set(codec, spec->gpio_mask,
4546 spec->gpio_dir, 4562 spec->gpio_dir,
@@ -5219,6 +5235,22 @@ again:
5219 spec->num_smuxes = 0; 5235 spec->num_smuxes = 0;
5220 spec->num_dmuxes = 1; 5236 spec->num_dmuxes = 1;
5221 break; 5237 break;
5238 case STAC_HP_DV4_1222NR:
5239 spec->num_dmics = 1;
5240 /* I don't know if it needs 1 or 2 smuxes - will wait for
5241 * bug reports to fix if needed
5242 */
5243 spec->num_smuxes = 1;
5244 spec->num_dmuxes = 1;
5245#ifdef CONFIG_SND_HDA_POWER_SAVE
5246 /* This controls MUTE LED */
5247 spec->gpio_mask |= 0x01;
5248 spec->gpio_dir |= 0x01;
5249 spec->gpio_data |= 0x01;
5250 codec->patch_ops.check_power_status =
5251 stac92xx_hp_check_power_status;
5252#endif
5253 /* fallthrough */
5222 case STAC_HP_DV5: 5254 case STAC_HP_DV5:
5223 snd_hda_codec_set_pincfg(codec, 0x0d, 0x90170010); 5255 snd_hda_codec_set_pincfg(codec, 0x0d, 0x90170010);
5224 stac92xx_auto_set_pinctl(codec, 0x0d, AC_PINCTL_OUT_EN); 5256 stac92xx_auto_set_pinctl(codec, 0x0d, AC_PINCTL_OUT_EN);
@@ -5239,7 +5271,7 @@ again:
5239 5271
5240 /* register check_power_status callback. */ 5272 /* register check_power_status callback. */
5241 codec->patch_ops.check_power_status = 5273 codec->patch_ops.check_power_status =
5242 stac92xx_hp_hdx_check_power_status; 5274 stac92xx_hp_check_power_status;
5243#endif 5275#endif
5244 break; 5276 break;
5245 }; 5277 };