aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2010-08-04 01:37:39 -0400
committerTakashi Iwai <tiwai@suse.de>2010-08-04 01:40:53 -0400
commit748cce431eb413e794c8f1d1974b78b47a6174ef (patch)
tree88f4ece6d836c5bdd813fc19b297876385d8c157
parente096c8e6d5ed965f346d94befbbec2275dde3621 (diff)
ALSA: hda - Fix initial capsrc selection in patch_alc269()
In patch_alc269(), we initialize the primary capsrc so that the device works from the beginning. It issues CONNECT_SEL verb no matter which widget is although some widget (e.g. 0x23) has no connection selection but a mixer, which requires unmuting instead. This patch fixes the initialization of capsrc by re-using the code as a helper function. Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r--sound/pci/hda/patch_realtek.c27
1 files changed, 16 insertions, 11 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index 6c588ef26685..c8070620a4d8 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -5166,6 +5166,19 @@ static void fixup_automic_adc(struct hda_codec *codec)
5166 spec->auto_mic = 0; /* disable auto-mic to be sure */ 5166 spec->auto_mic = 0; /* disable auto-mic to be sure */
5167} 5167}
5168 5168
5169/* select or unmute the given capsrc route */
5170static void select_or_unmute_capsrc(struct hda_codec *codec, hda_nid_t cap,
5171 int idx)
5172{
5173 if (get_wcaps_type(get_wcaps(codec, cap)) == AC_WID_AUD_MIX) {
5174 snd_hda_codec_amp_stereo(codec, cap, HDA_INPUT, idx,
5175 HDA_AMP_MUTE, 0);
5176 } else {
5177 snd_hda_codec_write_cache(codec, cap, 0,
5178 AC_VERB_SET_CONNECT_SEL, idx);
5179 }
5180}
5181
5169/* set the default connection to that pin */ 5182/* set the default connection to that pin */
5170static int init_capsrc_for_pin(struct hda_codec *codec, hda_nid_t pin) 5183static int init_capsrc_for_pin(struct hda_codec *codec, hda_nid_t pin)
5171{ 5184{
@@ -5180,14 +5193,7 @@ static int init_capsrc_for_pin(struct hda_codec *codec, hda_nid_t pin)
5180 idx = get_connection_index(codec, cap, pin); 5193 idx = get_connection_index(codec, cap, pin);
5181 if (idx < 0) 5194 if (idx < 0)
5182 continue; 5195 continue;
5183 /* select or unmute this route */ 5196 select_or_unmute_capsrc(codec, cap, idx);
5184 if (get_wcaps_type(get_wcaps(codec, cap)) == AC_WID_AUD_MIX) {
5185 snd_hda_codec_amp_stereo(codec, cap, HDA_INPUT, idx,
5186 HDA_AMP_MUTE, 0);
5187 } else {
5188 snd_hda_codec_write_cache(codec, cap, 0,
5189 AC_VERB_SET_CONNECT_SEL, idx);
5190 }
5191 return i; /* return the found index */ 5197 return i; /* return the found index */
5192 } 5198 }
5193 return -1; /* not found */ 5199 return -1; /* not found */
@@ -14364,9 +14370,8 @@ static int alc269_parse_auto_config(struct hda_codec *codec)
14364 14370
14365 /* set default input source */ 14371 /* set default input source */
14366 if (!spec->dual_adc_switch) 14372 if (!spec->dual_adc_switch)
14367 snd_hda_codec_write_cache(codec, spec->capsrc_nids[0], 14373 select_or_unmute_capsrc(codec, spec->capsrc_nids[0],
14368 0, AC_VERB_SET_CONNECT_SEL, 14374 spec->input_mux->items[0].index);
14369 spec->input_mux->items[0].index);
14370 14375
14371 err = alc_auto_add_mic_boost(codec); 14376 err = alc_auto_add_mic_boost(codec);
14372 if (err < 0) 14377 if (err < 0)