diff options
author | Takashi Iwai <tiwai@suse.de> | 2008-02-12 12:32:23 -0500 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2008-04-24 06:00:10 -0400 |
commit | f6c7e5461e9046445d50c5c7a9a4587824239623 (patch) | |
tree | e7fffba51f93339f10de792b338cc13a7cda7f3d /sound/pci/hda/patch_realtek.c | |
parent | 5832fcf8b55cfdbd7d8511f747d15fd20ed4703d (diff) |
[ALSA] hda-codec - Fix auto-configuration of Realtek codecs
This patch fixes some bugs in the auto-configurator of Realtek codecs:
- add missing pin set-up for speaker pins
- fix the speaker auto-mute function not to conflict with the existing
"Speaker" mixer switch
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/hda/patch_realtek.c')
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 111 |
1 files changed, 63 insertions, 48 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index f1fa1d249369..d41eafacd86d 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -746,7 +746,6 @@ static struct hda_verb alc_gpio3_init_verbs[] = { | |||
746 | static void alc_sku_automute(struct hda_codec *codec) | 746 | static void alc_sku_automute(struct hda_codec *codec) |
747 | { | 747 | { |
748 | struct alc_spec *spec = codec->spec; | 748 | struct alc_spec *spec = codec->spec; |
749 | unsigned int mute; | ||
750 | unsigned int present; | 749 | unsigned int present; |
751 | unsigned int hp_nid = spec->autocfg.hp_pins[0]; | 750 | unsigned int hp_nid = spec->autocfg.hp_pins[0]; |
752 | unsigned int sp_nid = spec->autocfg.speaker_pins[0]; | 751 | unsigned int sp_nid = spec->autocfg.speaker_pins[0]; |
@@ -756,16 +755,8 @@ static void alc_sku_automute(struct hda_codec *codec) | |||
756 | present = snd_hda_codec_read(codec, hp_nid, 0, | 755 | present = snd_hda_codec_read(codec, hp_nid, 0, |
757 | AC_VERB_GET_PIN_SENSE, 0); | 756 | AC_VERB_GET_PIN_SENSE, 0); |
758 | spec->jack_present = (present & 0x80000000) != 0; | 757 | spec->jack_present = (present & 0x80000000) != 0; |
759 | if (spec->jack_present) { | 758 | snd_hda_codec_write(codec, sp_nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, |
760 | /* mute internal speaker */ | 759 | spec->jack_present ? 0 : PIN_OUT); |
761 | snd_hda_codec_amp_stereo(codec, sp_nid, HDA_OUTPUT, 0, | ||
762 | HDA_AMP_MUTE, HDA_AMP_MUTE); | ||
763 | } else { | ||
764 | /* unmute internal speaker if necessary */ | ||
765 | mute = snd_hda_codec_amp_read(codec, hp_nid, 0, HDA_OUTPUT, 0); | ||
766 | snd_hda_codec_amp_stereo(codec, sp_nid, HDA_OUTPUT, 0, | ||
767 | HDA_AMP_MUTE, mute); | ||
768 | } | ||
769 | } | 760 | } |
770 | 761 | ||
771 | /* unsolicited event for HP jack sensing */ | 762 | /* unsolicited event for HP jack sensing */ |
@@ -3486,15 +3477,20 @@ static int alc880_auto_create_analog_input_ctls(struct alc_spec *spec, | |||
3486 | return 0; | 3477 | return 0; |
3487 | } | 3478 | } |
3488 | 3479 | ||
3480 | static void alc_set_pin_output(struct hda_codec *codec, hda_nid_t nid, | ||
3481 | unsigned int pin_type) | ||
3482 | { | ||
3483 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
3484 | pin_type); | ||
3485 | /* unmute pin */ | ||
3486 | snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0, 0xff, 0x00); | ||
3487 | } | ||
3488 | |||
3489 | static void alc880_auto_set_output_and_unmute(struct hda_codec *codec, | 3489 | static void alc880_auto_set_output_and_unmute(struct hda_codec *codec, |
3490 | hda_nid_t nid, int pin_type, | 3490 | hda_nid_t nid, int pin_type, |
3491 | int dac_idx) | 3491 | int dac_idx) |
3492 | { | 3492 | { |
3493 | /* set as output */ | 3493 | alc_set_pin_output(codec, nid, pin_type); |
3494 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
3495 | pin_type); | ||
3496 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
3497 | AMP_OUT_UNMUTE); | ||
3498 | /* need the manual connection? */ | 3494 | /* need the manual connection? */ |
3499 | if (alc880_is_multi_pin(nid)) { | 3495 | if (alc880_is_multi_pin(nid)) { |
3500 | struct alc_spec *spec = codec->spec; | 3496 | struct alc_spec *spec = codec->spec; |
@@ -3616,9 +3612,12 @@ static int alc880_parse_auto_config(struct hda_codec *codec) | |||
3616 | /* additional initialization for auto-configuration model */ | 3612 | /* additional initialization for auto-configuration model */ |
3617 | static void alc880_auto_init(struct hda_codec *codec) | 3613 | static void alc880_auto_init(struct hda_codec *codec) |
3618 | { | 3614 | { |
3615 | struct alc_spec *spec = codec->spec; | ||
3619 | alc880_auto_init_multi_out(codec); | 3616 | alc880_auto_init_multi_out(codec); |
3620 | alc880_auto_init_extra_out(codec); | 3617 | alc880_auto_init_extra_out(codec); |
3621 | alc880_auto_init_analog_input(codec); | 3618 | alc880_auto_init_analog_input(codec); |
3619 | if (spec->unsol_event) | ||
3620 | alc_sku_automute(codec); | ||
3622 | } | 3621 | } |
3623 | 3622 | ||
3624 | /* | 3623 | /* |
@@ -4814,11 +4813,7 @@ static void alc260_auto_set_output_and_unmute(struct hda_codec *codec, | |||
4814 | hda_nid_t nid, int pin_type, | 4813 | hda_nid_t nid, int pin_type, |
4815 | int sel_idx) | 4814 | int sel_idx) |
4816 | { | 4815 | { |
4817 | /* set as output */ | 4816 | alc_set_pin_output(codec, nid, pin_type); |
4818 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
4819 | pin_type); | ||
4820 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
4821 | AMP_OUT_UNMUTE); | ||
4822 | /* need the manual connection? */ | 4817 | /* need the manual connection? */ |
4823 | if (nid >= 0x12) { | 4818 | if (nid >= 0x12) { |
4824 | int idx = nid - 0x12; | 4819 | int idx = nid - 0x12; |
@@ -4965,8 +4960,11 @@ static int alc260_parse_auto_config(struct hda_codec *codec) | |||
4965 | /* additional initialization for auto-configuration model */ | 4960 | /* additional initialization for auto-configuration model */ |
4966 | static void alc260_auto_init(struct hda_codec *codec) | 4961 | static void alc260_auto_init(struct hda_codec *codec) |
4967 | { | 4962 | { |
4963 | struct alc_spec *spec = codec->spec; | ||
4968 | alc260_auto_init_multi_out(codec); | 4964 | alc260_auto_init_multi_out(codec); |
4969 | alc260_auto_init_analog_input(codec); | 4965 | alc260_auto_init_analog_input(codec); |
4966 | if (spec->unsol_event) | ||
4967 | alc_sku_automute(codec); | ||
4970 | } | 4968 | } |
4971 | 4969 | ||
4972 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 4970 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
@@ -6201,15 +6199,11 @@ static void alc882_auto_set_output_and_unmute(struct hda_codec *codec, | |||
6201 | struct alc_spec *spec = codec->spec; | 6199 | struct alc_spec *spec = codec->spec; |
6202 | int idx; | 6200 | int idx; |
6203 | 6201 | ||
6202 | alc_set_pin_output(codec, nid, pin_type); | ||
6204 | if (spec->multiout.dac_nids[dac_idx] == 0x25) | 6203 | if (spec->multiout.dac_nids[dac_idx] == 0x25) |
6205 | idx = 4; | 6204 | idx = 4; |
6206 | else | 6205 | else |
6207 | idx = spec->multiout.dac_nids[dac_idx] - 2; | 6206 | idx = spec->multiout.dac_nids[dac_idx] - 2; |
6208 | |||
6209 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
6210 | pin_type); | ||
6211 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
6212 | AMP_OUT_UNMUTE); | ||
6213 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); | 6207 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); |
6214 | 6208 | ||
6215 | } | 6209 | } |
@@ -6238,6 +6232,9 @@ static void alc882_auto_init_hp_out(struct hda_codec *codec) | |||
6238 | if (pin) /* connect to front */ | 6232 | if (pin) /* connect to front */ |
6239 | /* use dac 0 */ | 6233 | /* use dac 0 */ |
6240 | alc882_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); | 6234 | alc882_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); |
6235 | pin = spec->autocfg.speaker_pins[0]; | ||
6236 | if (pin) | ||
6237 | alc882_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0); | ||
6241 | } | 6238 | } |
6242 | 6239 | ||
6243 | #define alc882_is_input_pin(nid) alc880_is_input_pin(nid) | 6240 | #define alc882_is_input_pin(nid) alc880_is_input_pin(nid) |
@@ -6313,9 +6310,12 @@ static int alc882_parse_auto_config(struct hda_codec *codec) | |||
6313 | /* additional initialization for auto-configuration model */ | 6310 | /* additional initialization for auto-configuration model */ |
6314 | static void alc882_auto_init(struct hda_codec *codec) | 6311 | static void alc882_auto_init(struct hda_codec *codec) |
6315 | { | 6312 | { |
6313 | struct alc_spec *spec = codec->spec; | ||
6316 | alc882_auto_init_multi_out(codec); | 6314 | alc882_auto_init_multi_out(codec); |
6317 | alc882_auto_init_hp_out(codec); | 6315 | alc882_auto_init_hp_out(codec); |
6318 | alc882_auto_init_analog_input(codec); | 6316 | alc882_auto_init_analog_input(codec); |
6317 | if (spec->unsol_event) | ||
6318 | alc_sku_automute(codec); | ||
6319 | } | 6319 | } |
6320 | 6320 | ||
6321 | static int patch_alc882(struct hda_codec *codec) | 6321 | static int patch_alc882(struct hda_codec *codec) |
@@ -7878,15 +7878,11 @@ static void alc883_auto_set_output_and_unmute(struct hda_codec *codec, | |||
7878 | struct alc_spec *spec = codec->spec; | 7878 | struct alc_spec *spec = codec->spec; |
7879 | int idx; | 7879 | int idx; |
7880 | 7880 | ||
7881 | alc_set_pin_output(codec, nid, pin_type); | ||
7881 | if (spec->multiout.dac_nids[dac_idx] == 0x25) | 7882 | if (spec->multiout.dac_nids[dac_idx] == 0x25) |
7882 | idx = 4; | 7883 | idx = 4; |
7883 | else | 7884 | else |
7884 | idx = spec->multiout.dac_nids[dac_idx] - 2; | 7885 | idx = spec->multiout.dac_nids[dac_idx] - 2; |
7885 | |||
7886 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
7887 | pin_type); | ||
7888 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
7889 | AMP_OUT_UNMUTE); | ||
7890 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); | 7886 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); |
7891 | 7887 | ||
7892 | } | 7888 | } |
@@ -7915,6 +7911,9 @@ static void alc883_auto_init_hp_out(struct hda_codec *codec) | |||
7915 | if (pin) /* connect to front */ | 7911 | if (pin) /* connect to front */ |
7916 | /* use dac 0 */ | 7912 | /* use dac 0 */ |
7917 | alc883_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); | 7913 | alc883_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); |
7914 | pin = spec->autocfg.speaker_pins[0]; | ||
7915 | if (pin) | ||
7916 | alc883_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0); | ||
7918 | } | 7917 | } |
7919 | 7918 | ||
7920 | #define alc883_is_input_pin(nid) alc880_is_input_pin(nid) | 7919 | #define alc883_is_input_pin(nid) alc880_is_input_pin(nid) |
@@ -7966,9 +7965,12 @@ static int alc883_parse_auto_config(struct hda_codec *codec) | |||
7966 | /* additional initialization for auto-configuration model */ | 7965 | /* additional initialization for auto-configuration model */ |
7967 | static void alc883_auto_init(struct hda_codec *codec) | 7966 | static void alc883_auto_init(struct hda_codec *codec) |
7968 | { | 7967 | { |
7968 | struct alc_spec *spec = codec->spec; | ||
7969 | alc883_auto_init_multi_out(codec); | 7969 | alc883_auto_init_multi_out(codec); |
7970 | alc883_auto_init_hp_out(codec); | 7970 | alc883_auto_init_hp_out(codec); |
7971 | alc883_auto_init_analog_input(codec); | 7971 | alc883_auto_init_analog_input(codec); |
7972 | if (spec->unsol_event) | ||
7973 | alc_sku_automute(codec); | ||
7972 | } | 7974 | } |
7973 | 7975 | ||
7974 | static int patch_alc883(struct hda_codec *codec) | 7976 | static int patch_alc883(struct hda_codec *codec) |
@@ -9144,9 +9146,12 @@ static int alc262_parse_auto_config(struct hda_codec *codec) | |||
9144 | /* init callback for auto-configuration model -- overriding the default init */ | 9146 | /* init callback for auto-configuration model -- overriding the default init */ |
9145 | static void alc262_auto_init(struct hda_codec *codec) | 9147 | static void alc262_auto_init(struct hda_codec *codec) |
9146 | { | 9148 | { |
9149 | struct alc_spec *spec = codec->spec; | ||
9147 | alc262_auto_init_multi_out(codec); | 9150 | alc262_auto_init_multi_out(codec); |
9148 | alc262_auto_init_hp_out(codec); | 9151 | alc262_auto_init_hp_out(codec); |
9149 | alc262_auto_init_analog_input(codec); | 9152 | alc262_auto_init_analog_input(codec); |
9153 | if (spec->unsol_event) | ||
9154 | alc_sku_automute(codec); | ||
9150 | } | 9155 | } |
9151 | 9156 | ||
9152 | /* | 9157 | /* |
@@ -10033,10 +10038,13 @@ static int alc268_parse_auto_config(struct hda_codec *codec) | |||
10033 | /* init callback for auto-configuration model -- overriding the default init */ | 10038 | /* init callback for auto-configuration model -- overriding the default init */ |
10034 | static void alc268_auto_init(struct hda_codec *codec) | 10039 | static void alc268_auto_init(struct hda_codec *codec) |
10035 | { | 10040 | { |
10041 | struct alc_spec *spec = codec->spec; | ||
10036 | alc268_auto_init_multi_out(codec); | 10042 | alc268_auto_init_multi_out(codec); |
10037 | alc268_auto_init_hp_out(codec); | 10043 | alc268_auto_init_hp_out(codec); |
10038 | alc268_auto_init_mono_speaker_out(codec); | 10044 | alc268_auto_init_mono_speaker_out(codec); |
10039 | alc268_auto_init_analog_input(codec); | 10045 | alc268_auto_init_analog_input(codec); |
10046 | if (spec->unsol_event) | ||
10047 | alc_sku_automute(codec); | ||
10040 | } | 10048 | } |
10041 | 10049 | ||
10042 | /* | 10050 | /* |
@@ -10505,9 +10513,12 @@ static int alc269_parse_auto_config(struct hda_codec *codec) | |||
10505 | /* init callback for auto-configuration model -- overriding the default init */ | 10513 | /* init callback for auto-configuration model -- overriding the default init */ |
10506 | static void alc269_auto_init(struct hda_codec *codec) | 10514 | static void alc269_auto_init(struct hda_codec *codec) |
10507 | { | 10515 | { |
10516 | struct alc_spec *spec = codec->spec; | ||
10508 | alc269_auto_init_multi_out(codec); | 10517 | alc269_auto_init_multi_out(codec); |
10509 | alc269_auto_init_hp_out(codec); | 10518 | alc269_auto_init_hp_out(codec); |
10510 | alc269_auto_init_analog_input(codec); | 10519 | alc269_auto_init_analog_input(codec); |
10520 | if (spec->unsol_event) | ||
10521 | alc_sku_automute(codec); | ||
10511 | } | 10522 | } |
10512 | 10523 | ||
10513 | /* | 10524 | /* |
@@ -11429,13 +11440,7 @@ static void alc861_auto_set_output_and_unmute(struct hda_codec *codec, | |||
11429 | hda_nid_t nid, | 11440 | hda_nid_t nid, |
11430 | int pin_type, int dac_idx) | 11441 | int pin_type, int dac_idx) |
11431 | { | 11442 | { |
11432 | /* set as output */ | 11443 | alc_set_pin_output(codec, nid, pin_type); |
11433 | |||
11434 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | ||
11435 | pin_type); | ||
11436 | snd_hda_codec_write(codec, dac_idx, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
11437 | AMP_OUT_UNMUTE); | ||
11438 | |||
11439 | } | 11444 | } |
11440 | 11445 | ||
11441 | static void alc861_auto_init_multi_out(struct hda_codec *codec) | 11446 | static void alc861_auto_init_multi_out(struct hda_codec *codec) |
@@ -11462,6 +11467,9 @@ static void alc861_auto_init_hp_out(struct hda_codec *codec) | |||
11462 | if (pin) /* connect to front */ | 11467 | if (pin) /* connect to front */ |
11463 | alc861_auto_set_output_and_unmute(codec, pin, PIN_HP, | 11468 | alc861_auto_set_output_and_unmute(codec, pin, PIN_HP, |
11464 | spec->multiout.dac_nids[0]); | 11469 | spec->multiout.dac_nids[0]); |
11470 | pin = spec->autocfg.speaker_pins[0]; | ||
11471 | if (pin) | ||
11472 | alc861_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0); | ||
11465 | } | 11473 | } |
11466 | 11474 | ||
11467 | static void alc861_auto_init_analog_input(struct hda_codec *codec) | 11475 | static void alc861_auto_init_analog_input(struct hda_codec *codec) |
@@ -11534,9 +11542,12 @@ static int alc861_parse_auto_config(struct hda_codec *codec) | |||
11534 | /* additional initialization for auto-configuration model */ | 11542 | /* additional initialization for auto-configuration model */ |
11535 | static void alc861_auto_init(struct hda_codec *codec) | 11543 | static void alc861_auto_init(struct hda_codec *codec) |
11536 | { | 11544 | { |
11545 | struct alc_spec *spec = codec->spec; | ||
11537 | alc861_auto_init_multi_out(codec); | 11546 | alc861_auto_init_multi_out(codec); |
11538 | alc861_auto_init_hp_out(codec); | 11547 | alc861_auto_init_hp_out(codec); |
11539 | alc861_auto_init_analog_input(codec); | 11548 | alc861_auto_init_analog_input(codec); |
11549 | if (spec->unsol_event) | ||
11550 | alc_sku_automute(codec); | ||
11540 | } | 11551 | } |
11541 | 11552 | ||
11542 | #ifdef CONFIG_SND_HDA_POWER_SAVE | 11553 | #ifdef CONFIG_SND_HDA_POWER_SAVE |
@@ -12397,11 +12408,7 @@ static struct alc_config_preset alc861vd_presets[] = { | |||
12397 | static void alc861vd_auto_set_output_and_unmute(struct hda_codec *codec, | 12408 | static void alc861vd_auto_set_output_and_unmute(struct hda_codec *codec, |
12398 | hda_nid_t nid, int pin_type, int dac_idx) | 12409 | hda_nid_t nid, int pin_type, int dac_idx) |
12399 | { | 12410 | { |
12400 | /* set as output */ | 12411 | alc_set_pin_output(codec, nid, pin_type); |
12401 | snd_hda_codec_write(codec, nid, 0, | ||
12402 | AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | ||
12403 | snd_hda_codec_write(codec, nid, 0, | ||
12404 | AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | ||
12405 | } | 12412 | } |
12406 | 12413 | ||
12407 | static void alc861vd_auto_init_multi_out(struct hda_codec *codec) | 12414 | static void alc861vd_auto_init_multi_out(struct hda_codec *codec) |
@@ -12428,6 +12435,9 @@ static void alc861vd_auto_init_hp_out(struct hda_codec *codec) | |||
12428 | pin = spec->autocfg.hp_pins[0]; | 12435 | pin = spec->autocfg.hp_pins[0]; |
12429 | if (pin) /* connect to front and use dac 0 */ | 12436 | if (pin) /* connect to front and use dac 0 */ |
12430 | alc861vd_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); | 12437 | alc861vd_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); |
12438 | pin = spec->autocfg.speaker_pins[0]; | ||
12439 | if (pin) | ||
12440 | alc861vd_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0); | ||
12431 | } | 12441 | } |
12432 | 12442 | ||
12433 | #define alc861vd_is_input_pin(nid) alc880_is_input_pin(nid) | 12443 | #define alc861vd_is_input_pin(nid) alc880_is_input_pin(nid) |
@@ -12631,9 +12641,12 @@ static int alc861vd_parse_auto_config(struct hda_codec *codec) | |||
12631 | /* additional initialization for auto-configuration model */ | 12641 | /* additional initialization for auto-configuration model */ |
12632 | static void alc861vd_auto_init(struct hda_codec *codec) | 12642 | static void alc861vd_auto_init(struct hda_codec *codec) |
12633 | { | 12643 | { |
12644 | struct alc_spec *spec = codec->spec; | ||
12634 | alc861vd_auto_init_multi_out(codec); | 12645 | alc861vd_auto_init_multi_out(codec); |
12635 | alc861vd_auto_init_hp_out(codec); | 12646 | alc861vd_auto_init_hp_out(codec); |
12636 | alc861vd_auto_init_analog_input(codec); | 12647 | alc861vd_auto_init_analog_input(codec); |
12648 | if (spec->unsol_event) | ||
12649 | alc_sku_automute(codec); | ||
12637 | } | 12650 | } |
12638 | 12651 | ||
12639 | static int patch_alc861vd(struct hda_codec *codec) | 12652 | static int patch_alc861vd(struct hda_codec *codec) |
@@ -13453,11 +13466,7 @@ static void alc662_auto_set_output_and_unmute(struct hda_codec *codec, | |||
13453 | hda_nid_t nid, int pin_type, | 13466 | hda_nid_t nid, int pin_type, |
13454 | int dac_idx) | 13467 | int dac_idx) |
13455 | { | 13468 | { |
13456 | /* set as output */ | 13469 | alc_set_pin_output(codec, nid, pin_type); |
13457 | snd_hda_codec_write(codec, nid, 0, | ||
13458 | AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | ||
13459 | snd_hda_codec_write(codec, nid, 0, | ||
13460 | AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | ||
13461 | /* need the manual connection? */ | 13470 | /* need the manual connection? */ |
13462 | if (alc880_is_multi_pin(nid)) { | 13471 | if (alc880_is_multi_pin(nid)) { |
13463 | struct alc_spec *spec = codec->spec; | 13472 | struct alc_spec *spec = codec->spec; |
@@ -13492,6 +13501,9 @@ static void alc662_auto_init_hp_out(struct hda_codec *codec) | |||
13492 | if (pin) /* connect to front */ | 13501 | if (pin) /* connect to front */ |
13493 | /* use dac 0 */ | 13502 | /* use dac 0 */ |
13494 | alc662_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); | 13503 | alc662_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); |
13504 | pin = spec->autocfg.speaker_pins[0]; | ||
13505 | if (pin) | ||
13506 | alc662_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0); | ||
13495 | } | 13507 | } |
13496 | 13508 | ||
13497 | #define alc662_is_input_pin(nid) alc880_is_input_pin(nid) | 13509 | #define alc662_is_input_pin(nid) alc880_is_input_pin(nid) |
@@ -13569,9 +13581,12 @@ static int alc662_parse_auto_config(struct hda_codec *codec) | |||
13569 | /* additional initialization for auto-configuration model */ | 13581 | /* additional initialization for auto-configuration model */ |
13570 | static void alc662_auto_init(struct hda_codec *codec) | 13582 | static void alc662_auto_init(struct hda_codec *codec) |
13571 | { | 13583 | { |
13584 | struct alc_spec *spec = codec->spec; | ||
13572 | alc662_auto_init_multi_out(codec); | 13585 | alc662_auto_init_multi_out(codec); |
13573 | alc662_auto_init_hp_out(codec); | 13586 | alc662_auto_init_hp_out(codec); |
13574 | alc662_auto_init_analog_input(codec); | 13587 | alc662_auto_init_analog_input(codec); |
13588 | if (spec->unsol_event) | ||
13589 | alc_sku_automute(codec); | ||
13575 | } | 13590 | } |
13576 | 13591 | ||
13577 | static int patch_alc662(struct hda_codec *codec) | 13592 | static int patch_alc662(struct hda_codec *codec) |