diff options
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 938 |
1 files changed, 581 insertions, 357 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 5d7f61982001..f5944e05431f 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -177,7 +177,7 @@ struct alc_spec { | |||
177 | struct hda_pcm_stream *stream_analog_playback; | 177 | struct hda_pcm_stream *stream_analog_playback; |
178 | struct hda_pcm_stream *stream_analog_capture; | 178 | struct hda_pcm_stream *stream_analog_capture; |
179 | 179 | ||
180 | char *stream_name_digital; /* digital PCM stream */ | 180 | char *stream_name_digital; /* digital PCM stream */ |
181 | struct hda_pcm_stream *stream_digital_playback; | 181 | struct hda_pcm_stream *stream_digital_playback; |
182 | struct hda_pcm_stream *stream_digital_capture; | 182 | struct hda_pcm_stream *stream_digital_capture; |
183 | 183 | ||
@@ -415,7 +415,7 @@ static int alc_pin_mode_put(struct snd_kcontrol *kcontrol, | |||
415 | AC_VERB_GET_PIN_WIDGET_CONTROL, | 415 | AC_VERB_GET_PIN_WIDGET_CONTROL, |
416 | 0x00); | 416 | 0x00); |
417 | 417 | ||
418 | if (val < alc_pin_mode_min(dir) || val > alc_pin_mode_max(dir)) | 418 | if (val < alc_pin_mode_min(dir) || val > alc_pin_mode_max(dir)) |
419 | val = alc_pin_mode_min(dir); | 419 | val = alc_pin_mode_min(dir); |
420 | 420 | ||
421 | change = pinctl != alc_pin_mode_values[val]; | 421 | change = pinctl != alc_pin_mode_values[val]; |
@@ -474,7 +474,8 @@ static int alc_gpio_data_info(struct snd_kcontrol *kcontrol, | |||
474 | uinfo->value.integer.min = 0; | 474 | uinfo->value.integer.min = 0; |
475 | uinfo->value.integer.max = 1; | 475 | uinfo->value.integer.max = 1; |
476 | return 0; | 476 | return 0; |
477 | } | 477 | } |
478 | |||
478 | static int alc_gpio_data_get(struct snd_kcontrol *kcontrol, | 479 | static int alc_gpio_data_get(struct snd_kcontrol *kcontrol, |
479 | struct snd_ctl_elem_value *ucontrol) | 480 | struct snd_ctl_elem_value *ucontrol) |
480 | { | 481 | { |
@@ -534,7 +535,8 @@ static int alc_spdif_ctrl_info(struct snd_kcontrol *kcontrol, | |||
534 | uinfo->value.integer.min = 0; | 535 | uinfo->value.integer.min = 0; |
535 | uinfo->value.integer.max = 1; | 536 | uinfo->value.integer.max = 1; |
536 | return 0; | 537 | return 0; |
537 | } | 538 | } |
539 | |||
538 | static int alc_spdif_ctrl_get(struct snd_kcontrol *kcontrol, | 540 | static int alc_spdif_ctrl_get(struct snd_kcontrol *kcontrol, |
539 | struct snd_ctl_elem_value *ucontrol) | 541 | struct snd_ctl_elem_value *ucontrol) |
540 | { | 542 | { |
@@ -606,7 +608,7 @@ static void setup_preset(struct alc_spec *spec, | |||
606 | spec->multiout.hp_nid = preset->hp_nid; | 608 | spec->multiout.hp_nid = preset->hp_nid; |
607 | 609 | ||
608 | spec->num_mux_defs = preset->num_mux_defs; | 610 | spec->num_mux_defs = preset->num_mux_defs; |
609 | if (! spec->num_mux_defs) | 611 | if (!spec->num_mux_defs) |
610 | spec->num_mux_defs = 1; | 612 | spec->num_mux_defs = 1; |
611 | spec->input_mux = preset->input_mux; | 613 | spec->input_mux = preset->input_mux; |
612 | 614 | ||
@@ -877,7 +879,7 @@ static struct hda_channel_mode alc880_fivestack_modes[2] = { | |||
877 | static hda_nid_t alc880_6st_dac_nids[4] = { | 879 | static hda_nid_t alc880_6st_dac_nids[4] = { |
878 | /* front, rear, clfe, rear_surr */ | 880 | /* front, rear, clfe, rear_surr */ |
879 | 0x02, 0x03, 0x04, 0x05 | 881 | 0x02, 0x03, 0x04, 0x05 |
880 | }; | 882 | }; |
881 | 883 | ||
882 | static struct hda_input_mux alc880_6stack_capture_source = { | 884 | static struct hda_input_mux alc880_6stack_capture_source = { |
883 | .num_items = 4, | 885 | .num_items = 4, |
@@ -1488,22 +1490,24 @@ static struct hda_verb alc880_beep_init_verbs[] = { | |||
1488 | static void alc880_uniwill_automute(struct hda_codec *codec) | 1490 | static void alc880_uniwill_automute(struct hda_codec *codec) |
1489 | { | 1491 | { |
1490 | unsigned int present; | 1492 | unsigned int present; |
1493 | unsigned char bits; | ||
1491 | 1494 | ||
1492 | present = snd_hda_codec_read(codec, 0x14, 0, | 1495 | present = snd_hda_codec_read(codec, 0x14, 0, |
1493 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 1496 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
1497 | bits = present ? 0x80 : 0; | ||
1494 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, | 1498 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, |
1495 | 0x80, present ? 0x80 : 0); | 1499 | 0x80, bits); |
1496 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, | 1500 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, |
1497 | 0x80, present ? 0x80 : 0); | 1501 | 0x80, bits); |
1498 | snd_hda_codec_amp_update(codec, 0x16, 0, HDA_OUTPUT, 0, | 1502 | snd_hda_codec_amp_update(codec, 0x16, 0, HDA_OUTPUT, 0, |
1499 | 0x80, present ? 0x80 : 0); | 1503 | 0x80, bits); |
1500 | snd_hda_codec_amp_update(codec, 0x16, 1, HDA_OUTPUT, 0, | 1504 | snd_hda_codec_amp_update(codec, 0x16, 1, HDA_OUTPUT, 0, |
1501 | 0x80, present ? 0x80 : 0); | 1505 | 0x80, bits); |
1502 | 1506 | ||
1503 | present = snd_hda_codec_read(codec, 0x18, 0, | 1507 | present = snd_hda_codec_read(codec, 0x18, 0, |
1504 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 1508 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
1505 | snd_hda_codec_write(codec, 0x0b, 0, AC_VERB_SET_AMP_GAIN_MUTE, | 1509 | snd_hda_codec_write(codec, 0x0b, 0, AC_VERB_SET_AMP_GAIN_MUTE, |
1506 | 0x7000 | (0x01 << 8) | (present ? 0x80 : 0)); | 1510 | 0x7000 | (0x01 << 8) | bits); |
1507 | } | 1511 | } |
1508 | 1512 | ||
1509 | static void alc880_uniwill_unsol_event(struct hda_codec *codec, | 1513 | static void alc880_uniwill_unsol_event(struct hda_codec *codec, |
@@ -1520,14 +1524,15 @@ static void alc880_uniwill_unsol_event(struct hda_codec *codec, | |||
1520 | static void alc880_uniwill_p53_hp_automute(struct hda_codec *codec) | 1524 | static void alc880_uniwill_p53_hp_automute(struct hda_codec *codec) |
1521 | { | 1525 | { |
1522 | unsigned int present; | 1526 | unsigned int present; |
1527 | unsigned char bits; | ||
1523 | 1528 | ||
1524 | present = snd_hda_codec_read(codec, 0x14, 0, | 1529 | present = snd_hda_codec_read(codec, 0x14, 0, |
1525 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 1530 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
1526 | 1531 | bits = present ? 0x80 : 0; | |
1527 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_INPUT, 0, | 1532 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_INPUT, 0, |
1528 | 0x80, present ? 0x80 : 0); | 1533 | 0x80, bits); |
1529 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_INPUT, 0, | 1534 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_INPUT, 0, |
1530 | 0x80, present ? 0x80 : 0); | 1535 | 0x80, bits); |
1531 | } | 1536 | } |
1532 | 1537 | ||
1533 | static void alc880_uniwill_p53_dcvol_automute(struct hda_codec *codec) | 1538 | static void alc880_uniwill_p53_dcvol_automute(struct hda_codec *codec) |
@@ -1556,7 +1561,7 @@ static void alc880_uniwill_p53_unsol_event(struct hda_codec *codec, | |||
1556 | */ | 1561 | */ |
1557 | if ((res >> 28) == ALC880_HP_EVENT) | 1562 | if ((res >> 28) == ALC880_HP_EVENT) |
1558 | alc880_uniwill_p53_hp_automute(codec); | 1563 | alc880_uniwill_p53_hp_automute(codec); |
1559 | if ((res >> 28) == ALC880_DCVOL_EVENT) | 1564 | if ((res >> 28) == ALC880_DCVOL_EVENT) |
1560 | alc880_uniwill_p53_dcvol_automute(codec); | 1565 | alc880_uniwill_p53_dcvol_automute(codec); |
1561 | } | 1566 | } |
1562 | 1567 | ||
@@ -1796,13 +1801,15 @@ static struct hda_verb alc880_lg_init_verbs[] = { | |||
1796 | static void alc880_lg_automute(struct hda_codec *codec) | 1801 | static void alc880_lg_automute(struct hda_codec *codec) |
1797 | { | 1802 | { |
1798 | unsigned int present; | 1803 | unsigned int present; |
1804 | unsigned char bits; | ||
1799 | 1805 | ||
1800 | present = snd_hda_codec_read(codec, 0x1b, 0, | 1806 | present = snd_hda_codec_read(codec, 0x1b, 0, |
1801 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 1807 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
1808 | bits = present ? 0x80 : 0; | ||
1802 | snd_hda_codec_amp_update(codec, 0x17, 0, HDA_OUTPUT, 0, | 1809 | snd_hda_codec_amp_update(codec, 0x17, 0, HDA_OUTPUT, 0, |
1803 | 0x80, present ? 0x80 : 0); | 1810 | 0x80, bits); |
1804 | snd_hda_codec_amp_update(codec, 0x17, 1, HDA_OUTPUT, 0, | 1811 | snd_hda_codec_amp_update(codec, 0x17, 1, HDA_OUTPUT, 0, |
1805 | 0x80, present ? 0x80 : 0); | 1812 | 0x80, bits); |
1806 | } | 1813 | } |
1807 | 1814 | ||
1808 | static void alc880_lg_unsol_event(struct hda_codec *codec, unsigned int res) | 1815 | static void alc880_lg_unsol_event(struct hda_codec *codec, unsigned int res) |
@@ -1872,13 +1879,15 @@ static struct hda_verb alc880_lg_lw_init_verbs[] = { | |||
1872 | static void alc880_lg_lw_automute(struct hda_codec *codec) | 1879 | static void alc880_lg_lw_automute(struct hda_codec *codec) |
1873 | { | 1880 | { |
1874 | unsigned int present; | 1881 | unsigned int present; |
1882 | unsigned char bits; | ||
1875 | 1883 | ||
1876 | present = snd_hda_codec_read(codec, 0x1b, 0, | 1884 | present = snd_hda_codec_read(codec, 0x1b, 0, |
1877 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 1885 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
1886 | bits = present ? 0x80 : 0; | ||
1878 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, | 1887 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, |
1879 | 0x80, present ? 0x80 : 0); | 1888 | 0x80, bits); |
1880 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, | 1889 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, |
1881 | 0x80, present ? 0x80 : 0); | 1890 | 0x80, bits); |
1882 | } | 1891 | } |
1883 | 1892 | ||
1884 | static void alc880_lg_lw_unsol_event(struct hda_codec *codec, unsigned int res) | 1893 | static void alc880_lg_lw_unsol_event(struct hda_codec *codec, unsigned int res) |
@@ -2149,7 +2158,7 @@ static void alc_free(struct hda_codec *codec) | |||
2149 | struct alc_spec *spec = codec->spec; | 2158 | struct alc_spec *spec = codec->spec; |
2150 | unsigned int i; | 2159 | unsigned int i; |
2151 | 2160 | ||
2152 | if (! spec) | 2161 | if (!spec) |
2153 | return; | 2162 | return; |
2154 | 2163 | ||
2155 | if (spec->kctl_alloc) { | 2164 | if (spec->kctl_alloc) { |
@@ -2551,7 +2560,8 @@ static struct snd_pci_quirk alc880_cfg_tbl[] = { | |||
2551 | static struct alc_config_preset alc880_presets[] = { | 2560 | static struct alc_config_preset alc880_presets[] = { |
2552 | [ALC880_3ST] = { | 2561 | [ALC880_3ST] = { |
2553 | .mixers = { alc880_three_stack_mixer }, | 2562 | .mixers = { alc880_three_stack_mixer }, |
2554 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_3stack_init_verbs }, | 2563 | .init_verbs = { alc880_volume_init_verbs, |
2564 | alc880_pin_3stack_init_verbs }, | ||
2555 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), | 2565 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), |
2556 | .dac_nids = alc880_dac_nids, | 2566 | .dac_nids = alc880_dac_nids, |
2557 | .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes), | 2567 | .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes), |
@@ -2561,7 +2571,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2561 | }, | 2571 | }, |
2562 | [ALC880_3ST_DIG] = { | 2572 | [ALC880_3ST_DIG] = { |
2563 | .mixers = { alc880_three_stack_mixer }, | 2573 | .mixers = { alc880_three_stack_mixer }, |
2564 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_3stack_init_verbs }, | 2574 | .init_verbs = { alc880_volume_init_verbs, |
2575 | alc880_pin_3stack_init_verbs }, | ||
2565 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), | 2576 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), |
2566 | .dac_nids = alc880_dac_nids, | 2577 | .dac_nids = alc880_dac_nids, |
2567 | .dig_out_nid = ALC880_DIGOUT_NID, | 2578 | .dig_out_nid = ALC880_DIGOUT_NID, |
@@ -2583,8 +2594,10 @@ static struct alc_config_preset alc880_presets[] = { | |||
2583 | .input_mux = &alc880_capture_source, | 2594 | .input_mux = &alc880_capture_source, |
2584 | }, | 2595 | }, |
2585 | [ALC880_5ST] = { | 2596 | [ALC880_5ST] = { |
2586 | .mixers = { alc880_three_stack_mixer, alc880_five_stack_mixer}, | 2597 | .mixers = { alc880_three_stack_mixer, |
2587 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_5stack_init_verbs }, | 2598 | alc880_five_stack_mixer}, |
2599 | .init_verbs = { alc880_volume_init_verbs, | ||
2600 | alc880_pin_5stack_init_verbs }, | ||
2588 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), | 2601 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), |
2589 | .dac_nids = alc880_dac_nids, | 2602 | .dac_nids = alc880_dac_nids, |
2590 | .num_channel_mode = ARRAY_SIZE(alc880_fivestack_modes), | 2603 | .num_channel_mode = ARRAY_SIZE(alc880_fivestack_modes), |
@@ -2592,8 +2605,10 @@ static struct alc_config_preset alc880_presets[] = { | |||
2592 | .input_mux = &alc880_capture_source, | 2605 | .input_mux = &alc880_capture_source, |
2593 | }, | 2606 | }, |
2594 | [ALC880_5ST_DIG] = { | 2607 | [ALC880_5ST_DIG] = { |
2595 | .mixers = { alc880_three_stack_mixer, alc880_five_stack_mixer }, | 2608 | .mixers = { alc880_three_stack_mixer, |
2596 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_5stack_init_verbs }, | 2609 | alc880_five_stack_mixer }, |
2610 | .init_verbs = { alc880_volume_init_verbs, | ||
2611 | alc880_pin_5stack_init_verbs }, | ||
2597 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), | 2612 | .num_dacs = ARRAY_SIZE(alc880_dac_nids), |
2598 | .dac_nids = alc880_dac_nids, | 2613 | .dac_nids = alc880_dac_nids, |
2599 | .dig_out_nid = ALC880_DIGOUT_NID, | 2614 | .dig_out_nid = ALC880_DIGOUT_NID, |
@@ -2603,7 +2618,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2603 | }, | 2618 | }, |
2604 | [ALC880_6ST] = { | 2619 | [ALC880_6ST] = { |
2605 | .mixers = { alc880_six_stack_mixer }, | 2620 | .mixers = { alc880_six_stack_mixer }, |
2606 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_6stack_init_verbs }, | 2621 | .init_verbs = { alc880_volume_init_verbs, |
2622 | alc880_pin_6stack_init_verbs }, | ||
2607 | .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids), | 2623 | .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids), |
2608 | .dac_nids = alc880_6st_dac_nids, | 2624 | .dac_nids = alc880_6st_dac_nids, |
2609 | .num_channel_mode = ARRAY_SIZE(alc880_sixstack_modes), | 2625 | .num_channel_mode = ARRAY_SIZE(alc880_sixstack_modes), |
@@ -2612,7 +2628,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2612 | }, | 2628 | }, |
2613 | [ALC880_6ST_DIG] = { | 2629 | [ALC880_6ST_DIG] = { |
2614 | .mixers = { alc880_six_stack_mixer }, | 2630 | .mixers = { alc880_six_stack_mixer }, |
2615 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_6stack_init_verbs }, | 2631 | .init_verbs = { alc880_volume_init_verbs, |
2632 | alc880_pin_6stack_init_verbs }, | ||
2616 | .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids), | 2633 | .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids), |
2617 | .dac_nids = alc880_6st_dac_nids, | 2634 | .dac_nids = alc880_6st_dac_nids, |
2618 | .dig_out_nid = ALC880_DIGOUT_NID, | 2635 | .dig_out_nid = ALC880_DIGOUT_NID, |
@@ -2622,7 +2639,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2622 | }, | 2639 | }, |
2623 | [ALC880_W810] = { | 2640 | [ALC880_W810] = { |
2624 | .mixers = { alc880_w810_base_mixer }, | 2641 | .mixers = { alc880_w810_base_mixer }, |
2625 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_w810_init_verbs, | 2642 | .init_verbs = { alc880_volume_init_verbs, |
2643 | alc880_pin_w810_init_verbs, | ||
2626 | alc880_gpio2_init_verbs }, | 2644 | alc880_gpio2_init_verbs }, |
2627 | .num_dacs = ARRAY_SIZE(alc880_w810_dac_nids), | 2645 | .num_dacs = ARRAY_SIZE(alc880_w810_dac_nids), |
2628 | .dac_nids = alc880_w810_dac_nids, | 2646 | .dac_nids = alc880_w810_dac_nids, |
@@ -2633,7 +2651,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2633 | }, | 2651 | }, |
2634 | [ALC880_Z71V] = { | 2652 | [ALC880_Z71V] = { |
2635 | .mixers = { alc880_z71v_mixer }, | 2653 | .mixers = { alc880_z71v_mixer }, |
2636 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_z71v_init_verbs }, | 2654 | .init_verbs = { alc880_volume_init_verbs, |
2655 | alc880_pin_z71v_init_verbs }, | ||
2637 | .num_dacs = ARRAY_SIZE(alc880_z71v_dac_nids), | 2656 | .num_dacs = ARRAY_SIZE(alc880_z71v_dac_nids), |
2638 | .dac_nids = alc880_z71v_dac_nids, | 2657 | .dac_nids = alc880_z71v_dac_nids, |
2639 | .dig_out_nid = ALC880_DIGOUT_NID, | 2658 | .dig_out_nid = ALC880_DIGOUT_NID, |
@@ -2644,7 +2663,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2644 | }, | 2663 | }, |
2645 | [ALC880_F1734] = { | 2664 | [ALC880_F1734] = { |
2646 | .mixers = { alc880_f1734_mixer }, | 2665 | .mixers = { alc880_f1734_mixer }, |
2647 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_f1734_init_verbs }, | 2666 | .init_verbs = { alc880_volume_init_verbs, |
2667 | alc880_pin_f1734_init_verbs }, | ||
2648 | .num_dacs = ARRAY_SIZE(alc880_f1734_dac_nids), | 2668 | .num_dacs = ARRAY_SIZE(alc880_f1734_dac_nids), |
2649 | .dac_nids = alc880_f1734_dac_nids, | 2669 | .dac_nids = alc880_f1734_dac_nids, |
2650 | .hp_nid = 0x02, | 2670 | .hp_nid = 0x02, |
@@ -2654,7 +2674,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2654 | }, | 2674 | }, |
2655 | [ALC880_ASUS] = { | 2675 | [ALC880_ASUS] = { |
2656 | .mixers = { alc880_asus_mixer }, | 2676 | .mixers = { alc880_asus_mixer }, |
2657 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_asus_init_verbs, | 2677 | .init_verbs = { alc880_volume_init_verbs, |
2678 | alc880_pin_asus_init_verbs, | ||
2658 | alc880_gpio1_init_verbs }, | 2679 | alc880_gpio1_init_verbs }, |
2659 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), | 2680 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), |
2660 | .dac_nids = alc880_asus_dac_nids, | 2681 | .dac_nids = alc880_asus_dac_nids, |
@@ -2665,7 +2686,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2665 | }, | 2686 | }, |
2666 | [ALC880_ASUS_DIG] = { | 2687 | [ALC880_ASUS_DIG] = { |
2667 | .mixers = { alc880_asus_mixer }, | 2688 | .mixers = { alc880_asus_mixer }, |
2668 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_asus_init_verbs, | 2689 | .init_verbs = { alc880_volume_init_verbs, |
2690 | alc880_pin_asus_init_verbs, | ||
2669 | alc880_gpio1_init_verbs }, | 2691 | alc880_gpio1_init_verbs }, |
2670 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), | 2692 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), |
2671 | .dac_nids = alc880_asus_dac_nids, | 2693 | .dac_nids = alc880_asus_dac_nids, |
@@ -2677,7 +2699,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2677 | }, | 2699 | }, |
2678 | [ALC880_ASUS_DIG2] = { | 2700 | [ALC880_ASUS_DIG2] = { |
2679 | .mixers = { alc880_asus_mixer }, | 2701 | .mixers = { alc880_asus_mixer }, |
2680 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_asus_init_verbs, | 2702 | .init_verbs = { alc880_volume_init_verbs, |
2703 | alc880_pin_asus_init_verbs, | ||
2681 | alc880_gpio2_init_verbs }, /* use GPIO2 */ | 2704 | alc880_gpio2_init_verbs }, /* use GPIO2 */ |
2682 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), | 2705 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), |
2683 | .dac_nids = alc880_asus_dac_nids, | 2706 | .dac_nids = alc880_asus_dac_nids, |
@@ -2689,7 +2712,8 @@ static struct alc_config_preset alc880_presets[] = { | |||
2689 | }, | 2712 | }, |
2690 | [ALC880_ASUS_W1V] = { | 2713 | [ALC880_ASUS_W1V] = { |
2691 | .mixers = { alc880_asus_mixer, alc880_asus_w1v_mixer }, | 2714 | .mixers = { alc880_asus_mixer, alc880_asus_w1v_mixer }, |
2692 | .init_verbs = { alc880_volume_init_verbs, alc880_pin_asus_init_verbs, | 2715 | .init_verbs = { alc880_volume_init_verbs, |
2716 | alc880_pin_asus_init_verbs, | ||
2693 | alc880_gpio1_init_verbs }, | 2717 | alc880_gpio1_init_verbs }, |
2694 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), | 2718 | .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids), |
2695 | .dac_nids = alc880_asus_dac_nids, | 2719 | .dac_nids = alc880_asus_dac_nids, |
@@ -2738,7 +2762,7 @@ static struct alc_config_preset alc880_presets[] = { | |||
2738 | .init_hook = alc880_uniwill_p53_hp_automute, | 2762 | .init_hook = alc880_uniwill_p53_hp_automute, |
2739 | }, | 2763 | }, |
2740 | [ALC880_FUJITSU] = { | 2764 | [ALC880_FUJITSU] = { |
2741 | .mixers = { alc880_fujitsu_mixer, | 2765 | .mixers = { alc880_fujitsu_mixer, |
2742 | alc880_pcbeep_mixer, }, | 2766 | alc880_pcbeep_mixer, }, |
2743 | .init_verbs = { alc880_volume_init_verbs, | 2767 | .init_verbs = { alc880_volume_init_verbs, |
2744 | alc880_uniwill_p53_init_verbs, | 2768 | alc880_uniwill_p53_init_verbs, |
@@ -2781,7 +2805,7 @@ static struct alc_config_preset alc880_presets[] = { | |||
2781 | .mixers = { alc880_lg_lw_mixer }, | 2805 | .mixers = { alc880_lg_lw_mixer }, |
2782 | .init_verbs = { alc880_volume_init_verbs, | 2806 | .init_verbs = { alc880_volume_init_verbs, |
2783 | alc880_lg_lw_init_verbs }, | 2807 | alc880_lg_lw_init_verbs }, |
2784 | .num_dacs = 1, | 2808 | .num_dacs = 1, |
2785 | .dac_nids = alc880_dac_nids, | 2809 | .dac_nids = alc880_dac_nids, |
2786 | .dig_out_nid = ALC880_DIGOUT_NID, | 2810 | .dig_out_nid = ALC880_DIGOUT_NID, |
2787 | .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes), | 2811 | .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes), |
@@ -2823,18 +2847,21 @@ static struct snd_kcontrol_new alc880_control_templates[] = { | |||
2823 | }; | 2847 | }; |
2824 | 2848 | ||
2825 | /* add dynamic controls */ | 2849 | /* add dynamic controls */ |
2826 | static int add_control(struct alc_spec *spec, int type, const char *name, unsigned long val) | 2850 | static int add_control(struct alc_spec *spec, int type, const char *name, |
2851 | unsigned long val) | ||
2827 | { | 2852 | { |
2828 | struct snd_kcontrol_new *knew; | 2853 | struct snd_kcontrol_new *knew; |
2829 | 2854 | ||
2830 | if (spec->num_kctl_used >= spec->num_kctl_alloc) { | 2855 | if (spec->num_kctl_used >= spec->num_kctl_alloc) { |
2831 | int num = spec->num_kctl_alloc + NUM_CONTROL_ALLOC; | 2856 | int num = spec->num_kctl_alloc + NUM_CONTROL_ALLOC; |
2832 | 2857 | ||
2833 | knew = kcalloc(num + 1, sizeof(*knew), GFP_KERNEL); /* array + terminator */ | 2858 | /* array + terminator */ |
2834 | if (! knew) | 2859 | knew = kcalloc(num + 1, sizeof(*knew), GFP_KERNEL); |
2860 | if (!knew) | ||
2835 | return -ENOMEM; | 2861 | return -ENOMEM; |
2836 | if (spec->kctl_alloc) { | 2862 | if (spec->kctl_alloc) { |
2837 | memcpy(knew, spec->kctl_alloc, sizeof(*knew) * spec->num_kctl_alloc); | 2863 | memcpy(knew, spec->kctl_alloc, |
2864 | sizeof(*knew) * spec->num_kctl_alloc); | ||
2838 | kfree(spec->kctl_alloc); | 2865 | kfree(spec->kctl_alloc); |
2839 | } | 2866 | } |
2840 | spec->kctl_alloc = knew; | 2867 | spec->kctl_alloc = knew; |
@@ -2844,7 +2871,7 @@ static int add_control(struct alc_spec *spec, int type, const char *name, unsign | |||
2844 | knew = &spec->kctl_alloc[spec->num_kctl_used]; | 2871 | knew = &spec->kctl_alloc[spec->num_kctl_used]; |
2845 | *knew = alc880_control_templates[type]; | 2872 | *knew = alc880_control_templates[type]; |
2846 | knew->name = kstrdup(name, GFP_KERNEL); | 2873 | knew->name = kstrdup(name, GFP_KERNEL); |
2847 | if (! knew->name) | 2874 | if (!knew->name) |
2848 | return -ENOMEM; | 2875 | return -ENOMEM; |
2849 | knew->private_value = val; | 2876 | knew->private_value = val; |
2850 | spec->num_kctl_used++; | 2877 | spec->num_kctl_used++; |
@@ -2864,7 +2891,8 @@ static int add_control(struct alc_spec *spec, int type, const char *name, unsign | |||
2864 | #define ALC880_PIN_CD_NID 0x1c | 2891 | #define ALC880_PIN_CD_NID 0x1c |
2865 | 2892 | ||
2866 | /* fill in the dac_nids table from the parsed pin configuration */ | 2893 | /* fill in the dac_nids table from the parsed pin configuration */ |
2867 | static int alc880_auto_fill_dac_nids(struct alc_spec *spec, const struct auto_pin_cfg *cfg) | 2894 | static int alc880_auto_fill_dac_nids(struct alc_spec *spec, |
2895 | const struct auto_pin_cfg *cfg) | ||
2868 | { | 2896 | { |
2869 | hda_nid_t nid; | 2897 | hda_nid_t nid; |
2870 | int assigned[4]; | 2898 | int assigned[4]; |
@@ -2889,8 +2917,9 @@ static int alc880_auto_fill_dac_nids(struct alc_spec *spec, const struct auto_pi | |||
2889 | continue; | 2917 | continue; |
2890 | /* search for an empty channel */ | 2918 | /* search for an empty channel */ |
2891 | for (j = 0; j < cfg->line_outs; j++) { | 2919 | for (j = 0; j < cfg->line_outs; j++) { |
2892 | if (! assigned[j]) { | 2920 | if (!assigned[j]) { |
2893 | spec->multiout.dac_nids[i] = alc880_idx_to_dac(j); | 2921 | spec->multiout.dac_nids[i] = |
2922 | alc880_idx_to_dac(j); | ||
2894 | assigned[j] = 1; | 2923 | assigned[j] = 1; |
2895 | break; | 2924 | break; |
2896 | } | 2925 | } |
@@ -2905,36 +2934,54 @@ static int alc880_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
2905 | const struct auto_pin_cfg *cfg) | 2934 | const struct auto_pin_cfg *cfg) |
2906 | { | 2935 | { |
2907 | char name[32]; | 2936 | char name[32]; |
2908 | static const char *chname[4] = { "Front", "Surround", NULL /*CLFE*/, "Side" }; | 2937 | static const char *chname[4] = { |
2938 | "Front", "Surround", NULL /*CLFE*/, "Side" | ||
2939 | }; | ||
2909 | hda_nid_t nid; | 2940 | hda_nid_t nid; |
2910 | int i, err; | 2941 | int i, err; |
2911 | 2942 | ||
2912 | for (i = 0; i < cfg->line_outs; i++) { | 2943 | for (i = 0; i < cfg->line_outs; i++) { |
2913 | if (! spec->multiout.dac_nids[i]) | 2944 | if (!spec->multiout.dac_nids[i]) |
2914 | continue; | 2945 | continue; |
2915 | nid = alc880_idx_to_mixer(alc880_dac_to_idx(spec->multiout.dac_nids[i])); | 2946 | nid = alc880_idx_to_mixer(alc880_dac_to_idx(spec->multiout.dac_nids[i])); |
2916 | if (i == 2) { | 2947 | if (i == 2) { |
2917 | /* Center/LFE */ | 2948 | /* Center/LFE */ |
2918 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, "Center Playback Volume", | 2949 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
2919 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT))) < 0) | 2950 | "Center Playback Volume", |
2951 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, | ||
2952 | HDA_OUTPUT)); | ||
2953 | if (err < 0) | ||
2920 | return err; | 2954 | return err; |
2921 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, "LFE Playback Volume", | 2955 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
2922 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT))) < 0) | 2956 | "LFE Playback Volume", |
2957 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, | ||
2958 | HDA_OUTPUT)); | ||
2959 | if (err < 0) | ||
2923 | return err; | 2960 | return err; |
2924 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, "Center Playback Switch", | 2961 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
2925 | HDA_COMPOSE_AMP_VAL(nid, 1, 2, HDA_INPUT))) < 0) | 2962 | "Center Playback Switch", |
2963 | HDA_COMPOSE_AMP_VAL(nid, 1, 2, | ||
2964 | HDA_INPUT)); | ||
2965 | if (err < 0) | ||
2926 | return err; | 2966 | return err; |
2927 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, "LFE Playback Switch", | 2967 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
2928 | HDA_COMPOSE_AMP_VAL(nid, 2, 2, HDA_INPUT))) < 0) | 2968 | "LFE Playback Switch", |
2969 | HDA_COMPOSE_AMP_VAL(nid, 2, 2, | ||
2970 | HDA_INPUT)); | ||
2971 | if (err < 0) | ||
2929 | return err; | 2972 | return err; |
2930 | } else { | 2973 | } else { |
2931 | sprintf(name, "%s Playback Volume", chname[i]); | 2974 | sprintf(name, "%s Playback Volume", chname[i]); |
2932 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 2975 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
2933 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 2976 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, |
2977 | HDA_OUTPUT)); | ||
2978 | if (err < 0) | ||
2934 | return err; | 2979 | return err; |
2935 | sprintf(name, "%s Playback Switch", chname[i]); | 2980 | sprintf(name, "%s Playback Switch", chname[i]); |
2936 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 2981 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
2937 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, HDA_INPUT))) < 0) | 2982 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, |
2983 | HDA_INPUT)); | ||
2984 | if (err < 0) | ||
2938 | return err; | 2985 | return err; |
2939 | } | 2986 | } |
2940 | } | 2987 | } |
@@ -2949,51 +2996,57 @@ static int alc880_auto_create_extra_out(struct alc_spec *spec, hda_nid_t pin, | |||
2949 | int err; | 2996 | int err; |
2950 | char name[32]; | 2997 | char name[32]; |
2951 | 2998 | ||
2952 | if (! pin) | 2999 | if (!pin) |
2953 | return 0; | 3000 | return 0; |
2954 | 3001 | ||
2955 | if (alc880_is_fixed_pin(pin)) { | 3002 | if (alc880_is_fixed_pin(pin)) { |
2956 | nid = alc880_idx_to_dac(alc880_fixed_pin_idx(pin)); | 3003 | nid = alc880_idx_to_dac(alc880_fixed_pin_idx(pin)); |
2957 | /* specify the DAC as the extra output */ | 3004 | /* specify the DAC as the extra output */ |
2958 | if (! spec->multiout.hp_nid) | 3005 | if (!spec->multiout.hp_nid) |
2959 | spec->multiout.hp_nid = nid; | 3006 | spec->multiout.hp_nid = nid; |
2960 | else | 3007 | else |
2961 | spec->multiout.extra_out_nid[0] = nid; | 3008 | spec->multiout.extra_out_nid[0] = nid; |
2962 | /* control HP volume/switch on the output mixer amp */ | 3009 | /* control HP volume/switch on the output mixer amp */ |
2963 | nid = alc880_idx_to_mixer(alc880_fixed_pin_idx(pin)); | 3010 | nid = alc880_idx_to_mixer(alc880_fixed_pin_idx(pin)); |
2964 | sprintf(name, "%s Playback Volume", pfx); | 3011 | sprintf(name, "%s Playback Volume", pfx); |
2965 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 3012 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
2966 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 3013 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT)); |
3014 | if (err < 0) | ||
2967 | return err; | 3015 | return err; |
2968 | sprintf(name, "%s Playback Switch", pfx); | 3016 | sprintf(name, "%s Playback Switch", pfx); |
2969 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 3017 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
2970 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, HDA_INPUT))) < 0) | 3018 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, HDA_INPUT)); |
3019 | if (err < 0) | ||
2971 | return err; | 3020 | return err; |
2972 | } else if (alc880_is_multi_pin(pin)) { | 3021 | } else if (alc880_is_multi_pin(pin)) { |
2973 | /* set manual connection */ | 3022 | /* set manual connection */ |
2974 | /* we have only a switch on HP-out PIN */ | 3023 | /* we have only a switch on HP-out PIN */ |
2975 | sprintf(name, "%s Playback Switch", pfx); | 3024 | sprintf(name, "%s Playback Switch", pfx); |
2976 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, | 3025 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, |
2977 | HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT))) < 0) | 3026 | HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT)); |
3027 | if (err < 0) | ||
2978 | return err; | 3028 | return err; |
2979 | } | 3029 | } |
2980 | return 0; | 3030 | return 0; |
2981 | } | 3031 | } |
2982 | 3032 | ||
2983 | /* create input playback/capture controls for the given pin */ | 3033 | /* create input playback/capture controls for the given pin */ |
2984 | static int new_analog_input(struct alc_spec *spec, hda_nid_t pin, const char *ctlname, | 3034 | static int new_analog_input(struct alc_spec *spec, hda_nid_t pin, |
3035 | const char *ctlname, | ||
2985 | int idx, hda_nid_t mix_nid) | 3036 | int idx, hda_nid_t mix_nid) |
2986 | { | 3037 | { |
2987 | char name[32]; | 3038 | char name[32]; |
2988 | int err; | 3039 | int err; |
2989 | 3040 | ||
2990 | sprintf(name, "%s Playback Volume", ctlname); | 3041 | sprintf(name, "%s Playback Volume", ctlname); |
2991 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 3042 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
2992 | HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT))) < 0) | 3043 | HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT)); |
3044 | if (err < 0) | ||
2993 | return err; | 3045 | return err; |
2994 | sprintf(name, "%s Playback Switch", ctlname); | 3046 | sprintf(name, "%s Playback Switch", ctlname); |
2995 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, | 3047 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, |
2996 | HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT))) < 0) | 3048 | HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT)); |
3049 | if (err < 0) | ||
2997 | return err; | 3050 | return err; |
2998 | return 0; | 3051 | return 0; |
2999 | } | 3052 | } |
@@ -3013,8 +3066,10 @@ static int alc880_auto_create_analog_input_ctls(struct alc_spec *spec, | |||
3013 | idx, 0x0b); | 3066 | idx, 0x0b); |
3014 | if (err < 0) | 3067 | if (err < 0) |
3015 | return err; | 3068 | return err; |
3016 | imux->items[imux->num_items].label = auto_pin_cfg_labels[i]; | 3069 | imux->items[imux->num_items].label = |
3017 | imux->items[imux->num_items].index = alc880_input_pin_idx(cfg->input_pins[i]); | 3070 | auto_pin_cfg_labels[i]; |
3071 | imux->items[imux->num_items].index = | ||
3072 | alc880_input_pin_idx(cfg->input_pins[i]); | ||
3018 | imux->num_items++; | 3073 | imux->num_items++; |
3019 | } | 3074 | } |
3020 | } | 3075 | } |
@@ -3026,8 +3081,10 @@ static void alc880_auto_set_output_and_unmute(struct hda_codec *codec, | |||
3026 | int dac_idx) | 3081 | int dac_idx) |
3027 | { | 3082 | { |
3028 | /* set as output */ | 3083 | /* set as output */ |
3029 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | 3084 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, |
3030 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | 3085 | pin_type); |
3086 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
3087 | AMP_OUT_UNMUTE); | ||
3031 | /* need the manual connection? */ | 3088 | /* need the manual connection? */ |
3032 | if (alc880_is_multi_pin(nid)) { | 3089 | if (alc880_is_multi_pin(nid)) { |
3033 | struct alc_spec *spec = codec->spec; | 3090 | struct alc_spec *spec = codec->spec; |
@@ -3071,37 +3128,52 @@ static void alc880_auto_init_analog_input(struct hda_codec *codec) | |||
3071 | for (i = 0; i < AUTO_PIN_LAST; i++) { | 3128 | for (i = 0; i < AUTO_PIN_LAST; i++) { |
3072 | hda_nid_t nid = spec->autocfg.input_pins[i]; | 3129 | hda_nid_t nid = spec->autocfg.input_pins[i]; |
3073 | if (alc880_is_input_pin(nid)) { | 3130 | if (alc880_is_input_pin(nid)) { |
3074 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | 3131 | snd_hda_codec_write(codec, nid, 0, |
3075 | i <= AUTO_PIN_FRONT_MIC ? PIN_VREF80 : PIN_IN); | 3132 | AC_VERB_SET_PIN_WIDGET_CONTROL, |
3133 | i <= AUTO_PIN_FRONT_MIC ? | ||
3134 | PIN_VREF80 : PIN_IN); | ||
3076 | if (nid != ALC880_PIN_CD_NID) | 3135 | if (nid != ALC880_PIN_CD_NID) |
3077 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | 3136 | snd_hda_codec_write(codec, nid, 0, |
3137 | AC_VERB_SET_AMP_GAIN_MUTE, | ||
3078 | AMP_OUT_MUTE); | 3138 | AMP_OUT_MUTE); |
3079 | } | 3139 | } |
3080 | } | 3140 | } |
3081 | } | 3141 | } |
3082 | 3142 | ||
3083 | /* parse the BIOS configuration and set up the alc_spec */ | 3143 | /* parse the BIOS configuration and set up the alc_spec */ |
3084 | /* return 1 if successful, 0 if the proper config is not found, or a negative error code */ | 3144 | /* return 1 if successful, 0 if the proper config is not found, |
3145 | * or a negative error code | ||
3146 | */ | ||
3085 | static int alc880_parse_auto_config(struct hda_codec *codec) | 3147 | static int alc880_parse_auto_config(struct hda_codec *codec) |
3086 | { | 3148 | { |
3087 | struct alc_spec *spec = codec->spec; | 3149 | struct alc_spec *spec = codec->spec; |
3088 | int err; | 3150 | int err; |
3089 | static hda_nid_t alc880_ignore[] = { 0x1d, 0 }; | 3151 | static hda_nid_t alc880_ignore[] = { 0x1d, 0 }; |
3090 | 3152 | ||
3091 | if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 3153 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
3092 | alc880_ignore)) < 0) | 3154 | alc880_ignore); |
3155 | if (err < 0) | ||
3093 | return err; | 3156 | return err; |
3094 | if (! spec->autocfg.line_outs) | 3157 | if (!spec->autocfg.line_outs) |
3095 | return 0; /* can't find valid BIOS pin config */ | 3158 | return 0; /* can't find valid BIOS pin config */ |
3096 | 3159 | ||
3097 | if ((err = alc880_auto_fill_dac_nids(spec, &spec->autocfg)) < 0 || | 3160 | err = alc880_auto_fill_dac_nids(spec, &spec->autocfg); |
3098 | (err = alc880_auto_create_multi_out_ctls(spec, &spec->autocfg)) < 0 || | 3161 | if (err < 0) |
3099 | (err = alc880_auto_create_extra_out(spec, | 3162 | return err; |
3100 | spec->autocfg.speaker_pins[0], | 3163 | err = alc880_auto_create_multi_out_ctls(spec, &spec->autocfg); |
3101 | "Speaker")) < 0 || | 3164 | if (err < 0) |
3102 | (err = alc880_auto_create_extra_out(spec, spec->autocfg.hp_pins[0], | 3165 | return err; |
3103 | "Headphone")) < 0 || | 3166 | err = alc880_auto_create_extra_out(spec, |
3104 | (err = alc880_auto_create_analog_input_ctls(spec, &spec->autocfg)) < 0) | 3167 | spec->autocfg.speaker_pins[0], |
3168 | "Speaker"); | ||
3169 | if (err < 0) | ||
3170 | return err; | ||
3171 | err = alc880_auto_create_extra_out(spec, spec->autocfg.hp_pins[0], | ||
3172 | "Headphone"); | ||
3173 | if (err < 0) | ||
3174 | return err; | ||
3175 | err = alc880_auto_create_analog_input_ctls(spec, &spec->autocfg); | ||
3176 | if (err < 0) | ||
3105 | return err; | 3177 | return err; |
3106 | 3178 | ||
3107 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 3179 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |
@@ -3161,7 +3233,7 @@ static int patch_alc880(struct hda_codec *codec) | |||
3161 | if (err < 0) { | 3233 | if (err < 0) { |
3162 | alc_free(codec); | 3234 | alc_free(codec); |
3163 | return err; | 3235 | return err; |
3164 | } else if (! err) { | 3236 | } else if (!err) { |
3165 | printk(KERN_INFO | 3237 | printk(KERN_INFO |
3166 | "hda_codec: Cannot set up configuration " | 3238 | "hda_codec: Cannot set up configuration " |
3167 | "from BIOS. Using 3-stack mode...\n"); | 3239 | "from BIOS. Using 3-stack mode...\n"); |
@@ -3180,14 +3252,16 @@ static int patch_alc880(struct hda_codec *codec) | |||
3180 | spec->stream_digital_playback = &alc880_pcm_digital_playback; | 3252 | spec->stream_digital_playback = &alc880_pcm_digital_playback; |
3181 | spec->stream_digital_capture = &alc880_pcm_digital_capture; | 3253 | spec->stream_digital_capture = &alc880_pcm_digital_capture; |
3182 | 3254 | ||
3183 | if (! spec->adc_nids && spec->input_mux) { | 3255 | if (!spec->adc_nids && spec->input_mux) { |
3184 | /* check whether NID 0x07 is valid */ | 3256 | /* check whether NID 0x07 is valid */ |
3185 | unsigned int wcap = get_wcaps(codec, alc880_adc_nids[0]); | 3257 | unsigned int wcap = get_wcaps(codec, alc880_adc_nids[0]); |
3186 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; /* get type */ | 3258 | /* get type */ |
3259 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; | ||
3187 | if (wcap != AC_WID_AUD_IN) { | 3260 | if (wcap != AC_WID_AUD_IN) { |
3188 | spec->adc_nids = alc880_adc_nids_alt; | 3261 | spec->adc_nids = alc880_adc_nids_alt; |
3189 | spec->num_adc_nids = ARRAY_SIZE(alc880_adc_nids_alt); | 3262 | spec->num_adc_nids = ARRAY_SIZE(alc880_adc_nids_alt); |
3190 | spec->mixers[spec->num_mixers] = alc880_capture_alt_mixer; | 3263 | spec->mixers[spec->num_mixers] = |
3264 | alc880_capture_alt_mixer; | ||
3191 | spec->num_mixers++; | 3265 | spec->num_mixers++; |
3192 | } else { | 3266 | } else { |
3193 | spec->adc_nids = alc880_adc_nids; | 3267 | spec->adc_nids = alc880_adc_nids; |
@@ -3329,7 +3403,7 @@ static struct snd_kcontrol_new alc260_base_output_mixer[] = { | |||
3329 | HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0a, 1, 0x0, HDA_OUTPUT), | 3403 | HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0a, 1, 0x0, HDA_OUTPUT), |
3330 | HDA_BIND_MUTE_MONO("Mono Playback Switch", 0x0a, 1, 2, HDA_INPUT), | 3404 | HDA_BIND_MUTE_MONO("Mono Playback Switch", 0x0a, 1, 2, HDA_INPUT), |
3331 | { } /* end */ | 3405 | { } /* end */ |
3332 | }; | 3406 | }; |
3333 | 3407 | ||
3334 | static struct snd_kcontrol_new alc260_input_mixer[] = { | 3408 | static struct snd_kcontrol_new alc260_input_mixer[] = { |
3335 | HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT), | 3409 | HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT), |
@@ -3545,7 +3619,9 @@ static struct hda_verb alc260_init_verbs[] = { | |||
3545 | {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | 3619 | {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
3546 | /* unmute LINE-2 out pin */ | 3620 | /* unmute LINE-2 out pin */ |
3547 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | 3621 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
3548 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & Line In 2 = 0x03 */ | 3622 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & |
3623 | * Line In 2 = 0x03 | ||
3624 | */ | ||
3549 | /* mute CD */ | 3625 | /* mute CD */ |
3550 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, | 3626 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, |
3551 | /* mute Line In */ | 3627 | /* mute Line In */ |
@@ -3593,7 +3669,9 @@ static struct hda_verb alc260_hp_init_verbs[] = { | |||
3593 | {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000}, | 3669 | {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000}, |
3594 | /* mute pin widget amp left and right (no gain on this amp) */ | 3670 | /* mute pin widget amp left and right (no gain on this amp) */ |
3595 | {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000}, | 3671 | {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000}, |
3596 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & Line In 2 = 0x03 */ | 3672 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & |
3673 | * Line In 2 = 0x03 | ||
3674 | */ | ||
3597 | /* unmute CD */ | 3675 | /* unmute CD */ |
3598 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))}, | 3676 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))}, |
3599 | /* unmute Line In */ | 3677 | /* unmute Line In */ |
@@ -3641,7 +3719,9 @@ static struct hda_verb alc260_hp_3013_init_verbs[] = { | |||
3641 | {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000}, | 3719 | {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000}, |
3642 | /* mute pin widget amp left and right (no gain on this amp) */ | 3720 | /* mute pin widget amp left and right (no gain on this amp) */ |
3643 | {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000}, | 3721 | {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000}, |
3644 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & Line In 2 = 0x03 */ | 3722 | /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 & |
3723 | * Line In 2 = 0x03 | ||
3724 | */ | ||
3645 | /* unmute CD */ | 3725 | /* unmute CD */ |
3646 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))}, | 3726 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))}, |
3647 | /* unmute Line In */ | 3727 | /* unmute Line In */ |
@@ -3791,7 +3871,9 @@ static struct hda_verb alc260_acer_init_verbs[] = { | |||
3791 | {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, | 3871 | {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, |
3792 | {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, | 3872 | {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, |
3793 | 3873 | ||
3794 | /* Unmute Line-out pin widget amp left and right (no equiv mixer ctrl) */ | 3874 | /* Unmute Line-out pin widget amp left and right |
3875 | * (no equiv mixer ctrl) | ||
3876 | */ | ||
3795 | {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | 3877 | {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
3796 | /* Unmute mono pin widget amp output (no equiv mixer ctrl) */ | 3878 | /* Unmute mono pin widget amp output (no equiv mixer ctrl) */ |
3797 | {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, | 3879 | {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
@@ -4106,10 +4188,12 @@ static int alc260_add_playback_controls(struct alc_spec *spec, hda_nid_t nid, | |||
4106 | return 0; /* N/A */ | 4188 | return 0; /* N/A */ |
4107 | 4189 | ||
4108 | snprintf(name, sizeof(name), "%s Playback Volume", pfx); | 4190 | snprintf(name, sizeof(name), "%s Playback Volume", pfx); |
4109 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, vol_val)) < 0) | 4191 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, vol_val); |
4192 | if (err < 0) | ||
4110 | return err; | 4193 | return err; |
4111 | snprintf(name, sizeof(name), "%s Playback Switch", pfx); | 4194 | snprintf(name, sizeof(name), "%s Playback Switch", pfx); |
4112 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, sw_val)) < 0) | 4195 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, sw_val); |
4196 | if (err < 0) | ||
4113 | return err; | 4197 | return err; |
4114 | return 1; | 4198 | return 1; |
4115 | } | 4199 | } |
@@ -4145,7 +4229,7 @@ static int alc260_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
4145 | if (err < 0) | 4229 | if (err < 0) |
4146 | return err; | 4230 | return err; |
4147 | } | 4231 | } |
4148 | return 0; | 4232 | return 0; |
4149 | } | 4233 | } |
4150 | 4234 | ||
4151 | /* create playback/capture controls for input pins */ | 4235 | /* create playback/capture controls for input pins */ |
@@ -4159,20 +4243,24 @@ static int alc260_auto_create_analog_input_ctls(struct alc_spec *spec, | |||
4159 | if (cfg->input_pins[i] >= 0x12) { | 4243 | if (cfg->input_pins[i] >= 0x12) { |
4160 | idx = cfg->input_pins[i] - 0x12; | 4244 | idx = cfg->input_pins[i] - 0x12; |
4161 | err = new_analog_input(spec, cfg->input_pins[i], | 4245 | err = new_analog_input(spec, cfg->input_pins[i], |
4162 | auto_pin_cfg_labels[i], idx, 0x07); | 4246 | auto_pin_cfg_labels[i], idx, |
4247 | 0x07); | ||
4163 | if (err < 0) | 4248 | if (err < 0) |
4164 | return err; | 4249 | return err; |
4165 | imux->items[imux->num_items].label = auto_pin_cfg_labels[i]; | 4250 | imux->items[imux->num_items].label = |
4251 | auto_pin_cfg_labels[i]; | ||
4166 | imux->items[imux->num_items].index = idx; | 4252 | imux->items[imux->num_items].index = idx; |
4167 | imux->num_items++; | 4253 | imux->num_items++; |
4168 | } | 4254 | } |
4169 | if ((cfg->input_pins[i] >= 0x0f) && (cfg->input_pins[i] <= 0x10)){ | 4255 | if (cfg->input_pins[i] >= 0x0f && cfg->input_pins[i] <= 0x10){ |
4170 | idx = cfg->input_pins[i] - 0x09; | 4256 | idx = cfg->input_pins[i] - 0x09; |
4171 | err = new_analog_input(spec, cfg->input_pins[i], | 4257 | err = new_analog_input(spec, cfg->input_pins[i], |
4172 | auto_pin_cfg_labels[i], idx, 0x07); | 4258 | auto_pin_cfg_labels[i], idx, |
4259 | 0x07); | ||
4173 | if (err < 0) | 4260 | if (err < 0) |
4174 | return err; | 4261 | return err; |
4175 | imux->items[imux->num_items].label = auto_pin_cfg_labels[i]; | 4262 | imux->items[imux->num_items].label = |
4263 | auto_pin_cfg_labels[i]; | ||
4176 | imux->items[imux->num_items].index = idx; | 4264 | imux->items[imux->num_items].index = idx; |
4177 | imux->num_items++; | 4265 | imux->num_items++; |
4178 | } | 4266 | } |
@@ -4185,14 +4273,15 @@ static void alc260_auto_set_output_and_unmute(struct hda_codec *codec, | |||
4185 | int sel_idx) | 4273 | int sel_idx) |
4186 | { | 4274 | { |
4187 | /* set as output */ | 4275 | /* set as output */ |
4188 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | 4276 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, |
4189 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | 4277 | pin_type); |
4278 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
4279 | AMP_OUT_UNMUTE); | ||
4190 | /* need the manual connection? */ | 4280 | /* need the manual connection? */ |
4191 | if (nid >= 0x12) { | 4281 | if (nid >= 0x12) { |
4192 | int idx = nid - 0x12; | 4282 | int idx = nid - 0x12; |
4193 | snd_hda_codec_write(codec, idx + 0x0b, 0, | 4283 | snd_hda_codec_write(codec, idx + 0x0b, 0, |
4194 | AC_VERB_SET_CONNECT_SEL, sel_idx); | 4284 | AC_VERB_SET_CONNECT_SEL, sel_idx); |
4195 | |||
4196 | } | 4285 | } |
4197 | } | 4286 | } |
4198 | 4287 | ||
@@ -4202,7 +4291,7 @@ static void alc260_auto_init_multi_out(struct hda_codec *codec) | |||
4202 | hda_nid_t nid; | 4291 | hda_nid_t nid; |
4203 | 4292 | ||
4204 | alc_subsystem_id(codec, 0x10, 0x15, 0x0f); | 4293 | alc_subsystem_id(codec, 0x10, 0x15, 0x0f); |
4205 | nid = spec->autocfg.line_out_pins[0]; | 4294 | nid = spec->autocfg.line_out_pins[0]; |
4206 | if (nid) | 4295 | if (nid) |
4207 | alc260_auto_set_output_and_unmute(codec, nid, PIN_OUT, 0); | 4296 | alc260_auto_set_output_and_unmute(codec, nid, PIN_OUT, 0); |
4208 | 4297 | ||
@@ -4213,7 +4302,7 @@ static void alc260_auto_init_multi_out(struct hda_codec *codec) | |||
4213 | nid = spec->autocfg.hp_pins[0]; | 4302 | nid = spec->autocfg.hp_pins[0]; |
4214 | if (nid) | 4303 | if (nid) |
4215 | alc260_auto_set_output_and_unmute(codec, nid, PIN_OUT, 0); | 4304 | alc260_auto_set_output_and_unmute(codec, nid, PIN_OUT, 0); |
4216 | } | 4305 | } |
4217 | 4306 | ||
4218 | #define ALC260_PIN_CD_NID 0x16 | 4307 | #define ALC260_PIN_CD_NID 0x16 |
4219 | static void alc260_auto_init_analog_input(struct hda_codec *codec) | 4308 | static void alc260_auto_init_analog_input(struct hda_codec *codec) |
@@ -4224,10 +4313,13 @@ static void alc260_auto_init_analog_input(struct hda_codec *codec) | |||
4224 | for (i = 0; i < AUTO_PIN_LAST; i++) { | 4313 | for (i = 0; i < AUTO_PIN_LAST; i++) { |
4225 | hda_nid_t nid = spec->autocfg.input_pins[i]; | 4314 | hda_nid_t nid = spec->autocfg.input_pins[i]; |
4226 | if (nid >= 0x12) { | 4315 | if (nid >= 0x12) { |
4227 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | 4316 | snd_hda_codec_write(codec, nid, 0, |
4228 | i <= AUTO_PIN_FRONT_MIC ? PIN_VREF80 : PIN_IN); | 4317 | AC_VERB_SET_PIN_WIDGET_CONTROL, |
4318 | i <= AUTO_PIN_FRONT_MIC ? | ||
4319 | PIN_VREF80 : PIN_IN); | ||
4229 | if (nid != ALC260_PIN_CD_NID) | 4320 | if (nid != ALC260_PIN_CD_NID) |
4230 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | 4321 | snd_hda_codec_write(codec, nid, 0, |
4322 | AC_VERB_SET_AMP_GAIN_MUTE, | ||
4231 | AMP_OUT_MUTE); | 4323 | AMP_OUT_MUTE); |
4232 | } | 4324 | } |
4233 | } | 4325 | } |
@@ -4247,8 +4339,8 @@ static struct hda_verb alc260_volume_init_verbs[] = { | |||
4247 | 4339 | ||
4248 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 4340 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
4249 | * mixer widget | 4341 | * mixer widget |
4250 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 4342 | * Note: PASD motherboards uses the Line In 2 as the input for |
4251 | * mic (mic 2) | 4343 | * front panel mic (mic 2) |
4252 | */ | 4344 | */ |
4253 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 4345 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
4254 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 4346 | {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -4283,14 +4375,17 @@ static int alc260_parse_auto_config(struct hda_codec *codec) | |||
4283 | int err; | 4375 | int err; |
4284 | static hda_nid_t alc260_ignore[] = { 0x17, 0 }; | 4376 | static hda_nid_t alc260_ignore[] = { 0x17, 0 }; |
4285 | 4377 | ||
4286 | if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 4378 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
4287 | alc260_ignore)) < 0) | 4379 | alc260_ignore); |
4380 | if (err < 0) | ||
4288 | return err; | 4381 | return err; |
4289 | if ((err = alc260_auto_create_multi_out_ctls(spec, &spec->autocfg)) < 0) | 4382 | err = alc260_auto_create_multi_out_ctls(spec, &spec->autocfg); |
4383 | if (err < 0) | ||
4290 | return err; | 4384 | return err; |
4291 | if (! spec->kctl_alloc) | 4385 | if (!spec->kctl_alloc) |
4292 | return 0; /* can't find valid BIOS pin config */ | 4386 | return 0; /* can't find valid BIOS pin config */ |
4293 | if ((err = alc260_auto_create_analog_input_ctls(spec, &spec->autocfg)) < 0) | 4387 | err = alc260_auto_create_analog_input_ctls(spec, &spec->autocfg); |
4388 | if (err < 0) | ||
4294 | return err; | 4389 | return err; |
4295 | 4390 | ||
4296 | spec->multiout.max_channels = 2; | 4391 | spec->multiout.max_channels = 2; |
@@ -4506,7 +4601,7 @@ static int patch_alc260(struct hda_codec *codec) | |||
4506 | if (err < 0) { | 4601 | if (err < 0) { |
4507 | alc_free(codec); | 4602 | alc_free(codec); |
4508 | return err; | 4603 | return err; |
4509 | } else if (! err) { | 4604 | } else if (!err) { |
4510 | printk(KERN_INFO | 4605 | printk(KERN_INFO |
4511 | "hda_codec: Cannot set up configuration " | 4606 | "hda_codec: Cannot set up configuration " |
4512 | "from BIOS. Using base mode...\n"); | 4607 | "from BIOS. Using base mode...\n"); |
@@ -4575,7 +4670,8 @@ static struct hda_input_mux alc882_capture_source = { | |||
4575 | #define alc882_mux_enum_info alc_mux_enum_info | 4670 | #define alc882_mux_enum_info alc_mux_enum_info |
4576 | #define alc882_mux_enum_get alc_mux_enum_get | 4671 | #define alc882_mux_enum_get alc_mux_enum_get |
4577 | 4672 | ||
4578 | static int alc882_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) | 4673 | static int alc882_mux_enum_put(struct snd_kcontrol *kcontrol, |
4674 | struct snd_ctl_elem_value *ucontrol) | ||
4579 | { | 4675 | { |
4580 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); | 4676 | struct hda_codec *codec = snd_kcontrol_chip(kcontrol); |
4581 | struct alc_spec *spec = codec->spec; | 4677 | struct alc_spec *spec = codec->spec; |
@@ -4589,7 +4685,7 @@ static int alc882_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_ele | |||
4589 | idx = ucontrol->value.enumerated.item[0]; | 4685 | idx = ucontrol->value.enumerated.item[0]; |
4590 | if (idx >= imux->num_items) | 4686 | if (idx >= imux->num_items) |
4591 | idx = imux->num_items - 1; | 4687 | idx = imux->num_items - 1; |
4592 | if (*cur_val == idx && ! codec->in_resume) | 4688 | if (*cur_val == idx && !codec->in_resume) |
4593 | return 0; | 4689 | return 0; |
4594 | for (i = 0; i < imux->num_items; i++) { | 4690 | for (i = 0; i < imux->num_items; i++) { |
4595 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; | 4691 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; |
@@ -4752,7 +4848,7 @@ static struct hda_verb alc882_eapd_verbs[] = { | |||
4752 | /* change to EAPD mode */ | 4848 | /* change to EAPD mode */ |
4753 | {0x20, AC_VERB_SET_COEF_INDEX, 0x07}, | 4849 | {0x20, AC_VERB_SET_COEF_INDEX, 0x07}, |
4754 | {0x20, AC_VERB_SET_PROC_COEF, 0x3060}, | 4850 | {0x20, AC_VERB_SET_PROC_COEF, 0x3060}, |
4755 | { } | 4851 | { } |
4756 | }; | 4852 | }; |
4757 | 4853 | ||
4758 | /* Mac Pro test */ | 4854 | /* Mac Pro test */ |
@@ -4817,6 +4913,7 @@ static struct hda_verb alc882_macpro_init_verbs[] = { | |||
4817 | 4913 | ||
4818 | { } | 4914 | { } |
4819 | }; | 4915 | }; |
4916 | |||
4820 | static void alc882_gpio_mute(struct hda_codec *codec, int pin, int muted) | 4917 | static void alc882_gpio_mute(struct hda_codec *codec, int pin, int muted) |
4821 | { | 4918 | { |
4822 | unsigned int gpiostate, gpiomask, gpiodir; | 4919 | unsigned int gpiostate, gpiomask, gpiodir; |
@@ -4865,8 +4962,8 @@ static struct hda_verb alc882_auto_init_verbs[] = { | |||
4865 | 4962 | ||
4866 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 4963 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
4867 | * mixer widget | 4964 | * mixer widget |
4868 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 4965 | * Note: PASD motherboards uses the Line In 2 as the input for |
4869 | * mic (mic 2) | 4966 | * front panel mic (mic 2) |
4870 | */ | 4967 | */ |
4871 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 4968 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
4872 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 4969 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -5044,15 +5141,17 @@ static void alc882_auto_set_output_and_unmute(struct hda_codec *codec, | |||
5044 | { | 5141 | { |
5045 | /* set as output */ | 5142 | /* set as output */ |
5046 | struct alc_spec *spec = codec->spec; | 5143 | struct alc_spec *spec = codec->spec; |
5047 | int idx; | 5144 | int idx; |
5048 | 5145 | ||
5049 | if (spec->multiout.dac_nids[dac_idx] == 0x25) | 5146 | if (spec->multiout.dac_nids[dac_idx] == 0x25) |
5050 | idx = 4; | 5147 | idx = 4; |
5051 | else | 5148 | else |
5052 | idx = spec->multiout.dac_nids[dac_idx] - 2; | 5149 | idx = spec->multiout.dac_nids[dac_idx] - 2; |
5053 | 5150 | ||
5054 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | 5151 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, |
5055 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | 5152 | pin_type); |
5153 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
5154 | AMP_OUT_UNMUTE); | ||
5056 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); | 5155 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx); |
5057 | 5156 | ||
5058 | } | 5157 | } |
@@ -5064,9 +5163,10 @@ static void alc882_auto_init_multi_out(struct hda_codec *codec) | |||
5064 | 5163 | ||
5065 | alc_subsystem_id(codec, 0x15, 0x1b, 0x14); | 5164 | alc_subsystem_id(codec, 0x15, 0x1b, 0x14); |
5066 | for (i = 0; i <= HDA_SIDE; i++) { | 5165 | for (i = 0; i <= HDA_SIDE; i++) { |
5067 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; | 5166 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; |
5068 | if (nid) | 5167 | if (nid) |
5069 | alc882_auto_set_output_and_unmute(codec, nid, PIN_OUT, i); | 5168 | alc882_auto_set_output_and_unmute(codec, nid, PIN_OUT, |
5169 | i); | ||
5070 | } | 5170 | } |
5071 | } | 5171 | } |
5072 | 5172 | ||
@@ -5077,7 +5177,8 @@ static void alc882_auto_init_hp_out(struct hda_codec *codec) | |||
5077 | 5177 | ||
5078 | pin = spec->autocfg.hp_pins[0]; | 5178 | pin = spec->autocfg.hp_pins[0]; |
5079 | if (pin) /* connect to front */ | 5179 | if (pin) /* connect to front */ |
5080 | alc882_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); /* use dac 0 */ | 5180 | /* use dac 0 */ |
5181 | alc882_auto_set_output_and_unmute(codec, pin, PIN_HP, 0); | ||
5081 | } | 5182 | } |
5082 | 5183 | ||
5083 | #define alc882_is_input_pin(nid) alc880_is_input_pin(nid) | 5184 | #define alc882_is_input_pin(nid) alc880_is_input_pin(nid) |
@@ -5091,10 +5192,13 @@ static void alc882_auto_init_analog_input(struct hda_codec *codec) | |||
5091 | for (i = 0; i < AUTO_PIN_LAST; i++) { | 5192 | for (i = 0; i < AUTO_PIN_LAST; i++) { |
5092 | hda_nid_t nid = spec->autocfg.input_pins[i]; | 5193 | hda_nid_t nid = spec->autocfg.input_pins[i]; |
5093 | if (alc882_is_input_pin(nid)) { | 5194 | if (alc882_is_input_pin(nid)) { |
5094 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | 5195 | snd_hda_codec_write(codec, nid, 0, |
5095 | i <= AUTO_PIN_FRONT_MIC ? PIN_VREF80 : PIN_IN); | 5196 | AC_VERB_SET_PIN_WIDGET_CONTROL, |
5197 | i <= AUTO_PIN_FRONT_MIC ? | ||
5198 | PIN_VREF80 : PIN_IN); | ||
5096 | if (nid != ALC882_PIN_CD_NID) | 5199 | if (nid != ALC882_PIN_CD_NID) |
5097 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, | 5200 | snd_hda_codec_write(codec, nid, 0, |
5201 | AC_VERB_SET_AMP_GAIN_MUTE, | ||
5098 | AMP_OUT_MUTE); | 5202 | AMP_OUT_MUTE); |
5099 | } | 5203 | } |
5100 | } | 5204 | } |
@@ -5156,7 +5260,7 @@ static int patch_alc882(struct hda_codec *codec) | |||
5156 | if (err < 0) { | 5260 | if (err < 0) { |
5157 | alc_free(codec); | 5261 | alc_free(codec); |
5158 | return err; | 5262 | return err; |
5159 | } else if (! err) { | 5263 | } else if (!err) { |
5160 | printk(KERN_INFO | 5264 | printk(KERN_INFO |
5161 | "hda_codec: Cannot set up configuration " | 5265 | "hda_codec: Cannot set up configuration " |
5162 | "from BIOS. Using base mode...\n"); | 5266 | "from BIOS. Using base mode...\n"); |
@@ -5180,14 +5284,16 @@ static int patch_alc882(struct hda_codec *codec) | |||
5180 | spec->stream_digital_playback = &alc882_pcm_digital_playback; | 5284 | spec->stream_digital_playback = &alc882_pcm_digital_playback; |
5181 | spec->stream_digital_capture = &alc882_pcm_digital_capture; | 5285 | spec->stream_digital_capture = &alc882_pcm_digital_capture; |
5182 | 5286 | ||
5183 | if (! spec->adc_nids && spec->input_mux) { | 5287 | if (!spec->adc_nids && spec->input_mux) { |
5184 | /* check whether NID 0x07 is valid */ | 5288 | /* check whether NID 0x07 is valid */ |
5185 | unsigned int wcap = get_wcaps(codec, 0x07); | 5289 | unsigned int wcap = get_wcaps(codec, 0x07); |
5186 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; /* get type */ | 5290 | /* get type */ |
5291 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; | ||
5187 | if (wcap != AC_WID_AUD_IN) { | 5292 | if (wcap != AC_WID_AUD_IN) { |
5188 | spec->adc_nids = alc882_adc_nids_alt; | 5293 | spec->adc_nids = alc882_adc_nids_alt; |
5189 | spec->num_adc_nids = ARRAY_SIZE(alc882_adc_nids_alt); | 5294 | spec->num_adc_nids = ARRAY_SIZE(alc882_adc_nids_alt); |
5190 | spec->mixers[spec->num_mixers] = alc882_capture_alt_mixer; | 5295 | spec->mixers[spec->num_mixers] = |
5296 | alc882_capture_alt_mixer; | ||
5191 | spec->num_mixers++; | 5297 | spec->num_mixers++; |
5192 | } else { | 5298 | } else { |
5193 | spec->adc_nids = alc882_adc_nids; | 5299 | spec->adc_nids = alc882_adc_nids; |
@@ -5227,6 +5333,7 @@ static hda_nid_t alc883_adc_nids[2] = { | |||
5227 | /* ADC1-2 */ | 5333 | /* ADC1-2 */ |
5228 | 0x08, 0x09, | 5334 | 0x08, 0x09, |
5229 | }; | 5335 | }; |
5336 | |||
5230 | /* input MUX */ | 5337 | /* input MUX */ |
5231 | /* FIXME: should be a matrix-type input source selection */ | 5338 | /* FIXME: should be a matrix-type input source selection */ |
5232 | 5339 | ||
@@ -5266,7 +5373,7 @@ static int alc883_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
5266 | idx = ucontrol->value.enumerated.item[0]; | 5373 | idx = ucontrol->value.enumerated.item[0]; |
5267 | if (idx >= imux->num_items) | 5374 | if (idx >= imux->num_items) |
5268 | idx = imux->num_items - 1; | 5375 | idx = imux->num_items - 1; |
5269 | if (*cur_val == idx && ! codec->in_resume) | 5376 | if (*cur_val == idx && !codec->in_resume) |
5270 | return 0; | 5377 | return 0; |
5271 | for (i = 0; i < imux->num_items; i++) { | 5378 | for (i = 0; i < imux->num_items; i++) { |
5272 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; | 5379 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; |
@@ -5276,6 +5383,7 @@ static int alc883_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
5276 | *cur_val = idx; | 5383 | *cur_val = idx; |
5277 | return 1; | 5384 | return 1; |
5278 | } | 5385 | } |
5386 | |||
5279 | /* | 5387 | /* |
5280 | * 2ch mode | 5388 | * 2ch mode |
5281 | */ | 5389 | */ |
@@ -5528,7 +5636,7 @@ static struct snd_kcontrol_new alc883_tagra_mixer[] = { | |||
5528 | .put = alc883_mux_enum_put, | 5636 | .put = alc883_mux_enum_put, |
5529 | }, | 5637 | }, |
5530 | { } /* end */ | 5638 | { } /* end */ |
5531 | }; | 5639 | }; |
5532 | 5640 | ||
5533 | static struct snd_kcontrol_new alc883_tagra_2ch_mixer[] = { | 5641 | static struct snd_kcontrol_new alc883_tagra_2ch_mixer[] = { |
5534 | HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), | 5642 | HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), |
@@ -5553,7 +5661,7 @@ static struct snd_kcontrol_new alc883_tagra_2ch_mixer[] = { | |||
5553 | .put = alc883_mux_enum_put, | 5661 | .put = alc883_mux_enum_put, |
5554 | }, | 5662 | }, |
5555 | { } /* end */ | 5663 | { } /* end */ |
5556 | }; | 5664 | }; |
5557 | 5665 | ||
5558 | static struct snd_kcontrol_new alc883_lenovo_101e_2ch_mixer[] = { | 5666 | static struct snd_kcontrol_new alc883_lenovo_101e_2ch_mixer[] = { |
5559 | HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), | 5667 | HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), |
@@ -5576,7 +5684,7 @@ static struct snd_kcontrol_new alc883_lenovo_101e_2ch_mixer[] = { | |||
5576 | .put = alc883_mux_enum_put, | 5684 | .put = alc883_mux_enum_put, |
5577 | }, | 5685 | }, |
5578 | { } /* end */ | 5686 | { } /* end */ |
5579 | }; | 5687 | }; |
5580 | 5688 | ||
5581 | static struct snd_kcontrol_new alc883_chmode_mixer[] = { | 5689 | static struct snd_kcontrol_new alc883_chmode_mixer[] = { |
5582 | { | 5690 | { |
@@ -5678,9 +5786,9 @@ static struct hda_verb alc883_tagra_verbs[] = { | |||
5678 | {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */ | 5786 | {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */ |
5679 | 5787 | ||
5680 | {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN}, | 5788 | {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN}, |
5681 | {0x01, AC_VERB_SET_GPIO_MASK, 0x03}, | 5789 | {0x01, AC_VERB_SET_GPIO_MASK, 0x03}, |
5682 | {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x03}, | 5790 | {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x03}, |
5683 | {0x01, AC_VERB_SET_GPIO_DATA, 0x03}, | 5791 | {0x01, AC_VERB_SET_GPIO_DATA, 0x03}, |
5684 | 5792 | ||
5685 | { } /* end */ | 5793 | { } /* end */ |
5686 | }; | 5794 | }; |
@@ -5696,14 +5804,17 @@ static struct hda_verb alc883_lenovo_101e_verbs[] = { | |||
5696 | static void alc883_tagra_automute(struct hda_codec *codec) | 5804 | static void alc883_tagra_automute(struct hda_codec *codec) |
5697 | { | 5805 | { |
5698 | unsigned int present; | 5806 | unsigned int present; |
5807 | unsigned char bits; | ||
5699 | 5808 | ||
5700 | present = snd_hda_codec_read(codec, 0x14, 0, | 5809 | present = snd_hda_codec_read(codec, 0x14, 0, |
5701 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 5810 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
5811 | bits = present ? 0x80 : 0; | ||
5702 | snd_hda_codec_amp_update(codec, 0x1b, 0, HDA_OUTPUT, 0, | 5812 | snd_hda_codec_amp_update(codec, 0x1b, 0, HDA_OUTPUT, 0, |
5703 | 0x80, present ? 0x80 : 0); | 5813 | 0x80, bits); |
5704 | snd_hda_codec_amp_update(codec, 0x1b, 1, HDA_OUTPUT, 0, | 5814 | snd_hda_codec_amp_update(codec, 0x1b, 1, HDA_OUTPUT, 0, |
5705 | 0x80, present ? 0x80 : 0); | 5815 | 0x80, bits); |
5706 | snd_hda_codec_write(codec, 1, 0, AC_VERB_SET_GPIO_DATA, present ? 1 : 3); | 5816 | snd_hda_codec_write(codec, 1, 0, AC_VERB_SET_GPIO_DATA, |
5817 | present ? 1 : 3); | ||
5707 | } | 5818 | } |
5708 | 5819 | ||
5709 | static void alc883_tagra_unsol_event(struct hda_codec *codec, unsigned int res) | 5820 | static void alc883_tagra_unsol_event(struct hda_codec *codec, unsigned int res) |
@@ -5715,31 +5826,33 @@ static void alc883_tagra_unsol_event(struct hda_codec *codec, unsigned int res) | |||
5715 | static void alc883_lenovo_101e_ispeaker_automute(struct hda_codec *codec) | 5826 | static void alc883_lenovo_101e_ispeaker_automute(struct hda_codec *codec) |
5716 | { | 5827 | { |
5717 | unsigned int present; | 5828 | unsigned int present; |
5829 | unsigned char bits; | ||
5718 | 5830 | ||
5719 | present = snd_hda_codec_read(codec, 0x14, 0, | 5831 | present = snd_hda_codec_read(codec, 0x14, 0, |
5720 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 5832 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
5721 | 5833 | bits = present ? 0x80 : 0; | |
5722 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, | 5834 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, |
5723 | 0x80, present ? 0x80 : 0); | 5835 | 0x80, bits); |
5724 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, | 5836 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, |
5725 | 0x80, present ? 0x80 : 0); | 5837 | 0x80, bits); |
5726 | } | 5838 | } |
5727 | 5839 | ||
5728 | static void alc883_lenovo_101e_all_automute(struct hda_codec *codec) | 5840 | static void alc883_lenovo_101e_all_automute(struct hda_codec *codec) |
5729 | { | 5841 | { |
5730 | unsigned int present; | 5842 | unsigned int present; |
5843 | unsigned char bits; | ||
5731 | 5844 | ||
5732 | present = snd_hda_codec_read(codec, 0x1b, 0, | 5845 | present = snd_hda_codec_read(codec, 0x1b, 0, |
5733 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 5846 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
5734 | 5847 | bits = present ? 0x80 : 0; | |
5735 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, | 5848 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, |
5736 | 0x80, present ? 0x80 : 0); | 5849 | 0x80, bits); |
5737 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, | 5850 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, |
5738 | 0x80, present ? 0x80 : 0); | 5851 | 0x80, bits); |
5739 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, | 5852 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, |
5740 | 0x80, present ? 0x80 : 0); | 5853 | 0x80, bits); |
5741 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, | 5854 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, |
5742 | 0x80, present ? 0x80 : 0); | 5855 | 0x80, bits); |
5743 | } | 5856 | } |
5744 | 5857 | ||
5745 | static void alc883_lenovo_101e_unsol_event(struct hda_codec *codec, | 5858 | static void alc883_lenovo_101e_unsol_event(struct hda_codec *codec, |
@@ -5765,8 +5878,8 @@ static struct hda_verb alc883_auto_init_verbs[] = { | |||
5765 | 5878 | ||
5766 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 5879 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
5767 | * mixer widget | 5880 | * mixer widget |
5768 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 5881 | * Note: PASD motherboards uses the Line In 2 as the input for |
5769 | * mic (mic 2) | 5882 | * front panel mic (mic 2) |
5770 | */ | 5883 | */ |
5771 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 5884 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
5772 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 5885 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -5802,13 +5915,13 @@ static struct hda_verb alc883_auto_init_verbs[] = { | |||
5802 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 5915 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
5803 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 5916 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
5804 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 5917 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
5805 | //{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | 5918 | /* {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, */ |
5806 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, | 5919 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, |
5807 | /* Input mixer2 */ | 5920 | /* Input mixer2 */ |
5808 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 5921 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
5809 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 5922 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
5810 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 5923 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
5811 | //{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | 5924 | /* {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, */ |
5812 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, | 5925 | {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)}, |
5813 | 5926 | ||
5814 | { } | 5927 | { } |
@@ -5913,7 +6026,7 @@ static struct alc_config_preset alc883_presets[] = { | |||
5913 | .channel_mode = alc883_3ST_6ch_modes, | 6026 | .channel_mode = alc883_3ST_6ch_modes, |
5914 | .need_dac_fix = 1, | 6027 | .need_dac_fix = 1, |
5915 | .input_mux = &alc883_capture_source, | 6028 | .input_mux = &alc883_capture_source, |
5916 | }, | 6029 | }, |
5917 | [ALC883_3ST_6ch] = { | 6030 | [ALC883_3ST_6ch] = { |
5918 | .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer }, | 6031 | .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer }, |
5919 | .init_verbs = { alc883_init_verbs }, | 6032 | .init_verbs = { alc883_init_verbs }, |
@@ -5925,7 +6038,7 @@ static struct alc_config_preset alc883_presets[] = { | |||
5925 | .channel_mode = alc883_3ST_6ch_modes, | 6038 | .channel_mode = alc883_3ST_6ch_modes, |
5926 | .need_dac_fix = 1, | 6039 | .need_dac_fix = 1, |
5927 | .input_mux = &alc883_capture_source, | 6040 | .input_mux = &alc883_capture_source, |
5928 | }, | 6041 | }, |
5929 | [ALC883_6ST_DIG] = { | 6042 | [ALC883_6ST_DIG] = { |
5930 | .mixers = { alc883_base_mixer, alc883_chmode_mixer }, | 6043 | .mixers = { alc883_base_mixer, alc883_chmode_mixer }, |
5931 | .init_verbs = { alc883_init_verbs }, | 6044 | .init_verbs = { alc883_init_verbs }, |
@@ -6048,8 +6161,8 @@ static void alc883_auto_set_output_and_unmute(struct hda_codec *codec, | |||
6048 | { | 6161 | { |
6049 | /* set as output */ | 6162 | /* set as output */ |
6050 | struct alc_spec *spec = codec->spec; | 6163 | struct alc_spec *spec = codec->spec; |
6051 | int idx; | 6164 | int idx; |
6052 | 6165 | ||
6053 | if (spec->multiout.dac_nids[dac_idx] == 0x25) | 6166 | if (spec->multiout.dac_nids[dac_idx] == 0x25) |
6054 | idx = 4; | 6167 | idx = 4; |
6055 | else | 6168 | else |
@@ -6070,9 +6183,10 @@ static void alc883_auto_init_multi_out(struct hda_codec *codec) | |||
6070 | 6183 | ||
6071 | alc_subsystem_id(codec, 0x15, 0x1b, 0x14); | 6184 | alc_subsystem_id(codec, 0x15, 0x1b, 0x14); |
6072 | for (i = 0; i <= HDA_SIDE; i++) { | 6185 | for (i = 0; i <= HDA_SIDE; i++) { |
6073 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; | 6186 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; |
6074 | if (nid) | 6187 | if (nid) |
6075 | alc883_auto_set_output_and_unmute(codec, nid, PIN_OUT, i); | 6188 | alc883_auto_set_output_and_unmute(codec, nid, PIN_OUT, |
6189 | i); | ||
6076 | } | 6190 | } |
6077 | } | 6191 | } |
6078 | 6192 | ||
@@ -6160,7 +6274,7 @@ static int patch_alc883(struct hda_codec *codec) | |||
6160 | if (err < 0) { | 6274 | if (err < 0) { |
6161 | alc_free(codec); | 6275 | alc_free(codec); |
6162 | return err; | 6276 | return err; |
6163 | } else if (! err) { | 6277 | } else if (!err) { |
6164 | printk(KERN_INFO | 6278 | printk(KERN_INFO |
6165 | "hda_codec: Cannot set up configuration " | 6279 | "hda_codec: Cannot set up configuration " |
6166 | "from BIOS. Using base mode...\n"); | 6280 | "from BIOS. Using base mode...\n"); |
@@ -6179,7 +6293,7 @@ static int patch_alc883(struct hda_codec *codec) | |||
6179 | spec->stream_digital_playback = &alc883_pcm_digital_playback; | 6293 | spec->stream_digital_playback = &alc883_pcm_digital_playback; |
6180 | spec->stream_digital_capture = &alc883_pcm_digital_capture; | 6294 | spec->stream_digital_capture = &alc883_pcm_digital_capture; |
6181 | 6295 | ||
6182 | if (! spec->adc_nids && spec->input_mux) { | 6296 | if (!spec->adc_nids && spec->input_mux) { |
6183 | spec->adc_nids = alc883_adc_nids; | 6297 | spec->adc_nids = alc883_adc_nids; |
6184 | spec->num_adc_nids = ARRAY_SIZE(alc883_adc_nids); | 6298 | spec->num_adc_nids = ARRAY_SIZE(alc883_adc_nids); |
6185 | } | 6299 | } |
@@ -6316,8 +6430,8 @@ static struct hda_verb alc262_init_verbs[] = { | |||
6316 | 6430 | ||
6317 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 6431 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
6318 | * mixer widget | 6432 | * mixer widget |
6319 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 6433 | * Note: PASD motherboards uses the Line In 2 as the input for |
6320 | * mic (mic 2) | 6434 | * front panel mic (mic 2) |
6321 | */ | 6435 | */ |
6322 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 6436 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
6323 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 6437 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -6374,7 +6488,7 @@ static struct hda_verb alc262_init_verbs[] = { | |||
6374 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))}, | 6488 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))}, |
6375 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))}, | 6489 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))}, |
6376 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))}, | 6490 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))}, |
6377 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))}, | 6491 | {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))}, |
6378 | 6492 | ||
6379 | { } | 6493 | { } |
6380 | }; | 6494 | }; |
@@ -6401,7 +6515,7 @@ static void alc262_hippo_automute(struct hda_codec *codec, int force) | |||
6401 | struct alc_spec *spec = codec->spec; | 6515 | struct alc_spec *spec = codec->spec; |
6402 | unsigned int mute; | 6516 | unsigned int mute; |
6403 | 6517 | ||
6404 | if (force || ! spec->sense_updated) { | 6518 | if (force || !spec->sense_updated) { |
6405 | unsigned int present; | 6519 | unsigned int present; |
6406 | /* need to execute and sync at first */ | 6520 | /* need to execute and sync at first */ |
6407 | snd_hda_codec_read(codec, 0x15, 0, AC_VERB_SET_PIN_SENSE, 0); | 6521 | snd_hda_codec_read(codec, 0x15, 0, AC_VERB_SET_PIN_SENSE, 0); |
@@ -6441,7 +6555,7 @@ static void alc262_hippo1_automute(struct hda_codec *codec, int force) | |||
6441 | struct alc_spec *spec = codec->spec; | 6555 | struct alc_spec *spec = codec->spec; |
6442 | unsigned int mute; | 6556 | unsigned int mute; |
6443 | 6557 | ||
6444 | if (force || ! spec->sense_updated) { | 6558 | if (force || !spec->sense_updated) { |
6445 | unsigned int present; | 6559 | unsigned int present; |
6446 | /* need to execute and sync at first */ | 6560 | /* need to execute and sync at first */ |
6447 | snd_hda_codec_read(codec, 0x1b, 0, AC_VERB_SET_PIN_SENSE, 0); | 6561 | snd_hda_codec_read(codec, 0x1b, 0, AC_VERB_SET_PIN_SENSE, 0); |
@@ -6514,7 +6628,7 @@ static void alc262_fujitsu_automute(struct hda_codec *codec, int force) | |||
6514 | struct alc_spec *spec = codec->spec; | 6628 | struct alc_spec *spec = codec->spec; |
6515 | unsigned int mute; | 6629 | unsigned int mute; |
6516 | 6630 | ||
6517 | if (force || ! spec->sense_updated) { | 6631 | if (force || !spec->sense_updated) { |
6518 | unsigned int present; | 6632 | unsigned int present; |
6519 | /* need to execute and sync at first */ | 6633 | /* need to execute and sync at first */ |
6520 | snd_hda_codec_read(codec, 0x14, 0, AC_VERB_SET_PIN_SENSE, 0); | 6634 | snd_hda_codec_read(codec, 0x14, 0, AC_VERB_SET_PIN_SENSE, 0); |
@@ -6619,7 +6733,8 @@ static struct hda_verb alc262_EAPD_verbs[] = { | |||
6619 | }; | 6733 | }; |
6620 | 6734 | ||
6621 | /* add playback controls from the parsed DAC table */ | 6735 | /* add playback controls from the parsed DAC table */ |
6622 | static int alc262_auto_create_multi_out_ctls(struct alc_spec *spec, const struct auto_pin_cfg *cfg) | 6736 | static int alc262_auto_create_multi_out_ctls(struct alc_spec *spec, |
6737 | const struct auto_pin_cfg *cfg) | ||
6623 | { | 6738 | { |
6624 | hda_nid_t nid; | 6739 | hda_nid_t nid; |
6625 | int err; | 6740 | int err; |
@@ -6630,26 +6745,39 @@ static int alc262_auto_create_multi_out_ctls(struct alc_spec *spec, const struct | |||
6630 | 6745 | ||
6631 | nid = cfg->line_out_pins[0]; | 6746 | nid = cfg->line_out_pins[0]; |
6632 | if (nid) { | 6747 | if (nid) { |
6633 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, "Front Playback Volume", | 6748 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
6634 | HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT))) < 0) | 6749 | "Front Playback Volume", |
6750 | HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT)); | ||
6751 | if (err < 0) | ||
6635 | return err; | 6752 | return err; |
6636 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Front Playback Switch", | 6753 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
6637 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 6754 | "Front Playback Switch", |
6755 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT)); | ||
6756 | if (err < 0) | ||
6638 | return err; | 6757 | return err; |
6639 | } | 6758 | } |
6640 | 6759 | ||
6641 | nid = cfg->speaker_pins[0]; | 6760 | nid = cfg->speaker_pins[0]; |
6642 | if (nid) { | 6761 | if (nid) { |
6643 | if (nid == 0x16) { | 6762 | if (nid == 0x16) { |
6644 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, "Speaker Playback Volume", | 6763 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
6645 | HDA_COMPOSE_AMP_VAL(0x0e, 2, 0, HDA_OUTPUT))) < 0) | 6764 | "Speaker Playback Volume", |
6765 | HDA_COMPOSE_AMP_VAL(0x0e, 2, 0, | ||
6766 | HDA_OUTPUT)); | ||
6767 | if (err < 0) | ||
6646 | return err; | 6768 | return err; |
6647 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Speaker Playback Switch", | 6769 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
6648 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT))) < 0) | 6770 | "Speaker Playback Switch", |
6771 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, | ||
6772 | HDA_OUTPUT)); | ||
6773 | if (err < 0) | ||
6649 | return err; | 6774 | return err; |
6650 | } else { | 6775 | } else { |
6651 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Speaker Playback Switch", | 6776 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
6652 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 6777 | "Speaker Playback Switch", |
6778 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, | ||
6779 | HDA_OUTPUT)); | ||
6780 | if (err < 0) | ||
6653 | return err; | 6781 | return err; |
6654 | } | 6782 | } |
6655 | } | 6783 | } |
@@ -6657,23 +6785,33 @@ static int alc262_auto_create_multi_out_ctls(struct alc_spec *spec, const struct | |||
6657 | if (nid) { | 6785 | if (nid) { |
6658 | /* spec->multiout.hp_nid = 2; */ | 6786 | /* spec->multiout.hp_nid = 2; */ |
6659 | if (nid == 0x16) { | 6787 | if (nid == 0x16) { |
6660 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, "Headphone Playback Volume", | 6788 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
6661 | HDA_COMPOSE_AMP_VAL(0x0e, 2, 0, HDA_OUTPUT))) < 0) | 6789 | "Headphone Playback Volume", |
6790 | HDA_COMPOSE_AMP_VAL(0x0e, 2, 0, | ||
6791 | HDA_OUTPUT)); | ||
6792 | if (err < 0) | ||
6662 | return err; | 6793 | return err; |
6663 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Headphone Playback Switch", | 6794 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
6664 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT))) < 0) | 6795 | "Headphone Playback Switch", |
6796 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, | ||
6797 | HDA_OUTPUT)); | ||
6798 | if (err < 0) | ||
6665 | return err; | 6799 | return err; |
6666 | } else { | 6800 | } else { |
6667 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Headphone Playback Switch", | 6801 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
6668 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 6802 | "Headphone Playback Switch", |
6803 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, | ||
6804 | HDA_OUTPUT)); | ||
6805 | if (err < 0) | ||
6669 | return err; | 6806 | return err; |
6670 | } | 6807 | } |
6671 | } | 6808 | } |
6672 | return 0; | 6809 | return 0; |
6673 | } | 6810 | } |
6674 | 6811 | ||
6675 | /* identical with ALC880 */ | 6812 | /* identical with ALC880 */ |
6676 | #define alc262_auto_create_analog_input_ctls alc880_auto_create_analog_input_ctls | 6813 | #define alc262_auto_create_analog_input_ctls \ |
6814 | alc880_auto_create_analog_input_ctls | ||
6677 | 6815 | ||
6678 | /* | 6816 | /* |
6679 | * generic initialization of ADC, input mixers and output mixers | 6817 | * generic initialization of ADC, input mixers and output mixers |
@@ -6691,8 +6829,8 @@ static struct hda_verb alc262_volume_init_verbs[] = { | |||
6691 | 6829 | ||
6692 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 6830 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
6693 | * mixer widget | 6831 | * mixer widget |
6694 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 6832 | * Note: PASD motherboards uses the Line In 2 as the input for |
6695 | * mic (mic 2) | 6833 | * front panel mic (mic 2) |
6696 | */ | 6834 | */ |
6697 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 6835 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
6698 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 6836 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -6752,8 +6890,8 @@ static struct hda_verb alc262_HP_BPC_init_verbs[] = { | |||
6752 | 6890 | ||
6753 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback | 6891 | /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback |
6754 | * mixer widget | 6892 | * mixer widget |
6755 | * Note: PASD motherboards uses the Line In 2 as the input for front panel | 6893 | * Note: PASD motherboards uses the Line In 2 as the input for |
6756 | * mic (mic 2) | 6894 | * front panel mic (mic 2) |
6757 | */ | 6895 | */ |
6758 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ | 6896 | /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */ |
6759 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 6897 | {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
@@ -6935,13 +7073,17 @@ static int alc262_parse_auto_config(struct hda_codec *codec) | |||
6935 | int err; | 7073 | int err; |
6936 | static hda_nid_t alc262_ignore[] = { 0x1d, 0 }; | 7074 | static hda_nid_t alc262_ignore[] = { 0x1d, 0 }; |
6937 | 7075 | ||
6938 | if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 7076 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
6939 | alc262_ignore)) < 0) | 7077 | alc262_ignore); |
7078 | if (err < 0) | ||
6940 | return err; | 7079 | return err; |
6941 | if (! spec->autocfg.line_outs) | 7080 | if (!spec->autocfg.line_outs) |
6942 | return 0; /* can't find valid BIOS pin config */ | 7081 | return 0; /* can't find valid BIOS pin config */ |
6943 | if ((err = alc262_auto_create_multi_out_ctls(spec, &spec->autocfg)) < 0 || | 7082 | err = alc262_auto_create_multi_out_ctls(spec, &spec->autocfg); |
6944 | (err = alc262_auto_create_analog_input_ctls(spec, &spec->autocfg)) < 0) | 7083 | if (err < 0) |
7084 | return err; | ||
7085 | err = alc262_auto_create_analog_input_ctls(spec, &spec->autocfg); | ||
7086 | if (err < 0) | ||
6945 | return err; | 7087 | return err; |
6946 | 7088 | ||
6947 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 7089 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |
@@ -7065,7 +7207,7 @@ static struct alc_config_preset alc262_presets[] = { | |||
7065 | .num_channel_mode = ARRAY_SIZE(alc262_modes), | 7207 | .num_channel_mode = ARRAY_SIZE(alc262_modes), |
7066 | .channel_mode = alc262_modes, | 7208 | .channel_mode = alc262_modes, |
7067 | .input_mux = &alc262_HP_capture_source, | 7209 | .input_mux = &alc262_HP_capture_source, |
7068 | }, | 7210 | }, |
7069 | [ALC262_HP_BPC_D7000_WF] = { | 7211 | [ALC262_HP_BPC_D7000_WF] = { |
7070 | .mixers = { alc262_HP_BPC_WildWest_mixer }, | 7212 | .mixers = { alc262_HP_BPC_WildWest_mixer }, |
7071 | .init_verbs = { alc262_HP_BPC_WildWest_init_verbs }, | 7213 | .init_verbs = { alc262_HP_BPC_WildWest_init_verbs }, |
@@ -7075,7 +7217,7 @@ static struct alc_config_preset alc262_presets[] = { | |||
7075 | .num_channel_mode = ARRAY_SIZE(alc262_modes), | 7217 | .num_channel_mode = ARRAY_SIZE(alc262_modes), |
7076 | .channel_mode = alc262_modes, | 7218 | .channel_mode = alc262_modes, |
7077 | .input_mux = &alc262_HP_capture_source, | 7219 | .input_mux = &alc262_HP_capture_source, |
7078 | }, | 7220 | }, |
7079 | [ALC262_HP_BPC_D7000_WL] = { | 7221 | [ALC262_HP_BPC_D7000_WL] = { |
7080 | .mixers = { alc262_HP_BPC_WildWest_mixer, | 7222 | .mixers = { alc262_HP_BPC_WildWest_mixer, |
7081 | alc262_HP_BPC_WildWest_option_mixer }, | 7223 | alc262_HP_BPC_WildWest_option_mixer }, |
@@ -7086,7 +7228,7 @@ static struct alc_config_preset alc262_presets[] = { | |||
7086 | .num_channel_mode = ARRAY_SIZE(alc262_modes), | 7228 | .num_channel_mode = ARRAY_SIZE(alc262_modes), |
7087 | .channel_mode = alc262_modes, | 7229 | .channel_mode = alc262_modes, |
7088 | .input_mux = &alc262_HP_capture_source, | 7230 | .input_mux = &alc262_HP_capture_source, |
7089 | }, | 7231 | }, |
7090 | [ALC262_BENQ_ED8] = { | 7232 | [ALC262_BENQ_ED8] = { |
7091 | .mixers = { alc262_base_mixer }, | 7233 | .mixers = { alc262_base_mixer }, |
7092 | .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs }, | 7234 | .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs }, |
@@ -7096,7 +7238,7 @@ static struct alc_config_preset alc262_presets[] = { | |||
7096 | .num_channel_mode = ARRAY_SIZE(alc262_modes), | 7238 | .num_channel_mode = ARRAY_SIZE(alc262_modes), |
7097 | .channel_mode = alc262_modes, | 7239 | .channel_mode = alc262_modes, |
7098 | .input_mux = &alc262_capture_source, | 7240 | .input_mux = &alc262_capture_source, |
7099 | }, | 7241 | }, |
7100 | }; | 7242 | }; |
7101 | 7243 | ||
7102 | static int patch_alc262(struct hda_codec *codec) | 7244 | static int patch_alc262(struct hda_codec *codec) |
@@ -7111,7 +7253,9 @@ static int patch_alc262(struct hda_codec *codec) | |||
7111 | 7253 | ||
7112 | codec->spec = spec; | 7254 | codec->spec = spec; |
7113 | #if 0 | 7255 | #if 0 |
7114 | /* pshou 07/11/05 set a zero PCM sample to DAC when FIFO is under-run */ | 7256 | /* pshou 07/11/05 set a zero PCM sample to DAC when FIFO is |
7257 | * under-run | ||
7258 | */ | ||
7115 | { | 7259 | { |
7116 | int tmp; | 7260 | int tmp; |
7117 | snd_hda_codec_write(codec, 0x1a, 0, AC_VERB_SET_COEF_INDEX, 7); | 7261 | snd_hda_codec_write(codec, 0x1a, 0, AC_VERB_SET_COEF_INDEX, 7); |
@@ -7137,7 +7281,7 @@ static int patch_alc262(struct hda_codec *codec) | |||
7137 | if (err < 0) { | 7281 | if (err < 0) { |
7138 | alc_free(codec); | 7282 | alc_free(codec); |
7139 | return err; | 7283 | return err; |
7140 | } else if (! err) { | 7284 | } else if (!err) { |
7141 | printk(KERN_INFO | 7285 | printk(KERN_INFO |
7142 | "hda_codec: Cannot set up configuration " | 7286 | "hda_codec: Cannot set up configuration " |
7143 | "from BIOS. Using base mode...\n"); | 7287 | "from BIOS. Using base mode...\n"); |
@@ -7156,15 +7300,17 @@ static int patch_alc262(struct hda_codec *codec) | |||
7156 | spec->stream_digital_playback = &alc262_pcm_digital_playback; | 7300 | spec->stream_digital_playback = &alc262_pcm_digital_playback; |
7157 | spec->stream_digital_capture = &alc262_pcm_digital_capture; | 7301 | spec->stream_digital_capture = &alc262_pcm_digital_capture; |
7158 | 7302 | ||
7159 | if (! spec->adc_nids && spec->input_mux) { | 7303 | if (!spec->adc_nids && spec->input_mux) { |
7160 | /* check whether NID 0x07 is valid */ | 7304 | /* check whether NID 0x07 is valid */ |
7161 | unsigned int wcap = get_wcaps(codec, 0x07); | 7305 | unsigned int wcap = get_wcaps(codec, 0x07); |
7162 | 7306 | ||
7163 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; /* get type */ | 7307 | /* get type */ |
7308 | wcap = (wcap & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT; | ||
7164 | if (wcap != AC_WID_AUD_IN) { | 7309 | if (wcap != AC_WID_AUD_IN) { |
7165 | spec->adc_nids = alc262_adc_nids_alt; | 7310 | spec->adc_nids = alc262_adc_nids_alt; |
7166 | spec->num_adc_nids = ARRAY_SIZE(alc262_adc_nids_alt); | 7311 | spec->num_adc_nids = ARRAY_SIZE(alc262_adc_nids_alt); |
7167 | spec->mixers[spec->num_mixers] = alc262_capture_alt_mixer; | 7312 | spec->mixers[spec->num_mixers] = |
7313 | alc262_capture_alt_mixer; | ||
7168 | spec->num_mixers++; | 7314 | spec->num_mixers++; |
7169 | } else { | 7315 | } else { |
7170 | spec->adc_nids = alc262_adc_nids; | 7316 | spec->adc_nids = alc262_adc_nids; |
@@ -7192,7 +7338,9 @@ static int patch_alc262(struct hda_codec *codec) | |||
7192 | static struct hda_verb alc861_threestack_ch2_init[] = { | 7338 | static struct hda_verb alc861_threestack_ch2_init[] = { |
7193 | /* set pin widget 1Ah (line in) for input */ | 7339 | /* set pin widget 1Ah (line in) for input */ |
7194 | { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 }, | 7340 | { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 }, |
7195 | /* set pin widget 18h (mic1/2) for input, for mic also enable the vref */ | 7341 | /* set pin widget 18h (mic1/2) for input, for mic also enable |
7342 | * the vref | ||
7343 | */ | ||
7196 | { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, | 7344 | { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, |
7197 | 7345 | ||
7198 | { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, | 7346 | { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, |
@@ -7249,7 +7397,9 @@ static struct hda_channel_mode alc861_uniwill_m31_modes[2] = { | |||
7249 | static struct hda_verb alc861_asus_ch2_init[] = { | 7397 | static struct hda_verb alc861_asus_ch2_init[] = { |
7250 | /* set pin widget 1Ah (line in) for input */ | 7398 | /* set pin widget 1Ah (line in) for input */ |
7251 | { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 }, | 7399 | { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 }, |
7252 | /* set pin widget 18h (mic1/2) for input, for mic also enable the vref */ | 7400 | /* set pin widget 18h (mic1/2) for input, for mic also enable |
7401 | * the vref | ||
7402 | */ | ||
7253 | { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, | 7403 | { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, |
7254 | 7404 | ||
7255 | { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, | 7405 | { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, |
@@ -7304,7 +7454,7 @@ static struct snd_kcontrol_new alc861_base_mixer[] = { | |||
7304 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), | 7454 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), |
7305 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), | 7455 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), |
7306 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), | 7456 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), |
7307 | 7457 | ||
7308 | /* Capture mixer control */ | 7458 | /* Capture mixer control */ |
7309 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), | 7459 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), |
7310 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), | 7460 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), |
@@ -7338,7 +7488,7 @@ static struct snd_kcontrol_new alc861_3ST_mixer[] = { | |||
7338 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), | 7488 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), |
7339 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), | 7489 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), |
7340 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), | 7490 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), |
7341 | 7491 | ||
7342 | /* Capture mixer control */ | 7492 | /* Capture mixer control */ |
7343 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), | 7493 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), |
7344 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), | 7494 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), |
@@ -7380,7 +7530,7 @@ static struct snd_kcontrol_new alc861_toshiba_mixer[] = { | |||
7380 | }, | 7530 | }, |
7381 | 7531 | ||
7382 | { } /* end */ | 7532 | { } /* end */ |
7383 | }; | 7533 | }; |
7384 | 7534 | ||
7385 | static struct snd_kcontrol_new alc861_uniwill_m31_mixer[] = { | 7535 | static struct snd_kcontrol_new alc861_uniwill_m31_mixer[] = { |
7386 | /* output mixer control */ | 7536 | /* output mixer control */ |
@@ -7401,7 +7551,7 @@ static struct snd_kcontrol_new alc861_uniwill_m31_mixer[] = { | |||
7401 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), | 7551 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), |
7402 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), | 7552 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), |
7403 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), | 7553 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT), |
7404 | 7554 | ||
7405 | /* Capture mixer control */ | 7555 | /* Capture mixer control */ |
7406 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), | 7556 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), |
7407 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), | 7557 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), |
@@ -7422,7 +7572,7 @@ static struct snd_kcontrol_new alc861_uniwill_m31_mixer[] = { | |||
7422 | .private_value = ARRAY_SIZE(alc861_uniwill_m31_modes), | 7572 | .private_value = ARRAY_SIZE(alc861_uniwill_m31_modes), |
7423 | }, | 7573 | }, |
7424 | { } /* end */ | 7574 | { } /* end */ |
7425 | }; | 7575 | }; |
7426 | 7576 | ||
7427 | static struct snd_kcontrol_new alc861_asus_mixer[] = { | 7577 | static struct snd_kcontrol_new alc861_asus_mixer[] = { |
7428 | /* output mixer control */ | 7578 | /* output mixer control */ |
@@ -7442,8 +7592,8 @@ static struct snd_kcontrol_new alc861_asus_mixer[] = { | |||
7442 | HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT), | 7592 | HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT), |
7443 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), | 7593 | HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT), |
7444 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), | 7594 | HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT), |
7445 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_OUTPUT), /* was HDA_INPUT (why?) */ | 7595 | HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_OUTPUT), |
7446 | 7596 | ||
7447 | /* Capture mixer control */ | 7597 | /* Capture mixer control */ |
7448 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), | 7598 | HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT), |
7449 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), | 7599 | HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT), |
@@ -7527,7 +7677,7 @@ static struct hda_verb alc861_base_init_verbs[] = { | |||
7527 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7677 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7528 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7678 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7529 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7679 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7530 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, //Output 0~12 step | 7680 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */ |
7531 | 7681 | ||
7532 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7682 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7533 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7683 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
@@ -7537,7 +7687,8 @@ static struct hda_verb alc861_base_init_verbs[] = { | |||
7537 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7687 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7538 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7688 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7539 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7689 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7540 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, // hp used DAC 3 (Front) | 7690 | /* hp used DAC 3 (Front) */ |
7691 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | ||
7541 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7692 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7542 | 7693 | ||
7543 | { } | 7694 | { } |
@@ -7588,7 +7739,7 @@ static struct hda_verb alc861_threestack_init_verbs[] = { | |||
7588 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7739 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7589 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7740 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7590 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7741 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7591 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, //Output 0~12 step | 7742 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */ |
7592 | 7743 | ||
7593 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7744 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7594 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7745 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
@@ -7598,7 +7749,8 @@ static struct hda_verb alc861_threestack_init_verbs[] = { | |||
7598 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7749 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7599 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7750 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7600 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7751 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7601 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, // hp used DAC 3 (Front) | 7752 | /* hp used DAC 3 (Front) */ |
7753 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | ||
7602 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7754 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7603 | { } | 7755 | { } |
7604 | }; | 7756 | }; |
@@ -7617,7 +7769,8 @@ static struct hda_verb alc861_uniwill_m31_init_verbs[] = { | |||
7617 | { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 }, | 7769 | { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 }, |
7618 | { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 }, | 7770 | { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 }, |
7619 | /* port-E for HP out (front panel) */ | 7771 | /* port-E for HP out (front panel) */ |
7620 | { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, // this has to be set to VREF80 | 7772 | /* this has to be set to VREF80 */ |
7773 | { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, | ||
7621 | /* route front PCM to HP */ | 7774 | /* route front PCM to HP */ |
7622 | { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 }, | 7775 | { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 }, |
7623 | /* port-F for mic-in (front panel) with vref */ | 7776 | /* port-F for mic-in (front panel) with vref */ |
@@ -7648,7 +7801,7 @@ static struct hda_verb alc861_uniwill_m31_init_verbs[] = { | |||
7648 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7801 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7649 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7802 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7650 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7803 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7651 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, //Output 0~12 step | 7804 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */ |
7652 | 7805 | ||
7653 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7806 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7654 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7807 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
@@ -7658,7 +7811,8 @@ static struct hda_verb alc861_uniwill_m31_init_verbs[] = { | |||
7658 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7811 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7659 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7812 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7660 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7813 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7661 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, // hp used DAC 3 (Front) | 7814 | /* hp used DAC 3 (Front) */ |
7815 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | ||
7662 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7816 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7663 | { } | 7817 | { } |
7664 | }; | 7818 | }; |
@@ -7667,7 +7821,9 @@ static struct hda_verb alc861_asus_init_verbs[] = { | |||
7667 | /* | 7821 | /* |
7668 | * Unmute ADC0 and set the default input to mic-in | 7822 | * Unmute ADC0 and set the default input to mic-in |
7669 | */ | 7823 | */ |
7670 | /* port-A for surround (rear panel) | according to codec#0 this is the HP jack*/ | 7824 | /* port-A for surround (rear panel) |
7825 | * according to codec#0 this is the HP jack | ||
7826 | */ | ||
7671 | { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 }, /* was 0x00 */ | 7827 | { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 }, /* was 0x00 */ |
7672 | /* route front PCM to HP */ | 7828 | /* route front PCM to HP */ |
7673 | { 0x0e, AC_VERB_SET_CONNECT_SEL, 0x01 }, | 7829 | { 0x0e, AC_VERB_SET_CONNECT_SEL, 0x01 }, |
@@ -7679,7 +7835,8 @@ static struct hda_verb alc861_asus_init_verbs[] = { | |||
7679 | { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 }, | 7835 | { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 }, |
7680 | { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 }, | 7836 | { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 }, |
7681 | /* port-E for HP out (front panel) */ | 7837 | /* port-E for HP out (front panel) */ |
7682 | { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, /* this has to be set to VREF80 */ | 7838 | /* this has to be set to VREF80 */ |
7839 | { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 }, | ||
7683 | /* route front PCM to HP */ | 7840 | /* route front PCM to HP */ |
7684 | { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 }, | 7841 | { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 }, |
7685 | /* port-F for mic-in (front panel) with vref */ | 7842 | /* port-F for mic-in (front panel) with vref */ |
@@ -7709,7 +7866,7 @@ static struct hda_verb alc861_asus_init_verbs[] = { | |||
7709 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7866 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7710 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7867 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7711 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7868 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7712 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c }, /* Output 0~12 step */ | 7869 | {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */ |
7713 | 7870 | ||
7714 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7871 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7715 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7872 | {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
@@ -7719,7 +7876,8 @@ static struct hda_verb alc861_asus_init_verbs[] = { | |||
7719 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7876 | {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7720 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7877 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7721 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, | 7878 | {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)}, |
7722 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, /* hp used DAC 3 (Front) */ | 7879 | /* hp used DAC 3 (Front) */ |
7880 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | ||
7723 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7881 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7724 | { } | 7882 | { } |
7725 | }; | 7883 | }; |
@@ -7738,7 +7896,7 @@ static struct hda_verb alc861_auto_init_verbs[] = { | |||
7738 | /* | 7896 | /* |
7739 | * Unmute ADC0 and set the default input to mic-in | 7897 | * Unmute ADC0 and set the default input to mic-in |
7740 | */ | 7898 | */ |
7741 | // {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, | 7899 | /* {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, */ |
7742 | {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, | 7900 | {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
7743 | 7901 | ||
7744 | /* Unmute DAC0~3 & spdif out*/ | 7902 | /* Unmute DAC0~3 & spdif out*/ |
@@ -7771,21 +7929,21 @@ static struct hda_verb alc861_auto_init_verbs[] = { | |||
7771 | 7929 | ||
7772 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, | 7930 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, |
7773 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, | 7931 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, |
7774 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7932 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7775 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | 7933 | {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, |
7776 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, | 7934 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, |
7777 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, | 7935 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, |
7778 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, | 7936 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)}, |
7779 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, | 7937 | {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)}, |
7780 | 7938 | ||
7781 | {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, // set Mic 1 | 7939 | {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, /* set Mic 1 */ |
7782 | 7940 | ||
7783 | { } | 7941 | { } |
7784 | }; | 7942 | }; |
7785 | 7943 | ||
7786 | static struct hda_verb alc861_toshiba_init_verbs[] = { | 7944 | static struct hda_verb alc861_toshiba_init_verbs[] = { |
7787 | {0x0f, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, | 7945 | {0x0f, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT}, |
7788 | 7946 | ||
7789 | { } | 7947 | { } |
7790 | }; | 7948 | }; |
7791 | 7949 | ||
@@ -7853,7 +8011,8 @@ static struct hda_input_mux alc861_capture_source = { | |||
7853 | }; | 8011 | }; |
7854 | 8012 | ||
7855 | /* fill in the dac_nids table from the parsed pin configuration */ | 8013 | /* fill in the dac_nids table from the parsed pin configuration */ |
7856 | static int alc861_auto_fill_dac_nids(struct alc_spec *spec, const struct auto_pin_cfg *cfg) | 8014 | static int alc861_auto_fill_dac_nids(struct alc_spec *spec, |
8015 | const struct auto_pin_cfg *cfg) | ||
7857 | { | 8016 | { |
7858 | int i; | 8017 | int i; |
7859 | hda_nid_t nid; | 8018 | hda_nid_t nid; |
@@ -7876,29 +8035,40 @@ static int alc861_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
7876 | const struct auto_pin_cfg *cfg) | 8035 | const struct auto_pin_cfg *cfg) |
7877 | { | 8036 | { |
7878 | char name[32]; | 8037 | char name[32]; |
7879 | static const char *chname[4] = { "Front", "Surround", NULL /*CLFE*/, "Side" }; | 8038 | static const char *chname[4] = { |
8039 | "Front", "Surround", NULL /*CLFE*/, "Side" | ||
8040 | }; | ||
7880 | hda_nid_t nid; | 8041 | hda_nid_t nid; |
7881 | int i, idx, err; | 8042 | int i, idx, err; |
7882 | 8043 | ||
7883 | for (i = 0; i < cfg->line_outs; i++) { | 8044 | for (i = 0; i < cfg->line_outs; i++) { |
7884 | nid = spec->multiout.dac_nids[i]; | 8045 | nid = spec->multiout.dac_nids[i]; |
7885 | if (! nid) | 8046 | if (!nid) |
7886 | continue; | 8047 | continue; |
7887 | if (nid == 0x05) { | 8048 | if (nid == 0x05) { |
7888 | /* Center/LFE */ | 8049 | /* Center/LFE */ |
7889 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, "Center Playback Switch", | 8050 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
7890 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT))) < 0) | 8051 | "Center Playback Switch", |
8052 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, | ||
8053 | HDA_OUTPUT)); | ||
8054 | if (err < 0) | ||
7891 | return err; | 8055 | return err; |
7892 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, "LFE Playback Switch", | 8056 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
7893 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT))) < 0) | 8057 | "LFE Playback Switch", |
8058 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, | ||
8059 | HDA_OUTPUT)); | ||
8060 | if (err < 0) | ||
7894 | return err; | 8061 | return err; |
7895 | } else { | 8062 | } else { |
7896 | for (idx = 0; idx < ARRAY_SIZE(alc861_dac_nids) - 1; idx++) | 8063 | for (idx = 0; idx < ARRAY_SIZE(alc861_dac_nids) - 1; |
8064 | idx++) | ||
7897 | if (nid == alc861_dac_nids[idx]) | 8065 | if (nid == alc861_dac_nids[idx]) |
7898 | break; | 8066 | break; |
7899 | sprintf(name, "%s Playback Switch", chname[idx]); | 8067 | sprintf(name, "%s Playback Switch", chname[idx]); |
7900 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 8068 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
7901 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 8069 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, |
8070 | HDA_OUTPUT)); | ||
8071 | if (err < 0) | ||
7902 | return err; | 8072 | return err; |
7903 | } | 8073 | } |
7904 | } | 8074 | } |
@@ -7910,13 +8080,15 @@ static int alc861_auto_create_hp_ctls(struct alc_spec *spec, hda_nid_t pin) | |||
7910 | int err; | 8080 | int err; |
7911 | hda_nid_t nid; | 8081 | hda_nid_t nid; |
7912 | 8082 | ||
7913 | if (! pin) | 8083 | if (!pin) |
7914 | return 0; | 8084 | return 0; |
7915 | 8085 | ||
7916 | if ((pin >= 0x0b && pin <= 0x10) || pin == 0x1f || pin == 0x20) { | 8086 | if ((pin >= 0x0b && pin <= 0x10) || pin == 0x1f || pin == 0x20) { |
7917 | nid = 0x03; | 8087 | nid = 0x03; |
7918 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, "Headphone Playback Switch", | 8088 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, |
7919 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT))) < 0) | 8089 | "Headphone Playback Switch", |
8090 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT)); | ||
8091 | if (err < 0) | ||
7920 | return err; | 8092 | return err; |
7921 | spec->multiout.hp_nid = nid; | 8093 | spec->multiout.hp_nid = nid; |
7922 | } | 8094 | } |
@@ -7924,32 +8096,33 @@ static int alc861_auto_create_hp_ctls(struct alc_spec *spec, hda_nid_t pin) | |||
7924 | } | 8096 | } |
7925 | 8097 | ||
7926 | /* create playback/capture controls for input pins */ | 8098 | /* create playback/capture controls for input pins */ |
7927 | static int alc861_auto_create_analog_input_ctls(struct alc_spec *spec, const struct auto_pin_cfg *cfg) | 8099 | static int alc861_auto_create_analog_input_ctls(struct alc_spec *spec, |
8100 | const struct auto_pin_cfg *cfg) | ||
7928 | { | 8101 | { |
7929 | struct hda_input_mux *imux = &spec->private_imux; | 8102 | struct hda_input_mux *imux = &spec->private_imux; |
7930 | int i, err, idx, idx1; | 8103 | int i, err, idx, idx1; |
7931 | 8104 | ||
7932 | for (i = 0; i < AUTO_PIN_LAST; i++) { | 8105 | for (i = 0; i < AUTO_PIN_LAST; i++) { |
7933 | switch(cfg->input_pins[i]) { | 8106 | switch (cfg->input_pins[i]) { |
7934 | case 0x0c: | 8107 | case 0x0c: |
7935 | idx1 = 1; | 8108 | idx1 = 1; |
7936 | idx = 2; // Line In | 8109 | idx = 2; /* Line In */ |
7937 | break; | 8110 | break; |
7938 | case 0x0f: | 8111 | case 0x0f: |
7939 | idx1 = 2; | 8112 | idx1 = 2; |
7940 | idx = 2; // Line In | 8113 | idx = 2; /* Line In */ |
7941 | break; | 8114 | break; |
7942 | case 0x0d: | 8115 | case 0x0d: |
7943 | idx1 = 0; | 8116 | idx1 = 0; |
7944 | idx = 1; // Mic In | 8117 | idx = 1; /* Mic In */ |
7945 | break; | 8118 | break; |
7946 | case 0x10: | 8119 | case 0x10: |
7947 | idx1 = 3; | 8120 | idx1 = 3; |
7948 | idx = 1; // Mic In | 8121 | idx = 1; /* Mic In */ |
7949 | break; | 8122 | break; |
7950 | case 0x11: | 8123 | case 0x11: |
7951 | idx1 = 4; | 8124 | idx1 = 4; |
7952 | idx = 0; // CD | 8125 | idx = 0; /* CD */ |
7953 | break; | 8126 | break; |
7954 | default: | 8127 | default: |
7955 | continue; | 8128 | continue; |
@@ -7962,7 +8135,7 @@ static int alc861_auto_create_analog_input_ctls(struct alc_spec *spec, const str | |||
7962 | 8135 | ||
7963 | imux->items[imux->num_items].label = auto_pin_cfg_labels[i]; | 8136 | imux->items[imux->num_items].label = auto_pin_cfg_labels[i]; |
7964 | imux->items[imux->num_items].index = idx1; | 8137 | imux->items[imux->num_items].index = idx1; |
7965 | imux->num_items++; | 8138 | imux->num_items++; |
7966 | } | 8139 | } |
7967 | return 0; | 8140 | return 0; |
7968 | } | 8141 | } |
@@ -7987,13 +8160,16 @@ static struct snd_kcontrol_new alc861_capture_mixer[] = { | |||
7987 | { } /* end */ | 8160 | { } /* end */ |
7988 | }; | 8161 | }; |
7989 | 8162 | ||
7990 | static void alc861_auto_set_output_and_unmute(struct hda_codec *codec, hda_nid_t nid, | 8163 | static void alc861_auto_set_output_and_unmute(struct hda_codec *codec, |
8164 | hda_nid_t nid, | ||
7991 | int pin_type, int dac_idx) | 8165 | int pin_type, int dac_idx) |
7992 | { | 8166 | { |
7993 | /* set as output */ | 8167 | /* set as output */ |
7994 | 8168 | ||
7995 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type); | 8169 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, |
7996 | snd_hda_codec_write(codec, dac_idx, 0, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE); | 8170 | pin_type); |
8171 | snd_hda_codec_write(codec, dac_idx, 0, AC_VERB_SET_AMP_GAIN_MUTE, | ||
8172 | AMP_OUT_UNMUTE); | ||
7997 | 8173 | ||
7998 | } | 8174 | } |
7999 | 8175 | ||
@@ -8006,7 +8182,8 @@ static void alc861_auto_init_multi_out(struct hda_codec *codec) | |||
8006 | for (i = 0; i < spec->autocfg.line_outs; i++) { | 8182 | for (i = 0; i < spec->autocfg.line_outs; i++) { |
8007 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; | 8183 | hda_nid_t nid = spec->autocfg.line_out_pins[i]; |
8008 | if (nid) | 8184 | if (nid) |
8009 | alc861_auto_set_output_and_unmute(codec, nid, PIN_OUT, spec->multiout.dac_nids[i]); | 8185 | alc861_auto_set_output_and_unmute(codec, nid, PIN_OUT, |
8186 | spec->multiout.dac_nids[i]); | ||
8010 | } | 8187 | } |
8011 | } | 8188 | } |
8012 | 8189 | ||
@@ -8017,7 +8194,8 @@ static void alc861_auto_init_hp_out(struct hda_codec *codec) | |||
8017 | 8194 | ||
8018 | pin = spec->autocfg.hp_pins[0]; | 8195 | pin = spec->autocfg.hp_pins[0]; |
8019 | if (pin) /* connect to front */ | 8196 | if (pin) /* connect to front */ |
8020 | alc861_auto_set_output_and_unmute(codec, pin, PIN_HP, spec->multiout.dac_nids[0]); | 8197 | alc861_auto_set_output_and_unmute(codec, pin, PIN_HP, |
8198 | spec->multiout.dac_nids[0]); | ||
8021 | } | 8199 | } |
8022 | 8200 | ||
8023 | static void alc861_auto_init_analog_input(struct hda_codec *codec) | 8201 | static void alc861_auto_init_analog_input(struct hda_codec *codec) |
@@ -8027,31 +8205,43 @@ static void alc861_auto_init_analog_input(struct hda_codec *codec) | |||
8027 | 8205 | ||
8028 | for (i = 0; i < AUTO_PIN_LAST; i++) { | 8206 | for (i = 0; i < AUTO_PIN_LAST; i++) { |
8029 | hda_nid_t nid = spec->autocfg.input_pins[i]; | 8207 | hda_nid_t nid = spec->autocfg.input_pins[i]; |
8030 | if ((nid>=0x0c) && (nid <=0x11)) { | 8208 | if (nid >= 0x0c && nid <= 0x11) { |
8031 | snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, | 8209 | snd_hda_codec_write(codec, nid, 0, |
8032 | i <= AUTO_PIN_FRONT_MIC ? PIN_VREF80 : PIN_IN); | 8210 | AC_VERB_SET_PIN_WIDGET_CONTROL, |
8211 | i <= AUTO_PIN_FRONT_MIC ? | ||
8212 | PIN_VREF80 : PIN_IN); | ||
8033 | } | 8213 | } |
8034 | } | 8214 | } |
8035 | } | 8215 | } |
8036 | 8216 | ||
8037 | /* parse the BIOS configuration and set up the alc_spec */ | 8217 | /* parse the BIOS configuration and set up the alc_spec */ |
8038 | /* return 1 if successful, 0 if the proper config is not found, or a negative error code */ | 8218 | /* return 1 if successful, 0 if the proper config is not found, |
8219 | * or a negative error code | ||
8220 | */ | ||
8039 | static int alc861_parse_auto_config(struct hda_codec *codec) | 8221 | static int alc861_parse_auto_config(struct hda_codec *codec) |
8040 | { | 8222 | { |
8041 | struct alc_spec *spec = codec->spec; | 8223 | struct alc_spec *spec = codec->spec; |
8042 | int err; | 8224 | int err; |
8043 | static hda_nid_t alc861_ignore[] = { 0x1d, 0 }; | 8225 | static hda_nid_t alc861_ignore[] = { 0x1d, 0 }; |
8044 | 8226 | ||
8045 | if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 8227 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
8046 | alc861_ignore)) < 0) | 8228 | alc861_ignore); |
8229 | if (err < 0) | ||
8047 | return err; | 8230 | return err; |
8048 | if (! spec->autocfg.line_outs) | 8231 | if (!spec->autocfg.line_outs) |
8049 | return 0; /* can't find valid BIOS pin config */ | 8232 | return 0; /* can't find valid BIOS pin config */ |
8050 | 8233 | ||
8051 | if ((err = alc861_auto_fill_dac_nids(spec, &spec->autocfg)) < 0 || | 8234 | err = alc861_auto_fill_dac_nids(spec, &spec->autocfg); |
8052 | (err = alc861_auto_create_multi_out_ctls(spec, &spec->autocfg)) < 0 || | 8235 | if (err < 0) |
8053 | (err = alc861_auto_create_hp_ctls(spec, spec->autocfg.hp_pins[0])) < 0 || | 8236 | return err; |
8054 | (err = alc861_auto_create_analog_input_ctls(spec, &spec->autocfg)) < 0) | 8237 | err = alc861_auto_create_multi_out_ctls(spec, &spec->autocfg); |
8238 | if (err < 0) | ||
8239 | return err; | ||
8240 | err = alc861_auto_create_hp_ctls(spec, spec->autocfg.hp_pins[0]); | ||
8241 | if (err < 0) | ||
8242 | return err; | ||
8243 | err = alc861_auto_create_analog_input_ctls(spec, &spec->autocfg); | ||
8244 | if (err < 0) | ||
8055 | return err; | 8245 | return err; |
8056 | 8246 | ||
8057 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 8247 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |
@@ -8179,7 +8369,8 @@ static struct alc_config_preset alc861_presets[] = { | |||
8179 | }, | 8369 | }, |
8180 | [ALC861_TOSHIBA] = { | 8370 | [ALC861_TOSHIBA] = { |
8181 | .mixers = { alc861_toshiba_mixer }, | 8371 | .mixers = { alc861_toshiba_mixer }, |
8182 | .init_verbs = { alc861_base_init_verbs, alc861_toshiba_init_verbs }, | 8372 | .init_verbs = { alc861_base_init_verbs, |
8373 | alc861_toshiba_init_verbs }, | ||
8183 | .num_dacs = ARRAY_SIZE(alc861_dac_nids), | 8374 | .num_dacs = ARRAY_SIZE(alc861_dac_nids), |
8184 | .dac_nids = alc861_dac_nids, | 8375 | .dac_nids = alc861_dac_nids, |
8185 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), | 8376 | .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes), |
@@ -8231,7 +8422,7 @@ static int patch_alc861(struct hda_codec *codec) | |||
8231 | if (spec == NULL) | 8422 | if (spec == NULL) |
8232 | return -ENOMEM; | 8423 | return -ENOMEM; |
8233 | 8424 | ||
8234 | codec->spec = spec; | 8425 | codec->spec = spec; |
8235 | 8426 | ||
8236 | board_config = snd_hda_check_board_config(codec, ALC861_MODEL_LAST, | 8427 | board_config = snd_hda_check_board_config(codec, ALC861_MODEL_LAST, |
8237 | alc861_models, | 8428 | alc861_models, |
@@ -8249,7 +8440,7 @@ static int patch_alc861(struct hda_codec *codec) | |||
8249 | if (err < 0) { | 8440 | if (err < 0) { |
8250 | alc_free(codec); | 8441 | alc_free(codec); |
8251 | return err; | 8442 | return err; |
8252 | } else if (! err) { | 8443 | } else if (!err) { |
8253 | printk(KERN_INFO | 8444 | printk(KERN_INFO |
8254 | "hda_codec: Cannot set up configuration " | 8445 | "hda_codec: Cannot set up configuration " |
8255 | "from BIOS. Using base mode...\n"); | 8446 | "from BIOS. Using base mode...\n"); |
@@ -8336,7 +8527,7 @@ static int alc861vd_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
8336 | idx = ucontrol->value.enumerated.item[0]; | 8527 | idx = ucontrol->value.enumerated.item[0]; |
8337 | if (idx >= imux->num_items) | 8528 | if (idx >= imux->num_items) |
8338 | idx = imux->num_items - 1; | 8529 | idx = imux->num_items - 1; |
8339 | if (*cur_val == idx && ! codec->in_resume) | 8530 | if (*cur_val == idx && !codec->in_resume) |
8340 | return 0; | 8531 | return 0; |
8341 | for (i = 0; i < imux->num_items; i++) { | 8532 | for (i = 0; i < imux->num_items; i++) { |
8342 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; | 8533 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; |
@@ -8755,7 +8946,7 @@ static int alc861vd_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
8755 | int i, err; | 8946 | int i, err; |
8756 | 8947 | ||
8757 | for (i = 0; i < cfg->line_outs; i++) { | 8948 | for (i = 0; i < cfg->line_outs; i++) { |
8758 | if (! spec->multiout.dac_nids[i]) | 8949 | if (!spec->multiout.dac_nids[i]) |
8759 | continue; | 8950 | continue; |
8760 | nid_v = alc861vd_idx_to_mixer_vol( | 8951 | nid_v = alc861vd_idx_to_mixer_vol( |
8761 | alc880_dac_to_idx( | 8952 | alc880_dac_to_idx( |
@@ -8766,36 +8957,42 @@ static int alc861vd_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
8766 | 8957 | ||
8767 | if (i == 2) { | 8958 | if (i == 2) { |
8768 | /* Center/LFE */ | 8959 | /* Center/LFE */ |
8769 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, | 8960 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
8770 | "Center Playback Volume", | 8961 | "Center Playback Volume", |
8771 | HDA_COMPOSE_AMP_VAL(nid_v, 1, | 8962 | HDA_COMPOSE_AMP_VAL(nid_v, 1, 0, |
8772 | 0, HDA_OUTPUT))) < 0) | 8963 | HDA_OUTPUT)); |
8964 | if (err < 0) | ||
8773 | return err; | 8965 | return err; |
8774 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, | 8966 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
8775 | "LFE Playback Volume", | 8967 | "LFE Playback Volume", |
8776 | HDA_COMPOSE_AMP_VAL(nid_v, 2, | 8968 | HDA_COMPOSE_AMP_VAL(nid_v, 2, 0, |
8777 | 0, HDA_OUTPUT))) < 0) | 8969 | HDA_OUTPUT)); |
8970 | if (err < 0) | ||
8778 | return err; | 8971 | return err; |
8779 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, | 8972 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
8780 | "Center Playback Switch", | 8973 | "Center Playback Switch", |
8781 | HDA_COMPOSE_AMP_VAL(nid_s, 1, | 8974 | HDA_COMPOSE_AMP_VAL(nid_s, 1, 2, |
8782 | 2, HDA_INPUT))) < 0) | 8975 | HDA_INPUT)); |
8976 | if (err < 0) | ||
8783 | return err; | 8977 | return err; |
8784 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, | 8978 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
8785 | "LFE Playback Switch", | 8979 | "LFE Playback Switch", |
8786 | HDA_COMPOSE_AMP_VAL(nid_s, 2, | 8980 | HDA_COMPOSE_AMP_VAL(nid_s, 2, 2, |
8787 | 2, HDA_INPUT))) < 0) | 8981 | HDA_INPUT)); |
8982 | if (err < 0) | ||
8788 | return err; | 8983 | return err; |
8789 | } else { | 8984 | } else { |
8790 | sprintf(name, "%s Playback Volume", chname[i]); | 8985 | sprintf(name, "%s Playback Volume", chname[i]); |
8791 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 8986 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
8792 | HDA_COMPOSE_AMP_VAL(nid_v, 3, | 8987 | HDA_COMPOSE_AMP_VAL(nid_v, 3, 0, |
8793 | 0, HDA_OUTPUT))) < 0) | 8988 | HDA_OUTPUT)); |
8989 | if (err < 0) | ||
8794 | return err; | 8990 | return err; |
8795 | sprintf(name, "%s Playback Switch", chname[i]); | 8991 | sprintf(name, "%s Playback Switch", chname[i]); |
8796 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 8992 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
8797 | HDA_COMPOSE_AMP_VAL(nid_v, 3, | 8993 | HDA_COMPOSE_AMP_VAL(nid_v, 3, 2, |
8798 | 2, HDA_INPUT))) < 0) | 8994 | HDA_INPUT)); |
8995 | if (err < 0) | ||
8799 | return err; | 8996 | return err; |
8800 | } | 8997 | } |
8801 | } | 8998 | } |
@@ -8812,13 +9009,13 @@ static int alc861vd_auto_create_extra_out(struct alc_spec *spec, | |||
8812 | int err; | 9009 | int err; |
8813 | char name[32]; | 9010 | char name[32]; |
8814 | 9011 | ||
8815 | if (! pin) | 9012 | if (!pin) |
8816 | return 0; | 9013 | return 0; |
8817 | 9014 | ||
8818 | if (alc880_is_fixed_pin(pin)) { | 9015 | if (alc880_is_fixed_pin(pin)) { |
8819 | nid_v = alc880_idx_to_dac(alc880_fixed_pin_idx(pin)); | 9016 | nid_v = alc880_idx_to_dac(alc880_fixed_pin_idx(pin)); |
8820 | /* specify the DAC as the extra output */ | 9017 | /* specify the DAC as the extra output */ |
8821 | if (! spec->multiout.hp_nid) | 9018 | if (!spec->multiout.hp_nid) |
8822 | spec->multiout.hp_nid = nid_v; | 9019 | spec->multiout.hp_nid = nid_v; |
8823 | else | 9020 | else |
8824 | spec->multiout.extra_out_nid[0] = nid_v; | 9021 | spec->multiout.extra_out_nid[0] = nid_v; |
@@ -8829,22 +9026,22 @@ static int alc861vd_auto_create_extra_out(struct alc_spec *spec, | |||
8829 | alc880_fixed_pin_idx(pin)); | 9026 | alc880_fixed_pin_idx(pin)); |
8830 | 9027 | ||
8831 | sprintf(name, "%s Playback Volume", pfx); | 9028 | sprintf(name, "%s Playback Volume", pfx); |
8832 | if ((err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 9029 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
8833 | HDA_COMPOSE_AMP_VAL(nid_v, 3, 0, | 9030 | HDA_COMPOSE_AMP_VAL(nid_v, 3, 0, HDA_OUTPUT)); |
8834 | HDA_OUTPUT))) < 0) | 9031 | if (err < 0) |
8835 | return err; | 9032 | return err; |
8836 | sprintf(name, "%s Playback Switch", pfx); | 9033 | sprintf(name, "%s Playback Switch", pfx); |
8837 | if ((err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 9034 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
8838 | HDA_COMPOSE_AMP_VAL(nid_s, 3, 2, | 9035 | HDA_COMPOSE_AMP_VAL(nid_s, 3, 2, HDA_INPUT)); |
8839 | HDA_INPUT))) < 0) | 9036 | if (err < 0) |
8840 | return err; | 9037 | return err; |
8841 | } else if (alc880_is_multi_pin(pin)) { | 9038 | } else if (alc880_is_multi_pin(pin)) { |
8842 | /* set manual connection */ | 9039 | /* set manual connection */ |
8843 | /* we have only a switch on HP-out PIN */ | 9040 | /* we have only a switch on HP-out PIN */ |
8844 | sprintf(name, "%s Playback Switch", pfx); | 9041 | sprintf(name, "%s Playback Switch", pfx); |
8845 | if ((err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, | 9042 | err = add_control(spec, ALC_CTL_WIDGET_MUTE, name, |
8846 | HDA_COMPOSE_AMP_VAL(pin, 3, 0, | 9043 | HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT)); |
8847 | HDA_OUTPUT))) < 0) | 9044 | if (err < 0) |
8848 | return err; | 9045 | return err; |
8849 | } | 9046 | } |
8850 | return 0; | 9047 | return 0; |
@@ -8861,21 +9058,31 @@ static int alc861vd_parse_auto_config(struct hda_codec *codec) | |||
8861 | int err; | 9058 | int err; |
8862 | static hda_nid_t alc861vd_ignore[] = { 0x1d, 0 }; | 9059 | static hda_nid_t alc861vd_ignore[] = { 0x1d, 0 }; |
8863 | 9060 | ||
8864 | if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 9061 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
8865 | alc861vd_ignore)) < 0) | 9062 | alc861vd_ignore); |
9063 | if (err < 0) | ||
8866 | return err; | 9064 | return err; |
8867 | if (! spec->autocfg.line_outs) | 9065 | if (!spec->autocfg.line_outs) |
8868 | return 0; /* can't find valid BIOS pin config */ | 9066 | return 0; /* can't find valid BIOS pin config */ |
8869 | 9067 | ||
8870 | if ((err = alc880_auto_fill_dac_nids(spec, &spec->autocfg)) < 0 || | 9068 | err = alc880_auto_fill_dac_nids(spec, &spec->autocfg); |
8871 | (err = alc861vd_auto_create_multi_out_ctls(spec, | 9069 | if (err < 0) |
8872 | &spec->autocfg)) < 0 || | 9070 | return err; |
8873 | (err = alc861vd_auto_create_extra_out(spec, | 9071 | err = alc861vd_auto_create_multi_out_ctls(spec, &spec->autocfg); |
8874 | spec->autocfg.speaker_pins[0], "Speaker")) < 0 || | 9072 | if (err < 0) |
8875 | (err = alc861vd_auto_create_extra_out(spec, | 9073 | return err; |
8876 | spec->autocfg.hp_pins[0], "Headphone")) < 0 || | 9074 | err = alc861vd_auto_create_extra_out(spec, |
8877 | (err = alc880_auto_create_analog_input_ctls(spec, | 9075 | spec->autocfg.speaker_pins[0], |
8878 | &spec->autocfg)) < 0) | 9076 | "Speaker"); |
9077 | if (err < 0) | ||
9078 | return err; | ||
9079 | err = alc861vd_auto_create_extra_out(spec, | ||
9080 | spec->autocfg.hp_pins[0], | ||
9081 | "Headphone"); | ||
9082 | if (err < 0) | ||
9083 | return err; | ||
9084 | err = alc880_auto_create_analog_input_ctls(spec, &spec->autocfg); | ||
9085 | if (err < 0) | ||
8879 | return err; | 9086 | return err; |
8880 | 9087 | ||
8881 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 9088 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |
@@ -8930,7 +9137,7 @@ static int patch_alc861vd(struct hda_codec *codec) | |||
8930 | if (err < 0) { | 9137 | if (err < 0) { |
8931 | alc_free(codec); | 9138 | alc_free(codec); |
8932 | return err; | 9139 | return err; |
8933 | } else if (! err) { | 9140 | } else if (!err) { |
8934 | printk(KERN_INFO | 9141 | printk(KERN_INFO |
8935 | "hda_codec: Cannot set up configuration " | 9142 | "hda_codec: Cannot set up configuration " |
8936 | "from BIOS. Using base mode...\n"); | 9143 | "from BIOS. Using base mode...\n"); |
@@ -9024,7 +9231,7 @@ static int alc662_mux_enum_put(struct snd_kcontrol *kcontrol, | |||
9024 | idx = ucontrol->value.enumerated.item[0]; | 9231 | idx = ucontrol->value.enumerated.item[0]; |
9025 | if (idx >= imux->num_items) | 9232 | if (idx >= imux->num_items) |
9026 | idx = imux->num_items - 1; | 9233 | idx = imux->num_items - 1; |
9027 | if (*cur_val == idx && ! codec->in_resume) | 9234 | if (*cur_val == idx && !codec->in_resume) |
9028 | return 0; | 9235 | return 0; |
9029 | for (i = 0; i < imux->num_items; i++) { | 9236 | for (i = 0; i < imux->num_items; i++) { |
9030 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; | 9237 | unsigned int v = (i == idx) ? 0x7000 : 0x7080; |
@@ -9370,31 +9577,33 @@ static struct snd_kcontrol_new alc662_capture_mixer[] = { | |||
9370 | static void alc662_lenovo_101e_ispeaker_automute(struct hda_codec *codec) | 9577 | static void alc662_lenovo_101e_ispeaker_automute(struct hda_codec *codec) |
9371 | { | 9578 | { |
9372 | unsigned int present; | 9579 | unsigned int present; |
9580 | unsigned char bits; | ||
9373 | 9581 | ||
9374 | present = snd_hda_codec_read(codec, 0x14, 0, | 9582 | present = snd_hda_codec_read(codec, 0x14, 0, |
9375 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 9583 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
9376 | 9584 | bits = present ? 0x80 : 0; | |
9377 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, | 9585 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, |
9378 | 0x80, present ? 0x80 : 0); | 9586 | 0x80, bits); |
9379 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, | 9587 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, |
9380 | 0x80, present ? 0x80 : 0); | 9588 | 0x80, bits); |
9381 | } | 9589 | } |
9382 | 9590 | ||
9383 | static void alc662_lenovo_101e_all_automute(struct hda_codec *codec) | 9591 | static void alc662_lenovo_101e_all_automute(struct hda_codec *codec) |
9384 | { | 9592 | { |
9385 | unsigned int present; | 9593 | unsigned int present; |
9594 | unsigned char bits; | ||
9386 | 9595 | ||
9387 | present = snd_hda_codec_read(codec, 0x1b, 0, | 9596 | present = snd_hda_codec_read(codec, 0x1b, 0, |
9388 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; | 9597 | AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; |
9389 | 9598 | bits = present ? 0x80 : 0; | |
9390 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, | 9599 | snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0, |
9391 | 0x80, present ? 0x80 : 0); | 9600 | 0x80, bits); |
9392 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, | 9601 | snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0, |
9393 | 0x80, present ? 0x80 : 0); | 9602 | 0x80, bits); |
9394 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, | 9603 | snd_hda_codec_amp_update(codec, 0x14, 0, HDA_OUTPUT, 0, |
9395 | 0x80, present ? 0x80 : 0); | 9604 | 0x80, bits); |
9396 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, | 9605 | snd_hda_codec_amp_update(codec, 0x14, 1, HDA_OUTPUT, 0, |
9397 | 0x80, present ? 0x80 : 0); | 9606 | 0x80, bits); |
9398 | } | 9607 | } |
9399 | 9608 | ||
9400 | static void alc662_lenovo_101e_unsol_event(struct hda_codec *codec, | 9609 | static void alc662_lenovo_101e_unsol_event(struct hda_codec *codec, |
@@ -9457,7 +9666,7 @@ static struct alc_config_preset alc662_presets[] = { | |||
9457 | .channel_mode = alc662_3ST_6ch_modes, | 9666 | .channel_mode = alc662_3ST_6ch_modes, |
9458 | .need_dac_fix = 1, | 9667 | .need_dac_fix = 1, |
9459 | .input_mux = &alc662_capture_source, | 9668 | .input_mux = &alc662_capture_source, |
9460 | }, | 9669 | }, |
9461 | [ALC662_3ST_6ch] = { | 9670 | [ALC662_3ST_6ch] = { |
9462 | .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer }, | 9671 | .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer }, |
9463 | .init_verbs = { alc662_init_verbs }, | 9672 | .init_verbs = { alc662_init_verbs }, |
@@ -9469,7 +9678,7 @@ static struct alc_config_preset alc662_presets[] = { | |||
9469 | .channel_mode = alc662_3ST_6ch_modes, | 9678 | .channel_mode = alc662_3ST_6ch_modes, |
9470 | .need_dac_fix = 1, | 9679 | .need_dac_fix = 1, |
9471 | .input_mux = &alc662_capture_source, | 9680 | .input_mux = &alc662_capture_source, |
9472 | }, | 9681 | }, |
9473 | [ALC662_5ST_DIG] = { | 9682 | [ALC662_5ST_DIG] = { |
9474 | .mixers = { alc662_base_mixer, alc662_chmode_mixer }, | 9683 | .mixers = { alc662_base_mixer, alc662_chmode_mixer }, |
9475 | .init_verbs = { alc662_init_verbs }, | 9684 | .init_verbs = { alc662_init_verbs }, |
@@ -9523,33 +9732,39 @@ static int alc662_auto_create_multi_out_ctls(struct alc_spec *spec, | |||
9523 | /* Center/LFE */ | 9732 | /* Center/LFE */ |
9524 | err = add_control(spec, ALC_CTL_WIDGET_VOL, | 9733 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
9525 | "Center Playback Volume", | 9734 | "Center Playback Volume", |
9526 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT)); | 9735 | HDA_COMPOSE_AMP_VAL(nid, 1, 0, |
9736 | HDA_OUTPUT)); | ||
9527 | if (err < 0) | 9737 | if (err < 0) |
9528 | return err; | 9738 | return err; |
9529 | err = add_control(spec, ALC_CTL_WIDGET_VOL, | 9739 | err = add_control(spec, ALC_CTL_WIDGET_VOL, |
9530 | "LFE Playback Volume", | 9740 | "LFE Playback Volume", |
9531 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT)); | 9741 | HDA_COMPOSE_AMP_VAL(nid, 2, 0, |
9742 | HDA_OUTPUT)); | ||
9532 | if (err < 0) | 9743 | if (err < 0) |
9533 | return err; | 9744 | return err; |
9534 | err = add_control(spec, ALC_CTL_BIND_MUTE, | 9745 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
9535 | "Center Playback Switch", | 9746 | "Center Playback Switch", |
9536 | HDA_COMPOSE_AMP_VAL(nid, 1, 2, HDA_INPUT)); | 9747 | HDA_COMPOSE_AMP_VAL(nid, 1, 2, |
9748 | HDA_INPUT)); | ||
9537 | if (err < 0) | 9749 | if (err < 0) |
9538 | return err; | 9750 | return err; |
9539 | err = add_control(spec, ALC_CTL_BIND_MUTE, | 9751 | err = add_control(spec, ALC_CTL_BIND_MUTE, |
9540 | "LFE Playback Switch", | 9752 | "LFE Playback Switch", |
9541 | HDA_COMPOSE_AMP_VAL(nid, 2, 2, HDA_INPUT)); | 9753 | HDA_COMPOSE_AMP_VAL(nid, 2, 2, |
9754 | HDA_INPUT)); | ||
9542 | if (err < 0) | 9755 | if (err < 0) |
9543 | return err; | 9756 | return err; |
9544 | } else { | 9757 | } else { |
9545 | sprintf(name, "%s Playback Volume", chname[i]); | 9758 | sprintf(name, "%s Playback Volume", chname[i]); |
9546 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, | 9759 | err = add_control(spec, ALC_CTL_WIDGET_VOL, name, |
9547 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT)); | 9760 | HDA_COMPOSE_AMP_VAL(nid, 3, 0, |
9761 | HDA_OUTPUT)); | ||
9548 | if (err < 0) | 9762 | if (err < 0) |
9549 | return err; | 9763 | return err; |
9550 | sprintf(name, "%s Playback Switch", chname[i]); | 9764 | sprintf(name, "%s Playback Switch", chname[i]); |
9551 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, | 9765 | err = add_control(spec, ALC_CTL_BIND_MUTE, name, |
9552 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, HDA_INPUT)); | 9766 | HDA_COMPOSE_AMP_VAL(nid, 3, 2, |
9767 | HDA_INPUT)); | ||
9553 | if (err < 0) | 9768 | if (err < 0) |
9554 | return err; | 9769 | return err; |
9555 | } | 9770 | } |
@@ -9704,14 +9919,23 @@ static int alc662_parse_auto_config(struct hda_codec *codec) | |||
9704 | if (!spec->autocfg.line_outs) | 9919 | if (!spec->autocfg.line_outs) |
9705 | return 0; /* can't find valid BIOS pin config */ | 9920 | return 0; /* can't find valid BIOS pin config */ |
9706 | 9921 | ||
9707 | if ((err = alc880_auto_fill_dac_nids(spec, &spec->autocfg)) < 0 || | 9922 | err = alc880_auto_fill_dac_nids(spec, &spec->autocfg); |
9708 | (err = alc662_auto_create_multi_out_ctls(spec, &spec->autocfg)) < 0 || | 9923 | if (err < 0) |
9709 | (err = alc662_auto_create_extra_out(spec, | 9924 | return err; |
9710 | spec->autocfg.speaker_pins[0], | 9925 | err = alc662_auto_create_multi_out_ctls(spec, &spec->autocfg); |
9711 | "Speaker")) < 0 || | 9926 | if (err < 0) |
9712 | (err = alc662_auto_create_extra_out(spec, spec->autocfg.hp_pins[0], | 9927 | return err; |
9713 | "Headphone")) < 0 || | 9928 | err = alc662_auto_create_extra_out(spec, |
9714 | (err = alc662_auto_create_analog_input_ctls(spec, &spec->autocfg)) < 0) | 9929 | spec->autocfg.speaker_pins[0], |
9930 | "Speaker"); | ||
9931 | if (err < 0) | ||
9932 | return err; | ||
9933 | err = alc662_auto_create_extra_out(spec, spec->autocfg.hp_pins[0], | ||
9934 | "Headphone"); | ||
9935 | if (err < 0) | ||
9936 | return err; | ||
9937 | err = alc662_auto_create_analog_input_ctls(spec, &spec->autocfg); | ||
9938 | if (err < 0) | ||
9715 | return err; | 9939 | return err; |
9716 | 9940 | ||
9717 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 9941 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |