aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci/hda/patch_cirrus.c
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2009-07-06 06:58:59 -0400
committerTakashi Iwai <tiwai@suse.de>2009-07-06 07:02:42 -0400
commitea35929b886975a240660b3ba6c61826761731ad (patch)
tree936855cbbe35e8a9b5ce3c0ab29946ec0c291f2e /sound/pci/hda/patch_cirrus.c
parent21a4dc43acdd547335f59ad52efeef5160247736 (diff)
ALSA: hda - Force to initialize input mixer setup for CS420x
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/hda/patch_cirrus.c')
-rw-r--r--sound/pci/hda/patch_cirrus.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/sound/pci/hda/patch_cirrus.c b/sound/pci/hda/patch_cirrus.c
index 051302e78345..8e33214abeb4 100644
--- a/sound/pci/hda/patch_cirrus.c
+++ b/sound/pci/hda/patch_cirrus.c
@@ -572,12 +572,13 @@ static struct snd_kcontrol_new cs_capture_ctls[] = {
572 HDA_BIND_VOL("Capture Volume", 0), 572 HDA_BIND_VOL("Capture Volume", 0),
573}; 573};
574 574
575static int change_cur_input(struct hda_codec *codec, unsigned int idx) 575static int change_cur_input(struct hda_codec *codec, unsigned int idx,
576 int force)
576{ 577{
577 struct cs_spec *spec = codec->spec; 578 struct cs_spec *spec = codec->spec;
578 struct auto_pin_cfg *cfg = &spec->autocfg; 579 struct auto_pin_cfg *cfg = &spec->autocfg;
579 580
580 if (spec->cur_input == idx) 581 if (spec->cur_input == idx && !force)
581 return 0; 582 return 0;
582 if (spec->cur_adc && spec->cur_adc != spec->adc_nid[idx]) { 583 if (spec->cur_adc && spec->cur_adc != spec->adc_nid[idx]) {
583 /* stream is running, let's swap the current ADC */ 584 /* stream is running, let's swap the current ADC */
@@ -630,7 +631,7 @@ static int cs_capture_source_put(struct snd_kcontrol *kcontrol,
630 if (idx >= spec->num_inputs) 631 if (idx >= spec->num_inputs)
631 return -EINVAL; 632 return -EINVAL;
632 idx = spec->input_idx[idx]; 633 idx = spec->input_idx[idx];
633 return change_cur_input(codec, idx); 634 return change_cur_input(codec, idx, 0);
634} 635}
635 636
636static struct snd_kcontrol_new cs_capture_source = { 637static struct snd_kcontrol_new cs_capture_source = {
@@ -773,11 +774,11 @@ static void cs_automic(struct hda_codec *codec)
773 present = snd_hda_codec_read(codec, nid, 0, 774 present = snd_hda_codec_read(codec, nid, 0,
774 AC_VERB_GET_PIN_SENSE, 0); 775 AC_VERB_GET_PIN_SENSE, 0);
775 if (present & AC_PINSENSE_PRESENCE) 776 if (present & AC_PINSENSE_PRESENCE)
776 change_cur_input(codec, spec->automic_idx); 777 change_cur_input(codec, spec->automic_idx, 0);
777 else { 778 else {
778 unsigned int imic = (spec->automic_idx == AUTO_PIN_MIC) ? 779 unsigned int imic = (spec->automic_idx == AUTO_PIN_MIC) ?
779 AUTO_PIN_FRONT_MIC : AUTO_PIN_MIC; 780 AUTO_PIN_FRONT_MIC : AUTO_PIN_MIC;
780 change_cur_input(codec, imic); 781 change_cur_input(codec, imic, 0);
781 } 782 }
782} 783}
783 784
@@ -857,6 +858,7 @@ static void init_input(struct hda_codec *codec)
857 AC_VERB_SET_UNSOLICITED_ENABLE, 858 AC_VERB_SET_UNSOLICITED_ENABLE,
858 AC_USRSP_EN | MIC_EVENT); 859 AC_USRSP_EN | MIC_EVENT);
859 } 860 }
861 change_cur_input(codec, spec->cur_input, 1);
860 if (spec->mic_detect) 862 if (spec->mic_detect)
861 cs_automic(codec); 863 cs_automic(codec);
862} 864}