diff options
Diffstat (limited to 'sound')
-rw-r--r-- | sound/pci/hda/patch_sigmatel.c | 35 |
1 files changed, 33 insertions, 2 deletions
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index f9b256388921..05661f7f3ce1 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c | |||
@@ -138,6 +138,7 @@ struct sigmatel_spec { | |||
138 | unsigned int mic_switch: 1; | 138 | unsigned int mic_switch: 1; |
139 | unsigned int alt_switch: 1; | 139 | unsigned int alt_switch: 1; |
140 | unsigned int hp_detect: 1; | 140 | unsigned int hp_detect: 1; |
141 | unsigned int spdif_mute: 1; | ||
141 | 142 | ||
142 | /* gpio lines */ | 143 | /* gpio lines */ |
143 | unsigned int eapd_mask; | 144 | unsigned int eapd_mask; |
@@ -547,10 +548,32 @@ static int stac92xx_smux_enum_put(struct snd_kcontrol *kcontrol, | |||
547 | { | 548 | { |
548 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); | 549 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); |
549 | struct sigmatel_spec *spec = codec->spec; | 550 | struct sigmatel_spec *spec = codec->spec; |
551 | struct hda_input_mux *smux = &spec->private_smux; | ||
550 | unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id); | 552 | unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id); |
553 | int err, val; | ||
554 | hda_nid_t nid; | ||
551 | 555 | ||
552 | return snd_hda_input_mux_put(codec, spec->sinput_mux, ucontrol, | 556 | err = snd_hda_input_mux_put(codec, spec->sinput_mux, ucontrol, |
553 | spec->smux_nids[smux_idx], &spec->cur_smux[smux_idx]); | 557 | spec->smux_nids[smux_idx], &spec->cur_smux[smux_idx]); |
558 | if (err < 0) | ||
559 | return err; | ||
560 | |||
561 | if (spec->spdif_mute) { | ||
562 | if (smux_idx == 0) | ||
563 | nid = spec->multiout.dig_out_nid; | ||
564 | else | ||
565 | nid = codec->slave_dig_outs[smux_idx - 1]; | ||
566 | if (spec->cur_smux[smux_idx] == smux->num_items - 1) | ||
567 | val = AMP_OUT_MUTE; | ||
568 | if (smux_idx == 0) | ||
569 | nid = spec->multiout.dig_out_nid; | ||
570 | else | ||
571 | nid = codec->slave_dig_outs[smux_idx - 1]; | ||
572 | /* un/mute SPDIF out */ | ||
573 | snd_hda_codec_write_cache(codec, nid, 0, | ||
574 | AC_VERB_SET_AMP_GAIN_MUTE, val); | ||
575 | } | ||
576 | return 0; | ||
554 | } | 577 | } |
555 | 578 | ||
556 | static int stac92xx_mux_enum_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo) | 579 | static int stac92xx_mux_enum_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo) |
@@ -1228,6 +1251,15 @@ static int stac92xx_build_controls(struct hda_codec *codec) | |||
1228 | return err; | 1251 | return err; |
1229 | } | 1252 | } |
1230 | if (spec->num_smuxes > 0) { | 1253 | if (spec->num_smuxes > 0) { |
1254 | int wcaps = get_wcaps(codec, spec->multiout.dig_out_nid); | ||
1255 | struct hda_input_mux *smux = &spec->private_smux; | ||
1256 | /* check for mute support on SPDIF out */ | ||
1257 | if (wcaps & AC_WCAP_OUT_AMP) { | ||
1258 | smux->items[smux->num_items].label = "Off"; | ||
1259 | smux->items[smux->num_items].index = 0; | ||
1260 | smux->num_items++; | ||
1261 | spec->spdif_mute = 1; | ||
1262 | } | ||
1231 | stac_smux_mixer.count = spec->num_smuxes; | 1263 | stac_smux_mixer.count = spec->num_smuxes; |
1232 | err = snd_ctl_add(codec->bus->card, | 1264 | err = snd_ctl_add(codec->bus->card, |
1233 | snd_ctl_new1(&stac_smux_mixer, codec)); | 1265 | snd_ctl_new1(&stac_smux_mixer, codec)); |
@@ -4377,7 +4409,6 @@ again: | |||
4377 | 4409 | ||
4378 | spec->num_muxes = ARRAY_SIZE(stac92hd71bxx_mux_nids); | 4410 | spec->num_muxes = ARRAY_SIZE(stac92hd71bxx_mux_nids); |
4379 | spec->num_adcs = ARRAY_SIZE(stac92hd71bxx_adc_nids); | 4411 | spec->num_adcs = ARRAY_SIZE(stac92hd71bxx_adc_nids); |
4380 | spec->num_dmuxes = ARRAY_SIZE(stac92hd71bxx_dmux_nids); | ||
4381 | 4412 | ||
4382 | switch (spec->board_config) { | 4413 | switch (spec->board_config) { |
4383 | case STAC_HP_M4: | 4414 | case STAC_HP_M4: |