diff options
| author | Vitaliy Kulikov <Vitaliy.Kulikov@idt.com> | 2011-03-09 20:47:43 -0500 |
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2011-03-14 10:21:17 -0400 |
| commit | 094a42452abd5564429045e210281c6d22e67fca (patch) | |
| tree | 223419703fc0df8481864cecb3151c66796bf115 | |
| parent | ae0ebbf70afe2889b39f575e800e7292abd259d6 (diff) | |
ALSA: hda - fix digital mic selection in mixer on 92HD8X codecs
When the mux for digital mic is different from the mux for other mics,
the current auto-parser doesn't handle them in a right way but provides
only one mic. This patch fixes the issue.
Signed-off-by: Vitaliy Kulikov <Vitaliy.Kulikov@idt.com>
Cc: <stable@kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
| -rw-r--r-- | sound/pci/hda/patch_sigmatel.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c index 8fe5608c5f29..32f744d47da7 100644 --- a/sound/pci/hda/patch_sigmatel.c +++ b/sound/pci/hda/patch_sigmatel.c | |||
| @@ -748,7 +748,7 @@ static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_e | |||
| 748 | struct sigmatel_spec *spec = codec->spec; | 748 | struct sigmatel_spec *spec = codec->spec; |
| 749 | unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id); | 749 | unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id); |
| 750 | const struct hda_input_mux *imux = spec->input_mux; | 750 | const struct hda_input_mux *imux = spec->input_mux; |
| 751 | unsigned int idx, prev_idx; | 751 | unsigned int idx, prev_idx, didx; |
| 752 | 752 | ||
| 753 | idx = ucontrol->value.enumerated.item[0]; | 753 | idx = ucontrol->value.enumerated.item[0]; |
| 754 | if (idx >= imux->num_items) | 754 | if (idx >= imux->num_items) |
| @@ -760,7 +760,8 @@ static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_e | |||
| 760 | snd_hda_codec_write_cache(codec, spec->mux_nids[adc_idx], 0, | 760 | snd_hda_codec_write_cache(codec, spec->mux_nids[adc_idx], 0, |
| 761 | AC_VERB_SET_CONNECT_SEL, | 761 | AC_VERB_SET_CONNECT_SEL, |
| 762 | imux->items[idx].index); | 762 | imux->items[idx].index); |
| 763 | if (prev_idx >= spec->num_analog_muxes) { | 763 | if (prev_idx >= spec->num_analog_muxes && |
| 764 | spec->mux_nids[adc_idx] != spec->dmux_nids[adc_idx]) { | ||
| 764 | imux = spec->dinput_mux; | 765 | imux = spec->dinput_mux; |
| 765 | /* 0 = analog */ | 766 | /* 0 = analog */ |
| 766 | snd_hda_codec_write_cache(codec, | 767 | snd_hda_codec_write_cache(codec, |
| @@ -770,9 +771,13 @@ static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_e | |||
| 770 | } | 771 | } |
| 771 | } else { | 772 | } else { |
| 772 | imux = spec->dinput_mux; | 773 | imux = spec->dinput_mux; |
| 774 | /* first dimux item is hardcoded to select analog imux, | ||
| 775 | * so lets skip it | ||
| 776 | */ | ||
| 777 | didx = idx - spec->num_analog_muxes + 1; | ||
| 773 | snd_hda_codec_write_cache(codec, spec->dmux_nids[adc_idx], 0, | 778 | snd_hda_codec_write_cache(codec, spec->dmux_nids[adc_idx], 0, |
| 774 | AC_VERB_SET_CONNECT_SEL, | 779 | AC_VERB_SET_CONNECT_SEL, |
| 775 | imux->items[idx - 1].index); | 780 | imux->items[didx].index); |
| 776 | } | 781 | } |
| 777 | spec->cur_mux[adc_idx] = idx; | 782 | spec->cur_mux[adc_idx] = idx; |
| 778 | return 1; | 783 | return 1; |
