Merge branch 'topic/hda' into for-linus
authorTakashi Iwai <tiwai@suse.de>
Tue, 7 Apr 2009 02:50:46 +0000 (04:50 +0200)
committerTakashi Iwai <tiwai@suse.de>
Tue, 7 Apr 2009 02:50:46 +0000 (04:50 +0200)
sound/pci/hda/patch_analog.c
sound/pci/hda/patch_sigmatel.c

index 5bb48ee..38ad3f7 100644 (file)
@@ -3256,7 +3256,7 @@ static const char *ad1884_slave_vols[] = {
        "Mic Playback Volume",
        "CD Playback Volume",
        "Internal Mic Playback Volume",
-       "Docking Mic Playback Volume"
+       "Docking Mic Playback Volume",
        /* "Beep Playback Volume", */
        "IEC958 Playback Volume",
        NULL
index b34d78b..61996a2 100644 (file)
@@ -4413,6 +4413,24 @@ static void stac92xx_unsol_event(struct hda_codec *codec, unsigned int res)
                if (spec->num_pwrs > 0)
                        stac92xx_pin_sense(codec, event->nid);
                stac92xx_report_jack(codec, event->nid);
+
+               switch (codec->subsystem_id) {
+               case 0x103c308f:
+                       if (event->nid == 0xb) {
+                               int pin = AC_PINCTL_IN_EN;
+
+                               if (get_pin_presence(codec, 0xa)
+                                               && get_pin_presence(codec, 0xb))
+                                       pin |= AC_PINCTL_VREF_80;
+                               if (!get_pin_presence(codec, 0xb))
+                                       pin |= AC_PINCTL_VREF_80;
+
+                               /* toggle VREF state based on mic + hp pin
+                                * status
+                                */
+                               stac92xx_auto_set_pinctl(codec, 0x0a, pin);
+                       }
+               }
                break;
        case STAC_VREF_EVENT:
                data = snd_hda_codec_read(codec, codec->afg, 0,