mirror of https://gitee.com/openkylin/linux.git
1409 lines
50 KiB
C
1409 lines
50 KiB
C
/*
|
|
* ALC662/ALC663/ALC665/ALC670 quirk models
|
|
* included by patch_realtek.c
|
|
*/
|
|
|
|
/* ALC662 models */
|
|
enum {
|
|
ALC662_AUTO,
|
|
ALC662_3ST_2ch_DIG,
|
|
ALC662_3ST_6ch_DIG,
|
|
ALC662_3ST_6ch,
|
|
ALC662_5ST_DIG,
|
|
ALC662_LENOVO_101E,
|
|
ALC662_ASUS_EEEPC_P701,
|
|
ALC662_ASUS_EEEPC_EP20,
|
|
ALC663_ASUS_M51VA,
|
|
ALC663_ASUS_G71V,
|
|
ALC663_ASUS_H13,
|
|
ALC663_ASUS_G50V,
|
|
ALC662_ECS,
|
|
ALC663_ASUS_MODE1,
|
|
ALC662_ASUS_MODE2,
|
|
ALC663_ASUS_MODE3,
|
|
ALC663_ASUS_MODE4,
|
|
ALC663_ASUS_MODE5,
|
|
ALC663_ASUS_MODE6,
|
|
ALC663_ASUS_MODE7,
|
|
ALC663_ASUS_MODE8,
|
|
ALC272_DELL,
|
|
ALC272_DELL_ZM1,
|
|
ALC272_SAMSUNG_NC10,
|
|
ALC662_MODEL_LAST,
|
|
};
|
|
|
|
#define ALC662_DIGOUT_NID 0x06
|
|
#define ALC662_DIGIN_NID 0x0a
|
|
|
|
static const hda_nid_t alc662_dac_nids[3] = {
|
|
/* front, rear, clfe */
|
|
0x02, 0x03, 0x04
|
|
};
|
|
|
|
static const hda_nid_t alc272_dac_nids[2] = {
|
|
0x02, 0x03
|
|
};
|
|
|
|
static const hda_nid_t alc662_adc_nids[2] = {
|
|
/* ADC1-2 */
|
|
0x09, 0x08
|
|
};
|
|
|
|
static const hda_nid_t alc272_adc_nids[1] = {
|
|
/* ADC1-2 */
|
|
0x08,
|
|
};
|
|
|
|
static const hda_nid_t alc662_capsrc_nids[2] = { 0x22, 0x23 };
|
|
static const hda_nid_t alc272_capsrc_nids[1] = { 0x23 };
|
|
|
|
|
|
/* input MUX */
|
|
/* FIXME: should be a matrix-type input source selection */
|
|
static const struct hda_input_mux alc662_capture_source = {
|
|
.num_items = 4,
|
|
.items = {
|
|
{ "Mic", 0x0 },
|
|
{ "Front Mic", 0x1 },
|
|
{ "Line", 0x2 },
|
|
{ "CD", 0x4 },
|
|
},
|
|
};
|
|
|
|
static const struct hda_input_mux alc662_lenovo_101e_capture_source = {
|
|
.num_items = 2,
|
|
.items = {
|
|
{ "Mic", 0x1 },
|
|
{ "Line", 0x2 },
|
|
},
|
|
};
|
|
|
|
static const struct hda_input_mux alc663_capture_source = {
|
|
.num_items = 3,
|
|
.items = {
|
|
{ "Mic", 0x0 },
|
|
{ "Front Mic", 0x1 },
|
|
{ "Line", 0x2 },
|
|
},
|
|
};
|
|
|
|
#if 0 /* set to 1 for testing other input sources below */
|
|
static const struct hda_input_mux alc272_nc10_capture_source = {
|
|
.num_items = 16,
|
|
.items = {
|
|
{ "Autoselect Mic", 0x0 },
|
|
{ "Internal Mic", 0x1 },
|
|
{ "In-0x02", 0x2 },
|
|
{ "In-0x03", 0x3 },
|
|
{ "In-0x04", 0x4 },
|
|
{ "In-0x05", 0x5 },
|
|
{ "In-0x06", 0x6 },
|
|
{ "In-0x07", 0x7 },
|
|
{ "In-0x08", 0x8 },
|
|
{ "In-0x09", 0x9 },
|
|
{ "In-0x0a", 0x0a },
|
|
{ "In-0x0b", 0x0b },
|
|
{ "In-0x0c", 0x0c },
|
|
{ "In-0x0d", 0x0d },
|
|
{ "In-0x0e", 0x0e },
|
|
{ "In-0x0f", 0x0f },
|
|
},
|
|
};
|
|
#endif
|
|
|
|
/*
|
|
* 2ch mode
|
|
*/
|
|
static const struct hda_channel_mode alc662_3ST_2ch_modes[1] = {
|
|
{ 2, NULL }
|
|
};
|
|
|
|
/*
|
|
* 2ch mode
|
|
*/
|
|
static const struct hda_verb alc662_3ST_ch2_init[] = {
|
|
{ 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
|
|
{ 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
|
|
{ 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
|
|
{ 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
|
|
{ } /* end */
|
|
};
|
|
|
|
/*
|
|
* 6ch mode
|
|
*/
|
|
static const struct hda_verb alc662_3ST_ch6_init[] = {
|
|
{ 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
|
|
{ 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
|
|
{ 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
|
|
{ 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_channel_mode alc662_3ST_6ch_modes[2] = {
|
|
{ 2, alc662_3ST_ch2_init },
|
|
{ 6, alc662_3ST_ch6_init },
|
|
};
|
|
|
|
/*
|
|
* 2ch mode
|
|
*/
|
|
static const struct hda_verb alc662_sixstack_ch6_init[] = {
|
|
{ 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
|
|
{ 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
|
|
{ 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ } /* end */
|
|
};
|
|
|
|
/*
|
|
* 6ch mode
|
|
*/
|
|
static const struct hda_verb alc662_sixstack_ch8_init[] = {
|
|
{ 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_channel_mode alc662_5stack_modes[2] = {
|
|
{ 2, alc662_sixstack_ch6_init },
|
|
{ 6, alc662_sixstack_ch8_init },
|
|
};
|
|
|
|
/* Pin assignment: Front=0x14, Rear=0x15, CLFE=0x16, Side=0x17
|
|
* Mic=0x18, Front Mic=0x19, Line-In=0x1a, HP=0x1b
|
|
*/
|
|
|
|
static const struct snd_kcontrol_new alc662_base_mixer[] = {
|
|
/* output mixer control */
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Surround Playback Volume", 0x3, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
|
|
/*Input mixer control */
|
|
HDA_CODEC_VOLUME("CD Playback Volume", 0xb, 0x4, HDA_INPUT),
|
|
HDA_CODEC_MUTE("CD Playback Switch", 0xb, 0x4, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0xb, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0xb, 0x02, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0xb, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0xb, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0xb, 0x01, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0xb, 0x01, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_3ST_2ch_mixer[] = {
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
|
HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_3ST_6ch_mixer[] = {
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
|
|
HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_lenovo_101e_mixer[] = {
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_BIND_MUTE("Front Playback Switch", 0x02, 2, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_BIND_MUTE("Speaker Playback Switch", 0x03, 2, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_eeepc_p701_mixer[] = {
|
|
HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
ALC262_HIPPO_MASTER_SWITCH,
|
|
|
|
HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
|
|
HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_eeepc_ep20_mixer[] = {
|
|
ALC262_HIPPO_MASTER_SWITCH,
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
|
|
HDA_BIND_MUTE("MuteCtrl Playback Switch", 0x0c, 2, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_bind_master_vol = {
|
|
.ops = &snd_hda_bind_vol,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x03, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_one_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_m51va_mixer[] = {
|
|
HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_one_bind_switch),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_tree_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_two_hp_m1_mixer[] = {
|
|
HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_tree_bind_switch),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_four_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_two_hp_m2_mixer[] = {
|
|
HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_four_bind_switch),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_1bjd_mixer[] = {
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_two_bind_master_vol = {
|
|
.ops = &snd_hda_bind_vol,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x04, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_two_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x16, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_asus_21jd_clfe_mixer[] = {
|
|
HDA_BIND_VOL("Master Playback Volume",
|
|
&alc663_asus_two_bind_master_vol),
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
|
|
HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_asus_15jd_clfe_mixer[] = {
|
|
HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
|
|
HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_g71v_mixer[] = {
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Front Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Front Playback Switch", 0x15, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_g50v_mixer[] = {
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_mode7_8_all_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct hda_bind_ctls alc663_asus_mode7_8_sp_bind_switch = {
|
|
.ops = &snd_hda_bind_sw,
|
|
.values = {
|
|
HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
|
|
HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
|
|
0
|
|
},
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_mode7_mixer[] = {
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
|
|
HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
|
|
HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("IntMic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("IntMic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc663_mode8_mixer[] = {
|
|
HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
|
|
HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
|
|
HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
|
|
HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x15, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
|
|
static const struct snd_kcontrol_new alc662_chmode_mixer[] = {
|
|
{
|
|
.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
|
|
.name = "Channel Mode",
|
|
.info = alc_ch_mode_info,
|
|
.get = alc_ch_mode_get,
|
|
.put = alc_ch_mode_put,
|
|
},
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct hda_verb alc662_init_verbs[] = {
|
|
/* ADC: mute amp left and right */
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
/* Front Pin: output 0 (0x0c) */
|
|
{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
/* Rear Pin: output 1 (0x0d) */
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
/* CLFE Pin: output 2 (0x0e) */
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
/* Mic (rear) pin: input vref at 80% */
|
|
{0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
|
|
{0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
/* Front Mic pin: input vref at 80% */
|
|
{0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
|
|
{0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
/* Line In pin: input */
|
|
{0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
/* Line-2 In: Headphone output (output 0 - 0x0c) */
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
/* CD pin widget for input */
|
|
{0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
/* FIXME: use matrix-type input source selection */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
|
|
/* Input mixer */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
{ }
|
|
};
|
|
|
|
static const struct hda_verb alc662_eapd_init_verbs[] = {
|
|
/* always trun on EAPD */
|
|
{0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
{0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
{ }
|
|
};
|
|
|
|
static const struct hda_verb alc662_sue_init_verbs[] = {
|
|
{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_FRONT_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc662_eeepc_sue_init_verbs[] = {
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
/* Set Unsolicited Event*/
|
|
static const struct hda_verb alc662_eeepc_ep20_sue_init_verbs[] = {
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_m51va_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_21jd_amic_init_verbs[] = {
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc662_1bjd_amic_init_verbs[] = {
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_15jd_amic_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_two_hp_amic_m1_init_verbs[] = {
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x0}, /* Headphone */
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x0}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_two_hp_amic_m2_init_verbs[] = {
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_g71v_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
/* {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, */
|
|
/* {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, */ /* Headphone */
|
|
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
|
|
|
|
{0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_FRONT_EVENT},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_g50v_init_verbs[] = {
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
|
|
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc662_ecs_init_verbs[] = {
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0x701f},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc272_dell_zm1_init_verbs[] = {
|
|
{0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc272_dell_init_verbs[] = {
|
|
{0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_mode7_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
|
|
{0x19, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct hda_verb alc663_mode8_init_verbs[] = {
|
|
{0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
|
|
{0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
|
|
{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
|
|
{}
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc662_auto_capture_mixer[] = {
|
|
HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc272_auto_capture_mixer[] = {
|
|
HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static void alc662_lenovo_101e_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
|
|
spec->autocfg.hp_pins[0] = 0x1b;
|
|
spec->autocfg.line_out_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[0] = 0x15;
|
|
spec->automute = 1;
|
|
spec->detect_line = 1;
|
|
spec->automute_lines = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_AMP;
|
|
}
|
|
|
|
static void alc662_eeepc_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
|
|
alc262_hippo1_setup(codec);
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
static void alc662_eeepc_ep20_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
|
|
spec->autocfg.hp_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[0] = 0x1b;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_AMP;
|
|
}
|
|
|
|
static void alc663_m51va_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute_mixer_nid[0] = 0x0c;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_MIXER;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x12;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode1 ******************************/
|
|
static void alc663_mode1_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute_mixer_nid[0] = 0x0c;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_MIXER;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode2 ******************************/
|
|
static void alc662_mode2_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x1b;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_PIN;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode3 ******************************/
|
|
static void alc663_mode3_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.hp_pins[0] = 0x15;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_PIN;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode4 ******************************/
|
|
static void alc663_mode4_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[1] = 0x16;
|
|
spec->automute_mixer_nid[0] = 0x0c;
|
|
spec->automute_mixer_nid[1] = 0x0e;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_MIXER;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode5 ******************************/
|
|
static void alc663_mode5_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x15;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[1] = 0x16;
|
|
spec->automute_mixer_nid[0] = 0x0c;
|
|
spec->automute_mixer_nid[1] = 0x0e;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_MIXER;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode6 ******************************/
|
|
static void alc663_mode6_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x1b;
|
|
spec->autocfg.hp_pins[0] = 0x15;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute_mixer_nid[0] = 0x0c;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_MIXER;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode7 ******************************/
|
|
static void alc663_mode7_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x1b;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[0] = 0x17;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_PIN;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x19;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
/* ***************** Mode8 ******************************/
|
|
static void alc663_mode8_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.hp_pins[1] = 0x15;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->autocfg.speaker_pins[0] = 0x17;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_PIN;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x12;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
static void alc663_g71v_setup(struct hda_codec *codec)
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->autocfg.hp_pins[0] = 0x21;
|
|
spec->autocfg.line_out_pins[0] = 0x15;
|
|
spec->autocfg.speaker_pins[0] = 0x14;
|
|
spec->automute = 1;
|
|
spec->automute_mode = ALC_AUTOMUTE_AMP;
|
|
spec->detect_line = 1;
|
|
spec->automute_lines = 1;
|
|
spec->ext_mic_pin = 0x18;
|
|
spec->int_mic_pin = 0x12;
|
|
spec->auto_mic = 1;
|
|
}
|
|
|
|
#define alc663_g50v_setup alc663_m51va_setup
|
|
|
|
static const struct snd_kcontrol_new alc662_ecs_mixer[] = {
|
|
HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
ALC262_HIPPO_MASTER_SWITCH,
|
|
|
|
HDA_CODEC_VOLUME("Mic/LineIn Boost Volume", 0x18, 0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic/LineIn Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic/LineIn Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
|
|
HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
static const struct snd_kcontrol_new alc272_nc10_mixer[] = {
|
|
/* Master Playback automatically created from Speaker and Headphone */
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
|
|
HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
|
|
|
|
HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
|
|
{ } /* end */
|
|
};
|
|
|
|
|
|
/*
|
|
* configuration and preset
|
|
*/
|
|
static const char * const alc662_models[ALC662_MODEL_LAST] = {
|
|
[ALC662_3ST_2ch_DIG] = "3stack-dig",
|
|
[ALC662_3ST_6ch_DIG] = "3stack-6ch-dig",
|
|
[ALC662_3ST_6ch] = "3stack-6ch",
|
|
[ALC662_5ST_DIG] = "5stack-dig",
|
|
[ALC662_LENOVO_101E] = "lenovo-101e",
|
|
[ALC662_ASUS_EEEPC_P701] = "eeepc-p701",
|
|
[ALC662_ASUS_EEEPC_EP20] = "eeepc-ep20",
|
|
[ALC662_ECS] = "ecs",
|
|
[ALC663_ASUS_M51VA] = "m51va",
|
|
[ALC663_ASUS_G71V] = "g71v",
|
|
[ALC663_ASUS_H13] = "h13",
|
|
[ALC663_ASUS_G50V] = "g50v",
|
|
[ALC663_ASUS_MODE1] = "asus-mode1",
|
|
[ALC662_ASUS_MODE2] = "asus-mode2",
|
|
[ALC663_ASUS_MODE3] = "asus-mode3",
|
|
[ALC663_ASUS_MODE4] = "asus-mode4",
|
|
[ALC663_ASUS_MODE5] = "asus-mode5",
|
|
[ALC663_ASUS_MODE6] = "asus-mode6",
|
|
[ALC663_ASUS_MODE7] = "asus-mode7",
|
|
[ALC663_ASUS_MODE8] = "asus-mode8",
|
|
[ALC272_DELL] = "dell",
|
|
[ALC272_DELL_ZM1] = "dell-zm1",
|
|
[ALC272_SAMSUNG_NC10] = "samsung-nc10",
|
|
[ALC662_AUTO] = "auto",
|
|
};
|
|
|
|
static const struct snd_pci_quirk alc662_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x1019, 0x9087, "ECS", ALC662_ECS),
|
|
SND_PCI_QUIRK(0x1028, 0x02d6, "DELL", ALC272_DELL),
|
|
SND_PCI_QUIRK(0x1028, 0x02f4, "DELL ZM1", ALC272_DELL_ZM1),
|
|
SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x11c3, "ASUS M70V", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1203, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1303, "ASUS G60J", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1333, "ASUS G60Jx", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1339, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x13e3, "ASUS N71JA", ALC663_ASUS_MODE7),
|
|
SND_PCI_QUIRK(0x1043, 0x1463, "ASUS N71", ALC663_ASUS_MODE7),
|
|
SND_PCI_QUIRK(0x1043, 0x14d3, "ASUS G72", ALC663_ASUS_MODE8),
|
|
SND_PCI_QUIRK(0x1043, 0x1563, "ASUS N90", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x15d3, "ASUS N50SF F50SF", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x16c3, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x16f3, "ASUS K40C K50C", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1733, "ASUS N81De", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1753, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1763, "ASUS NB", ALC663_ASUS_MODE6),
|
|
SND_PCI_QUIRK(0x1043, 0x1765, "ASUS NB", ALC663_ASUS_MODE6),
|
|
SND_PCI_QUIRK(0x1043, 0x1783, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1793, "ASUS F50GX", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x17b3, "ASUS F70SL", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x17c3, "ASUS UX20", ALC663_ASUS_M51VA),
|
|
SND_PCI_QUIRK(0x1043, 0x17f3, "ASUS X58LE", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1813, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1823, "ASUS NB", ALC663_ASUS_MODE5),
|
|
SND_PCI_QUIRK(0x1043, 0x1833, "ASUS NB", ALC663_ASUS_MODE6),
|
|
SND_PCI_QUIRK(0x1043, 0x1843, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1853, "ASUS F50Z", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1864, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1876, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M51VA", ALC663_ASUS_M51VA),
|
|
/*SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M50Vr", ALC663_ASUS_MODE1),*/
|
|
SND_PCI_QUIRK(0x1043, 0x1893, "ASUS M50Vm", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x1894, "ASUS X55", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x18b3, "ASUS N80Vc", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x18c3, "ASUS VX5", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x18d3, "ASUS N81Te", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x18f3, "ASUS N505Tp", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1903, "ASUS F5GL", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1913, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1933, "ASUS F80Q", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x1943, "ASUS Vx3V", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1953, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1963, "ASUS X71C", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x1983, "ASUS N5051A", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1993, "ASUS N20", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS G50V", ALC663_ASUS_G50V),
|
|
/*SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS NB", ALC663_ASUS_MODE1),*/
|
|
SND_PCI_QUIRK(0x1043, 0x19b3, "ASUS F7Z", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x19c3, "ASUS F5Z/F6x", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x19d3, "ASUS NB", ALC663_ASUS_M51VA),
|
|
SND_PCI_QUIRK(0x1043, 0x19e3, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x19f3, "ASUS NB", ALC663_ASUS_MODE4),
|
|
SND_PCI_QUIRK(0x1043, 0x8290, "ASUS P5GC-MX", ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK(0x1043, 0x82a1, "ASUS Eeepc", ALC662_ASUS_EEEPC_P701),
|
|
SND_PCI_QUIRK(0x1043, 0x82d1, "ASUS Eeepc EP20", ALC662_ASUS_EEEPC_EP20),
|
|
SND_PCI_QUIRK(0x105b, 0x0cd6, "Foxconn", ALC662_ECS),
|
|
SND_PCI_QUIRK(0x105b, 0x0d47, "Foxconn 45CMX/45GMX/45CMX-K",
|
|
ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK(0x1179, 0xff6e, "Toshiba NB20x", ALC662_AUTO),
|
|
SND_PCI_QUIRK(0x144d, 0xca00, "Samsung NC10", ALC272_SAMSUNG_NC10),
|
|
SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
|
|
ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK(0x152d, 0x2304, "Quanta WH1", ALC663_ASUS_H13),
|
|
SND_PCI_QUIRK(0x1565, 0x820f, "Biostar TA780G M2+", ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK(0x1631, 0xc10c, "PB RS65", ALC663_ASUS_M51VA),
|
|
SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo", ALC662_LENOVO_101E),
|
|
SND_PCI_QUIRK(0x1849, 0x3662, "ASROCK K10N78FullHD-hSLI R3.0",
|
|
ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK_MASK(0x1854, 0xf000, 0x2000, "ASUS H13-200x",
|
|
ALC663_ASUS_H13),
|
|
SND_PCI_QUIRK(0x1991, 0x5628, "Ordissimo EVE", ALC662_LENOVO_101E),
|
|
{}
|
|
};
|
|
|
|
static const struct alc_config_preset alc662_presets[] = {
|
|
[ALC662_3ST_2ch_DIG] = {
|
|
.mixers = { alc662_3ST_2ch_mixer },
|
|
.init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.dig_in_nid = ALC662_DIGIN_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.input_mux = &alc662_capture_source,
|
|
},
|
|
[ALC662_3ST_6ch_DIG] = {
|
|
.mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
|
|
.init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.dig_in_nid = ALC662_DIGIN_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
|
|
.channel_mode = alc662_3ST_6ch_modes,
|
|
.need_dac_fix = 1,
|
|
.input_mux = &alc662_capture_source,
|
|
},
|
|
[ALC662_3ST_6ch] = {
|
|
.mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
|
|
.init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
|
|
.channel_mode = alc662_3ST_6ch_modes,
|
|
.need_dac_fix = 1,
|
|
.input_mux = &alc662_capture_source,
|
|
},
|
|
[ALC662_5ST_DIG] = {
|
|
.mixers = { alc662_base_mixer, alc662_chmode_mixer },
|
|
.init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.dig_in_nid = ALC662_DIGIN_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_5stack_modes),
|
|
.channel_mode = alc662_5stack_modes,
|
|
.input_mux = &alc662_capture_source,
|
|
},
|
|
[ALC662_LENOVO_101E] = {
|
|
.mixers = { alc662_lenovo_101e_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc662_sue_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.input_mux = &alc662_lenovo_101e_capture_source,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc662_lenovo_101e_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC662_ASUS_EEEPC_P701] = {
|
|
.mixers = { alc662_eeepc_p701_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc662_eeepc_sue_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc662_eeepc_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC662_ASUS_EEEPC_EP20] = {
|
|
.mixers = { alc662_eeepc_ep20_mixer,
|
|
alc662_chmode_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc662_eeepc_ep20_sue_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
|
|
.channel_mode = alc662_3ST_6ch_modes,
|
|
.input_mux = &alc662_lenovo_101e_capture_source,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc662_eeepc_ep20_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC662_ECS] = {
|
|
.mixers = { alc662_ecs_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc662_ecs_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc662_eeepc_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_M51VA] = {
|
|
.mixers = { alc663_m51va_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_m51va_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_m51va_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_G71V] = {
|
|
.mixers = { alc663_g71v_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_g71v_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_g71v_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_H13] = {
|
|
.mixers = { alc663_m51va_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_m51va_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.setup = alc663_m51va_setup,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_G50V] = {
|
|
.mixers = { alc663_g50v_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_g50v_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
|
|
.channel_mode = alc662_3ST_6ch_modes,
|
|
.input_mux = &alc663_capture_source,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_g50v_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE1] = {
|
|
.mixers = { alc663_m51va_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_21jd_amic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode1_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC662_ASUS_MODE2] = {
|
|
.mixers = { alc662_1bjd_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc662_1bjd_amic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc662_mode2_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE3] = {
|
|
.mixers = { alc663_two_hp_m1_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_two_hp_amic_m1_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode3_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE4] = {
|
|
.mixers = { alc663_asus_21jd_clfe_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_21jd_amic_init_verbs},
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode4_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE5] = {
|
|
.mixers = { alc663_asus_15jd_clfe_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_15jd_amic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode5_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE6] = {
|
|
.mixers = { alc663_two_hp_m2_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_two_hp_amic_m2_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode6_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE7] = {
|
|
.mixers = { alc663_mode7_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_mode7_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode7_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC663_ASUS_MODE8] = {
|
|
.mixers = { alc663_mode8_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_mode8_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc662_dac_nids),
|
|
.hp_nid = 0x03,
|
|
.dac_nids = alc662_dac_nids,
|
|
.dig_out_nid = ALC662_DIGOUT_NID,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode8_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC272_DELL] = {
|
|
.mixers = { alc663_m51va_mixer },
|
|
.cap_mixer = alc272_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc272_dell_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc272_dac_nids),
|
|
.dac_nids = alc272_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.adc_nids = alc272_adc_nids,
|
|
.num_adc_nids = ARRAY_SIZE(alc272_adc_nids),
|
|
.capsrc_nids = alc272_capsrc_nids,
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_m51va_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC272_DELL_ZM1] = {
|
|
.mixers = { alc663_m51va_mixer },
|
|
.cap_mixer = alc662_auto_capture_mixer,
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc272_dell_zm1_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc272_dac_nids),
|
|
.dac_nids = alc272_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.adc_nids = alc662_adc_nids,
|
|
.num_adc_nids = 1,
|
|
.capsrc_nids = alc662_capsrc_nids,
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_m51va_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
[ALC272_SAMSUNG_NC10] = {
|
|
.mixers = { alc272_nc10_mixer },
|
|
.init_verbs = { alc662_init_verbs,
|
|
alc662_eapd_init_verbs,
|
|
alc663_21jd_amic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc272_dac_nids),
|
|
.dac_nids = alc272_dac_nids,
|
|
.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
|
|
.channel_mode = alc662_3ST_2ch_modes,
|
|
/*.input_mux = &alc272_nc10_capture_source,*/
|
|
.unsol_event = alc_sku_unsol_event,
|
|
.setup = alc663_mode4_setup,
|
|
.init_hook = alc_inithook,
|
|
},
|
|
};
|
|
|
|
|