summaryrefslogtreecommitdiffstats
path: root/sound/pci/hda
diff options
context:
space:
mode:
authorMatthew Ranostay <mranostay@embeddedalley.com>2008-10-09 08:37:28 -0400
committerJaroslav Kysela <perex@perex.cz>2008-10-10 13:41:59 +0200
commitb9aea7150a84d037b6ca3c2506b0058cee4eb1d2 (patch)
tree57eecb12ad32dcaae5223c1270da83294a8092e4 /sound/pci/hda
parentfb2aa074d4eac4957f5717d261bc336f4a5f31c4 (diff)
ALSA: hda: STAC_HP_M4
Set the third microphone to a default config of a 'Line In' to be added the Input Source Mux's. Signed-off-by: Matthew Ranostay <mranostay@embeddedalley.com> Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Jaroslav Kysela <perex@perex.cz>
Diffstat (limited to 'sound/pci/hda')
-rw-r--r--sound/pci/hda/patch_sigmatel.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
index 05661f7f3ce..5c65f7d4606 100644
--- a/sound/pci/hda/patch_sigmatel.c
+++ b/sound/pci/hda/patch_sigmatel.c
@@ -3643,7 +3643,12 @@ static int stac92xx_init(struct hda_codec *codec)
for (i = 0; i < AUTO_PIN_LAST; i++) {
hda_nid_t nid = cfg->input_pins[i];
if (nid) {
- unsigned int pinctl = AC_PINCTL_IN_EN;
+ unsigned int pinctl = snd_hda_codec_read(codec, nid,
+ 0, AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
+ /* if PINCTL already set then skip */
+ if (pinctl & AC_PINCAP_IN)
+ continue;
+ pinctl = AC_PINCTL_IN_EN;
if (i == AUTO_PIN_MIC || i == AUTO_PIN_FRONT_MIC)
pinctl |= stac92xx_get_vref(codec, nid);
stac92xx_auto_set_pinctl(codec, nid, pinctl);
@@ -4413,12 +4418,13 @@ again:
switch (spec->board_config) {
case STAC_HP_M4:
spec->num_dmics = 0;
- spec->num_smuxes = 1;
+ spec->num_smuxes = 0;
spec->num_dmuxes = 0;
/* enable internal microphone */
- snd_hda_codec_write_cache(codec, 0x0e, 0,
- AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80);
+ stac92xx_set_config_reg(codec, 0x0e, 0x01813040);
+ stac92xx_auto_set_pinctl(codec, 0x0e,
+ AC_PINCTL_IN_EN | AC_PINCTL_VREF_80);
break;
default:
spec->num_dmics = STAC92HD71BXX_NUM_DMICS;