|
@@ -131,8 +131,10 @@ enum {
|
|
enum {
|
|
enum {
|
|
ALC269_BASIC,
|
|
ALC269_BASIC,
|
|
ALC269_QUANTA_FL1,
|
|
ALC269_QUANTA_FL1,
|
|
- ALC269_ASUS_AMIC,
|
|
|
|
- ALC269_ASUS_DMIC,
|
|
|
|
|
|
+ ALC269_AMIC,
|
|
|
|
+ ALC269_DMIC,
|
|
|
|
+ ALC269VB_AMIC,
|
|
|
|
+ ALC269VB_DMIC,
|
|
ALC269_FUJITSU,
|
|
ALC269_FUJITSU,
|
|
ALC269_LIFEBOOK,
|
|
ALC269_LIFEBOOK,
|
|
ALC269_AUTO,
|
|
ALC269_AUTO,
|
|
@@ -207,8 +209,10 @@ enum {
|
|
ALC882_ASUS_A7J,
|
|
ALC882_ASUS_A7J,
|
|
ALC882_ASUS_A7M,
|
|
ALC882_ASUS_A7M,
|
|
ALC885_MACPRO,
|
|
ALC885_MACPRO,
|
|
|
|
+ ALC885_MBA21,
|
|
ALC885_MBP3,
|
|
ALC885_MBP3,
|
|
ALC885_MB5,
|
|
ALC885_MB5,
|
|
|
|
+ ALC885_MACMINI3,
|
|
ALC885_IMAC24,
|
|
ALC885_IMAC24,
|
|
ALC885_IMAC91,
|
|
ALC885_IMAC91,
|
|
ALC883_3ST_2ch_DIG,
|
|
ALC883_3ST_2ch_DIG,
|
|
@@ -841,27 +845,6 @@ static void add_verb(struct alc_spec *spec, const struct hda_verb *verb)
|
|
spec->init_verbs[spec->num_init_verbs++] = verb;
|
|
spec->init_verbs[spec->num_init_verbs++] = verb;
|
|
}
|
|
}
|
|
|
|
|
|
-#ifdef CONFIG_PROC_FS
|
|
|
|
-/*
|
|
|
|
- * hook for proc
|
|
|
|
- */
|
|
|
|
-static void print_realtek_coef(struct snd_info_buffer *buffer,
|
|
|
|
- struct hda_codec *codec, hda_nid_t nid)
|
|
|
|
-{
|
|
|
|
- int coeff;
|
|
|
|
-
|
|
|
|
- if (nid != 0x20)
|
|
|
|
- return;
|
|
|
|
- coeff = snd_hda_codec_read(codec, nid, 0, AC_VERB_GET_PROC_COEF, 0);
|
|
|
|
- snd_iprintf(buffer, " Processing Coefficient: 0x%02x\n", coeff);
|
|
|
|
- coeff = snd_hda_codec_read(codec, nid, 0,
|
|
|
|
- AC_VERB_GET_COEF_INDEX, 0);
|
|
|
|
- snd_iprintf(buffer, " Coefficient Index: 0x%02x\n", coeff);
|
|
|
|
-}
|
|
|
|
-#else
|
|
|
|
-#define print_realtek_coef NULL
|
|
|
|
-#endif
|
|
|
|
-
|
|
|
|
/*
|
|
/*
|
|
* set up from the preset table
|
|
* set up from the preset table
|
|
*/
|
|
*/
|
|
@@ -1166,6 +1149,7 @@ static void alc_auto_init_amp(struct hda_codec *codec, int type)
|
|
case 0x10ec0888:
|
|
case 0x10ec0888:
|
|
alc888_coef_init(codec);
|
|
alc888_coef_init(codec);
|
|
break;
|
|
break;
|
|
|
|
+#if 0 /* XXX: This may cause the silent output on speaker on some machines */
|
|
case 0x10ec0267:
|
|
case 0x10ec0267:
|
|
case 0x10ec0268:
|
|
case 0x10ec0268:
|
|
snd_hda_codec_write(codec, 0x20, 0,
|
|
snd_hda_codec_write(codec, 0x20, 0,
|
|
@@ -1178,6 +1162,7 @@ static void alc_auto_init_amp(struct hda_codec *codec, int type)
|
|
AC_VERB_SET_PROC_COEF,
|
|
AC_VERB_SET_PROC_COEF,
|
|
tmp | 0x3000);
|
|
tmp | 0x3000);
|
|
break;
|
|
break;
|
|
|
|
+#endif /* XXX */
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
@@ -1269,7 +1254,7 @@ static void alc_init_auto_mic(struct hda_codec *codec)
|
|
*/
|
|
*/
|
|
static int alc_subsystem_id(struct hda_codec *codec,
|
|
static int alc_subsystem_id(struct hda_codec *codec,
|
|
hda_nid_t porta, hda_nid_t porte,
|
|
hda_nid_t porta, hda_nid_t porte,
|
|
- hda_nid_t portd)
|
|
|
|
|
|
+ hda_nid_t portd, hda_nid_t porti)
|
|
{
|
|
{
|
|
unsigned int ass, tmp, i;
|
|
unsigned int ass, tmp, i;
|
|
unsigned nid;
|
|
unsigned nid;
|
|
@@ -1295,7 +1280,7 @@ static int alc_subsystem_id(struct hda_codec *codec,
|
|
snd_printd("realtek: No valid SSID, "
|
|
snd_printd("realtek: No valid SSID, "
|
|
"checking pincfg 0x%08x for NID 0x%x\n",
|
|
"checking pincfg 0x%08x for NID 0x%x\n",
|
|
ass, nid);
|
|
ass, nid);
|
|
- if (!(ass & 1) && !(ass & 0x100000))
|
|
|
|
|
|
+ if (!(ass & 1))
|
|
return 0;
|
|
return 0;
|
|
if ((ass >> 30) != 1) /* no physical connection */
|
|
if ((ass >> 30) != 1) /* no physical connection */
|
|
return 0;
|
|
return 0;
|
|
@@ -1355,6 +1340,8 @@ do_sku:
|
|
nid = porte;
|
|
nid = porte;
|
|
else if (tmp == 2)
|
|
else if (tmp == 2)
|
|
nid = portd;
|
|
nid = portd;
|
|
|
|
+ else if (tmp == 3)
|
|
|
|
+ nid = porti;
|
|
else
|
|
else
|
|
return 1;
|
|
return 1;
|
|
for (i = 0; i < spec->autocfg.line_outs; i++)
|
|
for (i = 0; i < spec->autocfg.line_outs; i++)
|
|
@@ -1369,9 +1356,10 @@ do_sku:
|
|
}
|
|
}
|
|
|
|
|
|
static void alc_ssid_check(struct hda_codec *codec,
|
|
static void alc_ssid_check(struct hda_codec *codec,
|
|
- hda_nid_t porta, hda_nid_t porte, hda_nid_t portd)
|
|
|
|
|
|
+ hda_nid_t porta, hda_nid_t porte,
|
|
|
|
+ hda_nid_t portd, hda_nid_t porti)
|
|
{
|
|
{
|
|
- if (!alc_subsystem_id(codec, porta, porte, portd)) {
|
|
|
|
|
|
+ if (!alc_subsystem_id(codec, porta, porte, portd, porti)) {
|
|
struct alc_spec *spec = codec->spec;
|
|
struct alc_spec *spec = codec->spec;
|
|
snd_printd("realtek: "
|
|
snd_printd("realtek: "
|
|
"Enable default setup for auto mode as fallback\n");
|
|
"Enable default setup for auto mode as fallback\n");
|
|
@@ -3729,25 +3717,22 @@ static void alc_power_eapd(struct hda_codec *codec)
|
|
/* We currently only handle front, HP */
|
|
/* We currently only handle front, HP */
|
|
switch (codec->vendor_id) {
|
|
switch (codec->vendor_id) {
|
|
case 0x10ec0260:
|
|
case 0x10ec0260:
|
|
- snd_hda_codec_write(codec, 0x0f, 0,
|
|
|
|
- AC_VERB_SET_EAPD_BTLENABLE, 0x00);
|
|
|
|
- snd_hda_codec_write(codec, 0x10, 0,
|
|
|
|
- AC_VERB_SET_EAPD_BTLENABLE, 0x00);
|
|
|
|
|
|
+ set_eapd(codec, 0x0f, 0);
|
|
|
|
+ set_eapd(codec, 0x10, 0);
|
|
break;
|
|
break;
|
|
case 0x10ec0262:
|
|
case 0x10ec0262:
|
|
case 0x10ec0267:
|
|
case 0x10ec0267:
|
|
case 0x10ec0268:
|
|
case 0x10ec0268:
|
|
case 0x10ec0269:
|
|
case 0x10ec0269:
|
|
|
|
+ case 0x10ec0270:
|
|
case 0x10ec0272:
|
|
case 0x10ec0272:
|
|
case 0x10ec0660:
|
|
case 0x10ec0660:
|
|
case 0x10ec0662:
|
|
case 0x10ec0662:
|
|
case 0x10ec0663:
|
|
case 0x10ec0663:
|
|
case 0x10ec0862:
|
|
case 0x10ec0862:
|
|
case 0x10ec0889:
|
|
case 0x10ec0889:
|
|
- snd_hda_codec_write(codec, 0x14, 0,
|
|
|
|
- AC_VERB_SET_EAPD_BTLENABLE, 0x00);
|
|
|
|
- snd_hda_codec_write(codec, 0x15, 0,
|
|
|
|
- AC_VERB_SET_EAPD_BTLENABLE, 0x00);
|
|
|
|
|
|
+ set_eapd(codec, 0x14, 0);
|
|
|
|
+ set_eapd(codec, 0x15, 0);
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -4877,7 +4862,7 @@ static int alc880_parse_auto_config(struct hda_codec *codec)
|
|
spec->num_mux_defs = 1;
|
|
spec->num_mux_defs = 1;
|
|
spec->input_mux = &spec->private_imux[0];
|
|
spec->input_mux = &spec->private_imux[0];
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -5081,7 +5066,6 @@ static int patch_alc880(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc880_loopbacks;
|
|
spec->loopback.amplist = alc880_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -6412,7 +6396,7 @@ static int alc260_parse_auto_config(struct hda_codec *codec)
|
|
spec->num_mux_defs = 1;
|
|
spec->num_mux_defs = 1;
|
|
spec->input_mux = &spec->private_imux[0];
|
|
spec->input_mux = &spec->private_imux[0];
|
|
|
|
|
|
- alc_ssid_check(codec, 0x10, 0x15, 0x0f);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x10, 0x15, 0x0f, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -6691,7 +6675,6 @@ static int patch_alc260(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc260_loopbacks;
|
|
spec->loopback.amplist = alc260_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -6773,6 +6756,14 @@ static struct hda_input_mux mb5_capture_source = {
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct hda_input_mux macmini3_capture_source = {
|
|
|
|
+ .num_items = 2,
|
|
|
|
+ .items = {
|
|
|
|
+ { "Line", 0x2 },
|
|
|
|
+ { "CD", 0x4 },
|
|
|
|
+ },
|
|
|
|
+};
|
|
|
|
+
|
|
static struct hda_input_mux alc883_3stack_6ch_intel = {
|
|
static struct hda_input_mux alc883_3stack_6ch_intel = {
|
|
.num_items = 4,
|
|
.num_items = 4,
|
|
.items = {
|
|
.items = {
|
|
@@ -6961,6 +6952,13 @@ static struct hda_channel_mode alc882_sixstack_modes[2] = {
|
|
{ 8, alc882_sixstack_ch8_init },
|
|
{ 8, alc882_sixstack_ch8_init },
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+
|
|
|
|
+/* Macbook Air 2,1 */
|
|
|
|
+
|
|
|
|
+static struct hda_channel_mode alc885_mba21_ch_modes[1] = {
|
|
|
|
+ { 2, NULL },
|
|
|
|
+};
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* macbook pro ALC885 can switch LineIn to LineOut without losing Mic
|
|
* macbook pro ALC885 can switch LineIn to LineOut without losing Mic
|
|
*/
|
|
*/
|
|
@@ -7021,6 +7019,7 @@ static struct hda_channel_mode alc885_mb5_6ch_modes[2] = {
|
|
{ 6, alc885_mb5_ch6_init },
|
|
{ 6, alc885_mb5_ch6_init },
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+#define alc885_macmini3_6ch_modes alc885_mb5_6ch_modes
|
|
|
|
|
|
/*
|
|
/*
|
|
* 2ch mode
|
|
* 2ch mode
|
|
@@ -7232,6 +7231,15 @@ static struct snd_kcontrol_new alc882_base_mixer[] = {
|
|
{ } /* end */
|
|
{ } /* end */
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+/* Macbook Air 2,1 same control for HP and internal Speaker */
|
|
|
|
+
|
|
|
|
+static struct snd_kcontrol_new alc885_mba21_mixer[] = {
|
|
|
|
+ HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
|
|
+ HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 0x02, HDA_OUTPUT),
|
|
|
|
+ { }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+
|
|
static struct snd_kcontrol_new alc885_mbp3_mixer[] = {
|
|
static struct snd_kcontrol_new alc885_mbp3_mixer[] = {
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
HDA_BIND_MUTE ("Speaker Playback Switch", 0x0c, 0x02, HDA_INPUT),
|
|
HDA_BIND_MUTE ("Speaker Playback Switch", 0x0c, 0x02, HDA_INPUT),
|
|
@@ -7265,6 +7273,21 @@ static struct snd_kcontrol_new alc885_mb5_mixer[] = {
|
|
{ } /* end */
|
|
{ } /* end */
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct snd_kcontrol_new alc885_macmini3_mixer[] = {
|
|
|
|
+ HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
|
|
+ HDA_BIND_MUTE ("Front Playback Switch", 0x0c, 0x02, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x00, HDA_OUTPUT),
|
|
|
|
+ HDA_BIND_MUTE ("Surround Playback Switch", 0x0d, 0x02, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("LFE Playback Volume", 0x0e, 0x00, HDA_OUTPUT),
|
|
|
|
+ HDA_BIND_MUTE ("LFE Playback Switch", 0x0e, 0x02, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0f, 0x00, HDA_OUTPUT),
|
|
|
|
+ HDA_BIND_MUTE ("Headphone Playback Switch", 0x0f, 0x02, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x07, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_MUTE ("Line Playback Switch", 0x0b, 0x07, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Line Boost", 0x15, 0x00, HDA_INPUT),
|
|
|
|
+ { } /* end */
|
|
|
|
+};
|
|
|
|
+
|
|
static struct snd_kcontrol_new alc885_imac91_mixer[] = {
|
|
static struct snd_kcontrol_new alc885_imac91_mixer[] = {
|
|
HDA_CODEC_VOLUME("Line-Out Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Line-Out Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
|
|
HDA_BIND_MUTE ("Line-Out Playback Switch", 0x0c, 0x02, HDA_INPUT),
|
|
HDA_BIND_MUTE ("Line-Out Playback Switch", 0x0c, 0x02, HDA_INPUT),
|
|
@@ -7356,29 +7379,18 @@ static struct snd_kcontrol_new alc882_chmode_mixer[] = {
|
|
|
|
|
|
static struct hda_verb alc882_base_init_verbs[] = {
|
|
static struct hda_verb alc882_base_init_verbs[] = {
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
- {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
/* Rear mixer */
|
|
/* Rear mixer */
|
|
- {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
/* CLFE mixer */
|
|
/* CLFE mixer */
|
|
- {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
{0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
/* Side mixer */
|
|
/* Side mixer */
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
{0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
{0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
|
|
- /* mute analog input loopbacks */
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
-
|
|
|
|
/* Front Pin: output 0 (0x0c) */
|
|
/* Front Pin: output 0 (0x0c) */
|
|
{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
@@ -7415,14 +7427,8 @@ static struct hda_verb alc882_base_init_verbs[] = {
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
|
|
/* Input mixer2 */
|
|
/* Input mixer2 */
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
/* Input mixer3 */
|
|
/* Input mixer3 */
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
/* ADC2: mute amp left and right */
|
|
/* ADC2: mute amp left and right */
|
|
{0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
{0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
@@ -7466,26 +7472,17 @@ static struct hda_verb alc_hp15_unsol_verbs[] = {
|
|
|
|
|
|
static struct hda_verb alc885_init_verbs[] = {
|
|
static struct hda_verb alc885_init_verbs[] = {
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
- {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
/* Rear mixer */
|
|
/* Rear mixer */
|
|
- {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
|
|
+ {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
/* CLFE mixer */
|
|
/* CLFE mixer */
|
|
- {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
|
|
+ {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
/* Side mixer */
|
|
/* Side mixer */
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
-
|
|
|
|
- /* mute analog input loopbacks */
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
|
|
/* Front HP Pin: output 0 (0x0c) */
|
|
/* Front HP Pin: output 0 (0x0c) */
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
@@ -7519,17 +7516,11 @@ static struct hda_verb alc885_init_verbs[] = {
|
|
|
|
|
|
/* Mixer elements: 0x18, , 0x1a, 0x1b */
|
|
/* Mixer elements: 0x18, , 0x1a, 0x1b */
|
|
/* Input mixer1 */
|
|
/* Input mixer1 */
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
|
|
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
|
|
+ {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
/* Input mixer2 */
|
|
/* Input mixer2 */
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
/* Input mixer3 */
|
|
/* Input mixer3 */
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
|
|
+ {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
/* ADC2: mute amp left and right */
|
|
/* ADC2: mute amp left and right */
|
|
{0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
/* ADC3: mute amp left and right */
|
|
/* ADC3: mute amp left and right */
|
|
@@ -7671,6 +7662,76 @@ static struct hda_verb alc885_mb5_init_verbs[] = {
|
|
{ }
|
|
{ }
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+/* Macmini 3,1 */
|
|
|
|
+static struct hda_verb alc885_macmini3_init_verbs[] = {
|
|
|
|
+ /* DACs */
|
|
|
|
+ {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ /* Front mixer */
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
+ /* Surround mixer */
|
|
|
|
+ {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
+ {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
+ /* LFE mixer */
|
|
|
|
+ {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
+ {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
+ /* HP mixer */
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
+ /* Front Pin (0x0c) */
|
|
|
|
+ {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
|
|
|
|
+ {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
+ /* LFE Pin (0x0e) */
|
|
|
|
+ {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
|
|
|
|
+ {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x1a, AC_VERB_SET_CONNECT_SEL, 0x02},
|
|
|
|
+ /* HP Pin (0x0f) */
|
|
|
|
+ {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x14, AC_VERB_SET_CONNECT_SEL, 0x03},
|
|
|
|
+ {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
|
|
|
|
+ /* Line In pin */
|
|
|
|
+ {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+ {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
+
|
|
|
|
+ {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
+ {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
+ {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
+ {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
+ { }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+static struct hda_verb alc885_mba21_init_verbs[] = {
|
|
|
|
+ /*Internal and HP Speaker Mixer*/
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
+ /*Internal Speaker Pin (0x0c)*/
|
|
|
|
+ {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) },
|
|
|
|
+ {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
+ /* HP Pin: output 0 (0x0e) */
|
|
|
|
+ {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc4},
|
|
|
|
+ {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
+ {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, (ALC880_HP_EVENT | AC_USRSP_EN)},
|
|
|
|
+ /* Line in (is hp when jack connected)*/
|
|
|
|
+ {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, AC_PINCTL_VREF_50},
|
|
|
|
+ {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
+
|
|
|
|
+ { }
|
|
|
|
+ };
|
|
|
|
+
|
|
|
|
+
|
|
/* Macbook Pro rev3 */
|
|
/* Macbook Pro rev3 */
|
|
static struct hda_verb alc885_mbp3_init_verbs[] = {
|
|
static struct hda_verb alc885_mbp3_init_verbs[] = {
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
/* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
@@ -7833,54 +7894,35 @@ static void alc885_imac24_setup(struct hda_codec *codec)
|
|
spec->autocfg.speaker_pins[1] = 0x1a;
|
|
spec->autocfg.speaker_pins[1] = 0x1a;
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc885_mbp3_setup(struct hda_codec *codec)
|
|
|
|
-{
|
|
|
|
- struct alc_spec *spec = codec->spec;
|
|
|
|
-
|
|
|
|
- spec->autocfg.hp_pins[0] = 0x15;
|
|
|
|
- spec->autocfg.speaker_pins[0] = 0x14;
|
|
|
|
-}
|
|
|
|
|
|
+#define alc885_mb5_setup alc885_imac24_setup
|
|
|
|
+#define alc885_macmini3_setup alc885_imac24_setup
|
|
|
|
|
|
-static void alc885_mb5_automute(struct hda_codec *codec)
|
|
|
|
|
|
+/* Macbook Air 2,1 */
|
|
|
|
+static void alc885_mba21_setup(struct hda_codec *codec)
|
|
{
|
|
{
|
|
- unsigned int present;
|
|
|
|
-
|
|
|
|
- present = snd_hda_codec_read(codec, 0x14, 0,
|
|
|
|
- AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
|
|
|
- snd_hda_codec_amp_stereo(codec, 0x18, HDA_OUTPUT, 0,
|
|
|
|
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
|
|
|
|
- snd_hda_codec_amp_stereo(codec, 0x1a, HDA_OUTPUT, 0,
|
|
|
|
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
|
|
|
|
|
|
+ struct alc_spec *spec = codec->spec;
|
|
|
|
|
|
|
|
+ spec->autocfg.hp_pins[0] = 0x14;
|
|
|
|
+ spec->autocfg.speaker_pins[0] = 0x18;
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc885_mb5_unsol_event(struct hda_codec *codec,
|
|
|
|
- unsigned int res)
|
|
|
|
-{
|
|
|
|
- /* Headphone insertion or removal. */
|
|
|
|
- if ((res >> 26) == ALC880_HP_EVENT)
|
|
|
|
- alc885_mb5_automute(codec);
|
|
|
|
-}
|
|
|
|
|
|
|
|
-static void alc885_imac91_automute(struct hda_codec *codec)
|
|
|
|
-{
|
|
|
|
- unsigned int present;
|
|
|
|
|
|
|
|
- present = snd_hda_codec_read(codec, 0x14, 0,
|
|
|
|
- AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
|
|
|
|
- snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
|
|
|
|
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
|
|
|
|
- snd_hda_codec_amp_stereo(codec, 0x1a, HDA_OUTPUT, 0,
|
|
|
|
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
|
|
|
|
|
|
+static void alc885_mbp3_setup(struct hda_codec *codec)
|
|
|
|
+{
|
|
|
|
+ struct alc_spec *spec = codec->spec;
|
|
|
|
|
|
|
|
+ spec->autocfg.hp_pins[0] = 0x15;
|
|
|
|
+ spec->autocfg.speaker_pins[0] = 0x14;
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc885_imac91_unsol_event(struct hda_codec *codec,
|
|
|
|
- unsigned int res)
|
|
|
|
|
|
+static void alc885_imac91_setup(struct hda_codec *codec)
|
|
{
|
|
{
|
|
- /* Headphone insertion or removal. */
|
|
|
|
- if ((res >> 26) == ALC880_HP_EVENT)
|
|
|
|
- alc885_imac91_automute(codec);
|
|
|
|
|
|
+ struct alc_spec *spec = codec->spec;
|
|
|
|
+
|
|
|
|
+ spec->autocfg.hp_pins[0] = 0x14;
|
|
|
|
+ spec->autocfg.speaker_pins[0] = 0x15;
|
|
|
|
+ spec->autocfg.speaker_pins[1] = 0x1a;
|
|
}
|
|
}
|
|
|
|
|
|
static struct hda_verb alc882_targa_verbs[] = {
|
|
static struct hda_verb alc882_targa_verbs[] = {
|
|
@@ -8015,18 +8057,6 @@ static struct hda_verb alc883_auto_init_verbs[] = {
|
|
{0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
{0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
|
|
- /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
|
|
|
|
- * mixer widget
|
|
|
|
- * Note: PASD motherboards uses the Line In 2 as the input for
|
|
|
|
- * front panel mic (mic 2)
|
|
|
|
- */
|
|
|
|
- /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
-
|
|
|
|
/*
|
|
/*
|
|
* Set up output mixers (0x0c - 0x0f)
|
|
* Set up output mixers (0x0c - 0x0f)
|
|
*/
|
|
*/
|
|
@@ -8051,16 +8081,9 @@ static struct hda_verb alc883_auto_init_verbs[] = {
|
|
/* FIXME: use matrix-type input source selection */
|
|
/* FIXME: use matrix-type input source selection */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
|
|
/* Input mixer2 */
|
|
/* Input mixer2 */
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
|
|
|
|
- {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
|
|
|
|
|
|
+ {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
/* Input mixer3 */
|
|
/* Input mixer3 */
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
|
|
|
|
- {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
|
|
|
|
-
|
|
|
|
|
|
+ {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{ }
|
|
{ }
|
|
};
|
|
};
|
|
|
|
|
|
@@ -9047,6 +9070,8 @@ static const char *alc882_models[ALC882_MODEL_LAST] = {
|
|
[ALC882_ASUS_A7M] = "asus-a7m",
|
|
[ALC882_ASUS_A7M] = "asus-a7m",
|
|
[ALC885_MACPRO] = "macpro",
|
|
[ALC885_MACPRO] = "macpro",
|
|
[ALC885_MB5] = "mb5",
|
|
[ALC885_MB5] = "mb5",
|
|
|
|
+ [ALC885_MACMINI3] = "macmini3",
|
|
|
|
+ [ALC885_MBA21] = "mba21",
|
|
[ALC885_MBP3] = "mbp3",
|
|
[ALC885_MBP3] = "mbp3",
|
|
[ALC885_IMAC24] = "imac24",
|
|
[ALC885_IMAC24] = "imac24",
|
|
[ALC885_IMAC91] = "imac91",
|
|
[ALC885_IMAC91] = "imac91",
|
|
@@ -9230,6 +9255,7 @@ static struct snd_pci_quirk alc882_ssid_cfg_tbl[] = {
|
|
*/
|
|
*/
|
|
SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC885_MB5),
|
|
SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC885_MB5),
|
|
SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC885_MB5),
|
|
SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC885_MB5),
|
|
|
|
+ SND_PCI_QUIRK(0x106b, 0x4100, "Macmini 3,1", ALC885_MACMINI3),
|
|
{} /* terminator */
|
|
{} /* terminator */
|
|
};
|
|
};
|
|
|
|
|
|
@@ -9281,6 +9307,18 @@ static struct alc_config_preset alc882_presets[] = {
|
|
.input_mux = &alc882_capture_source,
|
|
.input_mux = &alc882_capture_source,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
},
|
|
},
|
|
|
|
+ [ALC885_MBA21] = {
|
|
|
|
+ .mixers = { alc885_mba21_mixer },
|
|
|
|
+ .init_verbs = { alc885_mba21_init_verbs, alc880_gpio1_init_verbs },
|
|
|
|
+ .num_dacs = 2,
|
|
|
|
+ .dac_nids = alc882_dac_nids,
|
|
|
|
+ .channel_mode = alc885_mba21_ch_modes,
|
|
|
|
+ .num_channel_mode = ARRAY_SIZE(alc885_mba21_ch_modes),
|
|
|
|
+ .input_mux = &alc882_capture_source,
|
|
|
|
+ .unsol_event = alc_automute_amp_unsol_event,
|
|
|
|
+ .setup = alc885_mba21_setup,
|
|
|
|
+ .init_hook = alc_automute_amp,
|
|
|
|
+ },
|
|
[ALC885_MBP3] = {
|
|
[ALC885_MBP3] = {
|
|
.mixers = { alc885_mbp3_mixer, alc882_chmode_mixer },
|
|
.mixers = { alc885_mbp3_mixer, alc882_chmode_mixer },
|
|
.init_verbs = { alc885_mbp3_init_verbs,
|
|
.init_verbs = { alc885_mbp3_init_verbs,
|
|
@@ -9308,8 +9346,24 @@ static struct alc_config_preset alc882_presets[] = {
|
|
.input_mux = &mb5_capture_source,
|
|
.input_mux = &mb5_capture_source,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
.dig_in_nid = ALC882_DIGIN_NID,
|
|
.dig_in_nid = ALC882_DIGIN_NID,
|
|
- .unsol_event = alc885_mb5_unsol_event,
|
|
|
|
- .init_hook = alc885_mb5_automute,
|
|
|
|
|
|
+ .unsol_event = alc_automute_amp_unsol_event,
|
|
|
|
+ .setup = alc885_mb5_setup,
|
|
|
|
+ .init_hook = alc_automute_amp,
|
|
|
|
+ },
|
|
|
|
+ [ALC885_MACMINI3] = {
|
|
|
|
+ .mixers = { alc885_macmini3_mixer, alc882_chmode_mixer },
|
|
|
|
+ .init_verbs = { alc885_macmini3_init_verbs,
|
|
|
|
+ alc880_gpio1_init_verbs },
|
|
|
|
+ .num_dacs = ARRAY_SIZE(alc882_dac_nids),
|
|
|
|
+ .dac_nids = alc882_dac_nids,
|
|
|
|
+ .channel_mode = alc885_macmini3_6ch_modes,
|
|
|
|
+ .num_channel_mode = ARRAY_SIZE(alc885_macmini3_6ch_modes),
|
|
|
|
+ .input_mux = &macmini3_capture_source,
|
|
|
|
+ .dig_out_nid = ALC882_DIGOUT_NID,
|
|
|
|
+ .dig_in_nid = ALC882_DIGIN_NID,
|
|
|
|
+ .unsol_event = alc_automute_amp_unsol_event,
|
|
|
|
+ .setup = alc885_macmini3_setup,
|
|
|
|
+ .init_hook = alc_automute_amp,
|
|
},
|
|
},
|
|
[ALC885_MACPRO] = {
|
|
[ALC885_MACPRO] = {
|
|
.mixers = { alc882_macpro_mixer },
|
|
.mixers = { alc882_macpro_mixer },
|
|
@@ -9348,8 +9402,9 @@ static struct alc_config_preset alc882_presets[] = {
|
|
.input_mux = &alc882_capture_source,
|
|
.input_mux = &alc882_capture_source,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
.dig_out_nid = ALC882_DIGOUT_NID,
|
|
.dig_in_nid = ALC882_DIGIN_NID,
|
|
.dig_in_nid = ALC882_DIGIN_NID,
|
|
- .unsol_event = alc885_imac91_unsol_event,
|
|
|
|
- .init_hook = alc885_imac91_automute,
|
|
|
|
|
|
+ .unsol_event = alc_automute_amp_unsol_event,
|
|
|
|
+ .setup = alc885_imac91_setup,
|
|
|
|
+ .init_hook = alc_automute_amp,
|
|
},
|
|
},
|
|
[ALC882_TARGA] = {
|
|
[ALC882_TARGA] = {
|
|
.mixers = { alc882_targa_mixer, alc882_chmode_mixer },
|
|
.mixers = { alc882_targa_mixer, alc882_chmode_mixer },
|
|
@@ -10172,7 +10227,7 @@ static int alc882_parse_auto_config(struct hda_codec *codec)
|
|
spec->num_mux_defs = 1;
|
|
spec->num_mux_defs = 1;
|
|
spec->input_mux = &spec->private_imux[0];
|
|
spec->input_mux = &spec->private_imux[0];
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
err = alc_auto_add_mic_boost(codec);
|
|
err = alc_auto_add_mic_boost(codec);
|
|
if (err < 0)
|
|
if (err < 0)
|
|
@@ -10310,7 +10365,6 @@ static int patch_alc882(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc882_loopbacks;
|
|
spec->loopback.amplist = alc882_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -11731,7 +11785,7 @@ static int alc262_parse_auto_config(struct hda_codec *codec)
|
|
if (err < 0)
|
|
if (err < 0)
|
|
return err;
|
|
return err;
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x14, 0x1b);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -12174,7 +12228,6 @@ static int patch_alc262(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc262_loopbacks;
|
|
spec->loopback.amplist = alc262_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -12683,7 +12736,6 @@ static int alc268_new_analog_output(struct alc_spec *spec, hda_nid_t nid,
|
|
dac = 0x02;
|
|
dac = 0x02;
|
|
break;
|
|
break;
|
|
case 0x15:
|
|
case 0x15:
|
|
- case 0x21:
|
|
|
|
dac = 0x03;
|
|
dac = 0x03;
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
@@ -12904,7 +12956,7 @@ static int alc268_parse_auto_config(struct hda_codec *codec)
|
|
if (err < 0)
|
|
if (err < 0)
|
|
return err;
|
|
return err;
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -13241,8 +13293,6 @@ static int patch_alc268(struct hda_codec *codec)
|
|
if (board_config == ALC268_AUTO)
|
|
if (board_config == ALC268_AUTO)
|
|
spec->init_hook = alc268_auto_init;
|
|
spec->init_hook = alc268_auto_init;
|
|
|
|
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
-
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -13262,6 +13312,15 @@ static hda_nid_t alc269_capsrc_nids[1] = {
|
|
0x23,
|
|
0x23,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static hda_nid_t alc269vb_adc_nids[1] = {
|
|
|
|
+ /* ADC1 */
|
|
|
|
+ 0x09,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static hda_nid_t alc269vb_capsrc_nids[1] = {
|
|
|
|
+ 0x22,
|
|
|
|
+};
|
|
|
|
+
|
|
/* NOTE: ADC2 (0x07) is connected from a recording *MIXER* (0x24),
|
|
/* NOTE: ADC2 (0x07) is connected from a recording *MIXER* (0x24),
|
|
* not a mux!
|
|
* not a mux!
|
|
*/
|
|
*/
|
|
@@ -13330,7 +13389,7 @@ static struct snd_kcontrol_new alc269_lifebook_mixer[] = {
|
|
{ }
|
|
{ }
|
|
};
|
|
};
|
|
|
|
|
|
-static struct snd_kcontrol_new alc269_eeepc_mixer[] = {
|
|
|
|
|
|
+static struct snd_kcontrol_new alc269_laptop_mixer[] = {
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
|
|
HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
|
|
@@ -13338,16 +13397,47 @@ static struct snd_kcontrol_new alc269_eeepc_mixer[] = {
|
|
{ } /* end */
|
|
{ } /* end */
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct snd_kcontrol_new alc269vb_laptop_mixer[] = {
|
|
|
|
+ HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
|
|
|
|
+ HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
|
|
|
|
+ { } /* end */
|
|
|
|
+};
|
|
|
|
+
|
|
/* capture mixer elements */
|
|
/* capture mixer elements */
|
|
-static struct snd_kcontrol_new alc269_epc_capture_mixer[] = {
|
|
|
|
|
|
+static struct snd_kcontrol_new alc269_laptop_analog_capture_mixer[] = {
|
|
|
|
+ HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("IntMic Boost", 0x19, 0, HDA_INPUT),
|
|
|
|
+ { } /* end */
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct snd_kcontrol_new alc269_laptop_digital_capture_mixer[] = {
|
|
HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
|
|
HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
|
HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
|
{ } /* end */
|
|
{ } /* end */
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct snd_kcontrol_new alc269vb_laptop_analog_capture_mixer[] = {
|
|
|
|
+ HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("IntMic Boost", 0x19, 0, HDA_INPUT),
|
|
|
|
+ { } /* end */
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct snd_kcontrol_new alc269vb_laptop_digital_capture_mixer[] = {
|
|
|
|
+ HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
|
|
|
|
+ HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
|
|
|
|
+ { } /* end */
|
|
|
|
+};
|
|
|
|
+
|
|
/* FSC amilo */
|
|
/* FSC amilo */
|
|
-#define alc269_fujitsu_mixer alc269_eeepc_mixer
|
|
|
|
|
|
+#define alc269_fujitsu_mixer alc269_laptop_mixer
|
|
|
|
|
|
static struct hda_verb alc269_quanta_fl1_verbs[] = {
|
|
static struct hda_verb alc269_quanta_fl1_verbs[] = {
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
@@ -13490,7 +13580,7 @@ static void alc269_lifebook_init_hook(struct hda_codec *codec)
|
|
alc269_lifebook_mic_autoswitch(codec);
|
|
alc269_lifebook_mic_autoswitch(codec);
|
|
}
|
|
}
|
|
|
|
|
|
-static struct hda_verb alc269_eeepc_dmic_init_verbs[] = {
|
|
|
|
|
|
+static struct hda_verb alc269_laptop_dmic_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x23, AC_VERB_SET_CONNECT_SEL, 0x05},
|
|
{0x23, AC_VERB_SET_CONNECT_SEL, 0x05},
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
@@ -13501,7 +13591,7 @@ static struct hda_verb alc269_eeepc_dmic_init_verbs[] = {
|
|
{}
|
|
{}
|
|
};
|
|
};
|
|
|
|
|
|
-static struct hda_verb alc269_eeepc_amic_init_verbs[] = {
|
|
|
|
|
|
+static struct hda_verb alc269_laptop_amic_init_verbs[] = {
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x23, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x23, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
@@ -13511,6 +13601,28 @@ static struct hda_verb alc269_eeepc_amic_init_verbs[] = {
|
|
{}
|
|
{}
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct hda_verb alc269vb_laptop_dmic_init_verbs[] = {
|
|
|
|
+ {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
|
|
+ {0x22, AC_VERB_SET_CONNECT_SEL, 0x06},
|
|
|
|
+ {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
|
|
+ {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7019 | (0x00 << 8))},
|
|
|
|
+ {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+ {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
|
|
|
|
+ {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
|
|
|
|
+ {}
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct hda_verb alc269vb_laptop_amic_init_verbs[] = {
|
|
|
|
+ {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
|
|
+ {0x22, AC_VERB_SET_CONNECT_SEL, 0x01},
|
|
|
|
+ {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
|
|
|
|
+ {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7019 | (0x00 << 8))},
|
|
|
|
+ {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+ {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
|
|
|
|
+ {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
|
|
|
|
+ {}
|
|
|
|
+};
|
|
|
|
+
|
|
/* toggle speaker-output according to the hp-jack state */
|
|
/* toggle speaker-output according to the hp-jack state */
|
|
static void alc269_speaker_automute(struct hda_codec *codec)
|
|
static void alc269_speaker_automute(struct hda_codec *codec)
|
|
{
|
|
{
|
|
@@ -13528,7 +13640,7 @@ static void alc269_speaker_automute(struct hda_codec *codec)
|
|
}
|
|
}
|
|
|
|
|
|
/* unsolicited event for HP jack sensing */
|
|
/* unsolicited event for HP jack sensing */
|
|
-static void alc269_eeepc_unsol_event(struct hda_codec *codec,
|
|
|
|
|
|
+static void alc269_laptop_unsol_event(struct hda_codec *codec,
|
|
unsigned int res)
|
|
unsigned int res)
|
|
{
|
|
{
|
|
switch (res >> 26) {
|
|
switch (res >> 26) {
|
|
@@ -13541,7 +13653,7 @@ static void alc269_eeepc_unsol_event(struct hda_codec *codec,
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc269_eeepc_dmic_setup(struct hda_codec *codec)
|
|
|
|
|
|
+static void alc269_laptop_dmic_setup(struct hda_codec *codec)
|
|
{
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->ext_mic.pin = 0x18;
|
|
spec->ext_mic.pin = 0x18;
|
|
@@ -13551,7 +13663,17 @@ static void alc269_eeepc_dmic_setup(struct hda_codec *codec)
|
|
spec->auto_mic = 1;
|
|
spec->auto_mic = 1;
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc269_eeepc_amic_setup(struct hda_codec *codec)
|
|
|
|
|
|
+static void alc269vb_laptop_dmic_setup(struct hda_codec *codec)
|
|
|
|
+{
|
|
|
|
+ struct alc_spec *spec = codec->spec;
|
|
|
|
+ spec->ext_mic.pin = 0x18;
|
|
|
|
+ spec->ext_mic.mux_idx = 0;
|
|
|
|
+ spec->int_mic.pin = 0x12;
|
|
|
|
+ spec->int_mic.mux_idx = 6;
|
|
|
|
+ spec->auto_mic = 1;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static void alc269_laptop_amic_setup(struct hda_codec *codec)
|
|
{
|
|
{
|
|
struct alc_spec *spec = codec->spec;
|
|
struct alc_spec *spec = codec->spec;
|
|
spec->ext_mic.pin = 0x18;
|
|
spec->ext_mic.pin = 0x18;
|
|
@@ -13561,7 +13683,7 @@ static void alc269_eeepc_amic_setup(struct hda_codec *codec)
|
|
spec->auto_mic = 1;
|
|
spec->auto_mic = 1;
|
|
}
|
|
}
|
|
|
|
|
|
-static void alc269_eeepc_inithook(struct hda_codec *codec)
|
|
|
|
|
|
+static void alc269_laptop_inithook(struct hda_codec *codec)
|
|
{
|
|
{
|
|
alc269_speaker_automute(codec);
|
|
alc269_speaker_automute(codec);
|
|
alc_mic_automute(codec);
|
|
alc_mic_automute(codec);
|
|
@@ -13574,22 +13696,10 @@ static struct hda_verb alc269_init_verbs[] = {
|
|
/*
|
|
/*
|
|
* Unmute ADC0 and set the default input to mic-in
|
|
* Unmute ADC0 and set the default input to mic-in
|
|
*/
|
|
*/
|
|
- {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
-
|
|
|
|
- /* Mute input amps (PCBeep, Line In, Mic 1 & Mic 2) of the
|
|
|
|
- * analog-loopback mixer widget
|
|
|
|
- * Note: PASD motherboards uses the Line In 2 as the input for
|
|
|
|
- * front panel mic (mic 2)
|
|
|
|
- */
|
|
|
|
- /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
|
|
+ {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
|
|
/*
|
|
/*
|
|
- * Set up output mixers (0x0c - 0x0e)
|
|
|
|
|
|
+ * Set up output mixers (0x02 - 0x03)
|
|
*/
|
|
*/
|
|
/* set vol=0 to output mixers */
|
|
/* set vol=0 to output mixers */
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
{0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
@@ -13614,26 +13724,57 @@ static struct hda_verb alc269_init_verbs[] = {
|
|
|
|
|
|
{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
- {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
- {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
- {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
- {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
- {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
|
|
|
|
- {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
- {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
|
|
+ /* FIXME: use Mux-type input source selection */
|
|
|
|
+ /* Mixer elements: 0x18, 19, 1a, 1b, 1d, 0b */
|
|
|
|
+ /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
|
|
|
|
+ {0x23, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
|
|
- /* FIXME: use matrix-type input source selection */
|
|
|
|
|
|
+ /* set EAPD */
|
|
|
|
+ {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
|
|
+ { }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct hda_verb alc269vb_init_verbs[] = {
|
|
|
|
+ /*
|
|
|
|
+ * Unmute ADC0 and set the default input to mic-in
|
|
|
|
+ */
|
|
|
|
+ {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * Set up output mixers (0x02 - 0x03)
|
|
|
|
+ */
|
|
|
|
+ /* set vol=0 to output mixers */
|
|
|
|
+ {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+ {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
+
|
|
|
|
+ /* set up input amps for analog loopback */
|
|
|
|
+ /* Amp Indices: DAC = 0, mixer = 1 */
|
|
|
|
+ {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)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
+
|
|
|
|
+ {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
|
|
|
|
+ {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
|
|
|
|
+ {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
|
|
|
|
+ {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+ {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+
|
|
|
|
+ {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+
|
|
|
|
+ /* FIXME: use Mux-type input source selection */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1d, 0b */
|
|
/* Mixer elements: 0x18, 19, 1a, 1b, 1d, 0b */
|
|
/* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
|
|
/* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
|
|
+ {0x22, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
|
|
/* set EAPD */
|
|
/* set EAPD */
|
|
{0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
{0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
- {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
|
|
|
|
{ }
|
|
{ }
|
|
};
|
|
};
|
|
|
|
|
|
@@ -13681,6 +13822,7 @@ static int alc269_parse_auto_config(struct hda_codec *codec)
|
|
struct alc_spec *spec = codec->spec;
|
|
struct alc_spec *spec = codec->spec;
|
|
int err;
|
|
int err;
|
|
static hda_nid_t alc269_ignore[] = { 0x1d, 0 };
|
|
static hda_nid_t alc269_ignore[] = { 0x1d, 0 };
|
|
|
|
+ hda_nid_t real_capsrc_nids;
|
|
|
|
|
|
err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
|
|
err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
|
|
alc269_ignore);
|
|
alc269_ignore);
|
|
@@ -13702,11 +13844,20 @@ static int alc269_parse_auto_config(struct hda_codec *codec)
|
|
if (spec->kctls.list)
|
|
if (spec->kctls.list)
|
|
add_mixer(spec, spec->kctls.list);
|
|
add_mixer(spec, spec->kctls.list);
|
|
|
|
|
|
- add_verb(spec, alc269_init_verbs);
|
|
|
|
|
|
+ if ((alc_read_coef_idx(codec, 0) & 0x00f0) == 0x0010) {
|
|
|
|
+ add_verb(spec, alc269vb_init_verbs);
|
|
|
|
+ real_capsrc_nids = alc269vb_capsrc_nids[0];
|
|
|
|
+ alc_ssid_check(codec, 0, 0x1b, 0x14, 0x21);
|
|
|
|
+ } else {
|
|
|
|
+ add_verb(spec, alc269_init_verbs);
|
|
|
|
+ real_capsrc_nids = alc269_capsrc_nids[0];
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
+ }
|
|
|
|
+
|
|
spec->num_mux_defs = 1;
|
|
spec->num_mux_defs = 1;
|
|
spec->input_mux = &spec->private_imux[0];
|
|
spec->input_mux = &spec->private_imux[0];
|
|
/* set default input source */
|
|
/* set default input source */
|
|
- snd_hda_codec_write_cache(codec, alc269_capsrc_nids[0],
|
|
|
|
|
|
+ snd_hda_codec_write_cache(codec, real_capsrc_nids,
|
|
0, AC_VERB_SET_CONNECT_SEL,
|
|
0, AC_VERB_SET_CONNECT_SEL,
|
|
spec->input_mux->items[0].index);
|
|
spec->input_mux->items[0].index);
|
|
|
|
|
|
@@ -13717,8 +13868,6 @@ static int alc269_parse_auto_config(struct hda_codec *codec)
|
|
if (!spec->cap_mixer && !spec->no_analog)
|
|
if (!spec->cap_mixer && !spec->no_analog)
|
|
set_capture_mixer(codec);
|
|
set_capture_mixer(codec);
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
-
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -13744,8 +13893,8 @@ static void alc269_auto_init(struct hda_codec *codec)
|
|
static const char *alc269_models[ALC269_MODEL_LAST] = {
|
|
static const char *alc269_models[ALC269_MODEL_LAST] = {
|
|
[ALC269_BASIC] = "basic",
|
|
[ALC269_BASIC] = "basic",
|
|
[ALC269_QUANTA_FL1] = "quanta",
|
|
[ALC269_QUANTA_FL1] = "quanta",
|
|
- [ALC269_ASUS_AMIC] = "asus-amic",
|
|
|
|
- [ALC269_ASUS_DMIC] = "asus-dmic",
|
|
|
|
|
|
+ [ALC269_AMIC] = "laptop-amic",
|
|
|
|
+ [ALC269_DMIC] = "laptop-dmic",
|
|
[ALC269_FUJITSU] = "fujitsu",
|
|
[ALC269_FUJITSU] = "fujitsu",
|
|
[ALC269_LIFEBOOK] = "lifebook",
|
|
[ALC269_LIFEBOOK] = "lifebook",
|
|
[ALC269_AUTO] = "auto",
|
|
[ALC269_AUTO] = "auto",
|
|
@@ -13754,43 +13903,57 @@ static const char *alc269_models[ALC269_MODEL_LAST] = {
|
|
static struct snd_pci_quirk alc269_cfg_tbl[] = {
|
|
static struct snd_pci_quirk alc269_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_QUANTA_FL1),
|
|
SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_QUANTA_FL1),
|
|
SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A",
|
|
SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A",
|
|
- ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1133, "ASUS UJ20ft", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1273, "ASUS UL80JT", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1283, "ASUS U53Jc", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x12b3, "ASUS N82Jv", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x13a3, "ASUS UL30Vt", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1373, "ASUS G73JX", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1383, "ASUS UJ30Jc", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x13d3, "ASUS N61JA", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1413, "ASUS UL50", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1443, "ASUS UL30", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1453, "ASUS M60Jv", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1483, "ASUS UL80", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x14f3, "ASUS F83Vf", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x14e3, "ASUS UL20", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1513, "ASUS UX30", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x15a3, "ASUS N60Jv", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x15b3, "ASUS N60Dp", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x15c3, "ASUS N70De", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x15e3, "ASUS F83T", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1643, "ASUS M60J", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_ASUS_DMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_ASUS_AMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_ASUS_AMIC),
|
|
|
|
|
|
+ ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1013, "ASUS N61Da", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1113, "ASUS N63Jn", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1143, "ASUS B53f", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1133, "ASUS UJ20ft", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1183, "ASUS K72DR", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x11b3, "ASUS K52DR", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x11e3, "ASUS U33Jc", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1273, "ASUS UL80Jt", ALC269VB_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1283, "ASUS U53Jc", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x12b3, "ASUS N82Jv", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x12d3, "ASUS N61Jv", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x13a3, "ASUS UL30Vt", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1373, "ASUS G73JX", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1383, "ASUS UJ30Jc", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x13d3, "ASUS N61JA", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1413, "ASUS UL50", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1443, "ASUS UL30", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1453, "ASUS M60Jv", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1483, "ASUS UL80", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x14f3, "ASUS F83Vf", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x14e3, "ASUS UL20", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1513, "ASUS UX30", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1593, "ASUS N51Vn", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x15a3, "ASUS N60Jv", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x15b3, "ASUS N60Dp", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x15c3, "ASUS N70De", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x15e3, "ASUS F83T", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1643, "ASUS M60J", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_AMIC),
|
|
SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901",
|
|
SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901",
|
|
- ALC269_ASUS_DMIC),
|
|
|
|
|
|
+ ALC269_DMIC),
|
|
SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101",
|
|
SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101",
|
|
- ALC269_ASUS_DMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005HA", ALC269_ASUS_DMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005HA", ALC269_ASUS_DMIC),
|
|
|
|
- SND_PCI_QUIRK(0x1734, 0x115d, "FSC Amilo", ALC269_FUJITSU),
|
|
|
|
|
|
+ ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005HA", ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005HA", ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x104d, 0x9071, "SONY XTB", ALC269_DMIC),
|
|
SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK),
|
|
SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK),
|
|
|
|
+ SND_PCI_QUIRK(0x152d, 0x1778, "Quanta ON1", ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x1734, 0x115d, "FSC Amilo", ALC269_FUJITSU),
|
|
|
|
+ SND_PCI_QUIRK(0x17aa, 0x3be9, "Quanta Wistron", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_AMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x17ff, 0x059a, "Quanta EL3", ALC269_DMIC),
|
|
|
|
+ SND_PCI_QUIRK(0x17ff, 0x059b, "Quanta JR1", ALC269_DMIC),
|
|
{}
|
|
{}
|
|
};
|
|
};
|
|
|
|
|
|
@@ -13818,47 +13981,75 @@ static struct alc_config_preset alc269_presets[] = {
|
|
.setup = alc269_quanta_fl1_setup,
|
|
.setup = alc269_quanta_fl1_setup,
|
|
.init_hook = alc269_quanta_fl1_init_hook,
|
|
.init_hook = alc269_quanta_fl1_init_hook,
|
|
},
|
|
},
|
|
- [ALC269_ASUS_AMIC] = {
|
|
|
|
- .mixers = { alc269_eeepc_mixer },
|
|
|
|
- .cap_mixer = alc269_epc_capture_mixer,
|
|
|
|
|
|
+ [ALC269_AMIC] = {
|
|
|
|
+ .mixers = { alc269_laptop_mixer },
|
|
|
|
+ .cap_mixer = alc269_laptop_analog_capture_mixer,
|
|
.init_verbs = { alc269_init_verbs,
|
|
.init_verbs = { alc269_init_verbs,
|
|
- alc269_eeepc_amic_init_verbs },
|
|
|
|
|
|
+ alc269_laptop_amic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.dac_nids = alc269_dac_nids,
|
|
.dac_nids = alc269_dac_nids,
|
|
.hp_nid = 0x03,
|
|
.hp_nid = 0x03,
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.channel_mode = alc269_modes,
|
|
.channel_mode = alc269_modes,
|
|
- .unsol_event = alc269_eeepc_unsol_event,
|
|
|
|
- .setup = alc269_eeepc_amic_setup,
|
|
|
|
- .init_hook = alc269_eeepc_inithook,
|
|
|
|
|
|
+ .unsol_event = alc269_laptop_unsol_event,
|
|
|
|
+ .setup = alc269_laptop_amic_setup,
|
|
|
|
+ .init_hook = alc269_laptop_inithook,
|
|
},
|
|
},
|
|
- [ALC269_ASUS_DMIC] = {
|
|
|
|
- .mixers = { alc269_eeepc_mixer },
|
|
|
|
- .cap_mixer = alc269_epc_capture_mixer,
|
|
|
|
|
|
+ [ALC269_DMIC] = {
|
|
|
|
+ .mixers = { alc269_laptop_mixer },
|
|
|
|
+ .cap_mixer = alc269_laptop_digital_capture_mixer,
|
|
.init_verbs = { alc269_init_verbs,
|
|
.init_verbs = { alc269_init_verbs,
|
|
- alc269_eeepc_dmic_init_verbs },
|
|
|
|
|
|
+ alc269_laptop_dmic_init_verbs },
|
|
|
|
+ .num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
|
|
+ .dac_nids = alc269_dac_nids,
|
|
|
|
+ .hp_nid = 0x03,
|
|
|
|
+ .num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
|
|
+ .channel_mode = alc269_modes,
|
|
|
|
+ .unsol_event = alc269_laptop_unsol_event,
|
|
|
|
+ .setup = alc269_laptop_dmic_setup,
|
|
|
|
+ .init_hook = alc269_laptop_inithook,
|
|
|
|
+ },
|
|
|
|
+ [ALC269VB_AMIC] = {
|
|
|
|
+ .mixers = { alc269vb_laptop_mixer },
|
|
|
|
+ .cap_mixer = alc269vb_laptop_analog_capture_mixer,
|
|
|
|
+ .init_verbs = { alc269vb_init_verbs,
|
|
|
|
+ alc269vb_laptop_amic_init_verbs },
|
|
|
|
+ .num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
|
|
+ .dac_nids = alc269_dac_nids,
|
|
|
|
+ .hp_nid = 0x03,
|
|
|
|
+ .num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
|
|
+ .channel_mode = alc269_modes,
|
|
|
|
+ .unsol_event = alc269_laptop_unsol_event,
|
|
|
|
+ .setup = alc269_laptop_amic_setup,
|
|
|
|
+ .init_hook = alc269_laptop_inithook,
|
|
|
|
+ },
|
|
|
|
+ [ALC269VB_DMIC] = {
|
|
|
|
+ .mixers = { alc269vb_laptop_mixer },
|
|
|
|
+ .cap_mixer = alc269vb_laptop_digital_capture_mixer,
|
|
|
|
+ .init_verbs = { alc269vb_init_verbs,
|
|
|
|
+ alc269vb_laptop_dmic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.dac_nids = alc269_dac_nids,
|
|
.dac_nids = alc269_dac_nids,
|
|
.hp_nid = 0x03,
|
|
.hp_nid = 0x03,
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.channel_mode = alc269_modes,
|
|
.channel_mode = alc269_modes,
|
|
- .unsol_event = alc269_eeepc_unsol_event,
|
|
|
|
- .setup = alc269_eeepc_dmic_setup,
|
|
|
|
- .init_hook = alc269_eeepc_inithook,
|
|
|
|
|
|
+ .unsol_event = alc269_laptop_unsol_event,
|
|
|
|
+ .setup = alc269vb_laptop_dmic_setup,
|
|
|
|
+ .init_hook = alc269_laptop_inithook,
|
|
},
|
|
},
|
|
[ALC269_FUJITSU] = {
|
|
[ALC269_FUJITSU] = {
|
|
.mixers = { alc269_fujitsu_mixer },
|
|
.mixers = { alc269_fujitsu_mixer },
|
|
- .cap_mixer = alc269_epc_capture_mixer,
|
|
|
|
|
|
+ .cap_mixer = alc269_laptop_digital_capture_mixer,
|
|
.init_verbs = { alc269_init_verbs,
|
|
.init_verbs = { alc269_init_verbs,
|
|
- alc269_eeepc_dmic_init_verbs },
|
|
|
|
|
|
+ alc269_laptop_dmic_init_verbs },
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.num_dacs = ARRAY_SIZE(alc269_dac_nids),
|
|
.dac_nids = alc269_dac_nids,
|
|
.dac_nids = alc269_dac_nids,
|
|
.hp_nid = 0x03,
|
|
.hp_nid = 0x03,
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.num_channel_mode = ARRAY_SIZE(alc269_modes),
|
|
.channel_mode = alc269_modes,
|
|
.channel_mode = alc269_modes,
|
|
- .unsol_event = alc269_eeepc_unsol_event,
|
|
|
|
- .setup = alc269_eeepc_dmic_setup,
|
|
|
|
- .init_hook = alc269_eeepc_inithook,
|
|
|
|
|
|
+ .unsol_event = alc269_laptop_unsol_event,
|
|
|
|
+ .setup = alc269_laptop_dmic_setup,
|
|
|
|
+ .init_hook = alc269_laptop_inithook,
|
|
},
|
|
},
|
|
[ALC269_LIFEBOOK] = {
|
|
[ALC269_LIFEBOOK] = {
|
|
.mixers = { alc269_lifebook_mixer },
|
|
.mixers = { alc269_lifebook_mixer },
|
|
@@ -13879,6 +14070,7 @@ static int patch_alc269(struct hda_codec *codec)
|
|
struct alc_spec *spec;
|
|
struct alc_spec *spec;
|
|
int board_config;
|
|
int board_config;
|
|
int err;
|
|
int err;
|
|
|
|
+ int is_alc269vb = 0;
|
|
|
|
|
|
spec = kzalloc(sizeof(*spec), GFP_KERNEL);
|
|
spec = kzalloc(sizeof(*spec), GFP_KERNEL);
|
|
if (spec == NULL)
|
|
if (spec == NULL)
|
|
@@ -13895,6 +14087,7 @@ static int patch_alc269(struct hda_codec *codec)
|
|
alc_free(codec);
|
|
alc_free(codec);
|
|
return -ENOMEM;
|
|
return -ENOMEM;
|
|
}
|
|
}
|
|
|
|
+ is_alc269vb = 1;
|
|
}
|
|
}
|
|
|
|
|
|
board_config = snd_hda_check_board_config(codec, ALC269_MODEL_LAST,
|
|
board_config = snd_hda_check_board_config(codec, ALC269_MODEL_LAST,
|
|
@@ -13930,7 +14123,7 @@ static int patch_alc269(struct hda_codec *codec)
|
|
if (board_config != ALC269_AUTO)
|
|
if (board_config != ALC269_AUTO)
|
|
setup_preset(codec, &alc269_presets[board_config]);
|
|
setup_preset(codec, &alc269_presets[board_config]);
|
|
|
|
|
|
- if (codec->subsystem_id == 0x17aa3bf8) {
|
|
|
|
|
|
+ if (board_config == ALC269_QUANTA_FL1) {
|
|
/* Due to a hardware problem on Lenovo Ideadpad, we need to
|
|
/* Due to a hardware problem on Lenovo Ideadpad, we need to
|
|
* fix the sample rate of analog I/O to 44.1kHz
|
|
* fix the sample rate of analog I/O to 44.1kHz
|
|
*/
|
|
*/
|
|
@@ -13943,9 +14136,16 @@ static int patch_alc269(struct hda_codec *codec)
|
|
spec->stream_digital_playback = &alc269_pcm_digital_playback;
|
|
spec->stream_digital_playback = &alc269_pcm_digital_playback;
|
|
spec->stream_digital_capture = &alc269_pcm_digital_capture;
|
|
spec->stream_digital_capture = &alc269_pcm_digital_capture;
|
|
|
|
|
|
- spec->adc_nids = alc269_adc_nids;
|
|
|
|
- spec->num_adc_nids = ARRAY_SIZE(alc269_adc_nids);
|
|
|
|
- spec->capsrc_nids = alc269_capsrc_nids;
|
|
|
|
|
|
+ if (!is_alc269vb) {
|
|
|
|
+ spec->adc_nids = alc269_adc_nids;
|
|
|
|
+ spec->num_adc_nids = ARRAY_SIZE(alc269_adc_nids);
|
|
|
|
+ spec->capsrc_nids = alc269_capsrc_nids;
|
|
|
|
+ } else {
|
|
|
|
+ spec->adc_nids = alc269vb_adc_nids;
|
|
|
|
+ spec->num_adc_nids = ARRAY_SIZE(alc269vb_adc_nids);
|
|
|
|
+ spec->capsrc_nids = alc269vb_capsrc_nids;
|
|
|
|
+ }
|
|
|
|
+
|
|
if (!spec->cap_mixer)
|
|
if (!spec->cap_mixer)
|
|
set_capture_mixer(codec);
|
|
set_capture_mixer(codec);
|
|
set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
|
|
set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
|
|
@@ -13959,7 +14159,6 @@ static int patch_alc269(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc269_loopbacks;
|
|
spec->loopback.amplist = alc269_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -14822,7 +15021,7 @@ static int alc861_parse_auto_config(struct hda_codec *codec)
|
|
spec->num_adc_nids = ARRAY_SIZE(alc861_adc_nids);
|
|
spec->num_adc_nids = ARRAY_SIZE(alc861_adc_nids);
|
|
set_capture_mixer(codec);
|
|
set_capture_mixer(codec);
|
|
|
|
|
|
- alc_ssid_check(codec, 0x0e, 0x0f, 0x0b);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x0e, 0x0f, 0x0b, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -15087,7 +15286,6 @@ static int patch_alc861(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc861_loopbacks;
|
|
spec->loopback.amplist = alc861_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -15714,7 +15912,7 @@ static struct alc_config_preset alc861vd_presets[] = {
|
|
static int alc861vd_auto_create_input_ctls(struct hda_codec *codec,
|
|
static int alc861vd_auto_create_input_ctls(struct hda_codec *codec,
|
|
const struct auto_pin_cfg *cfg)
|
|
const struct auto_pin_cfg *cfg)
|
|
{
|
|
{
|
|
- return alc_auto_create_input_ctls(codec, cfg, 0x15, 0x22, 0);
|
|
|
|
|
|
+ return alc_auto_create_input_ctls(codec, cfg, 0x15, 0x09, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
@@ -15950,7 +16148,7 @@ static int alc861vd_parse_auto_config(struct hda_codec *codec)
|
|
if (err < 0)
|
|
if (err < 0)
|
|
return err;
|
|
return err;
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -16067,7 +16265,6 @@ static int patch_alc861vd(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc861vd_loopbacks;
|
|
spec->loopback.amplist = alc861vd_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -16534,13 +16731,6 @@ static struct hda_verb alc662_init_verbs[] = {
|
|
/* ADC: mute amp left and right */
|
|
/* ADC: mute amp left and right */
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
{0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
{0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
- /* Front mixer: unmute input/output amp left and right (volume = 0) */
|
|
|
|
-
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
|
|
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
@@ -16590,6 +16780,28 @@ static struct hda_verb alc662_init_verbs[] = {
|
|
{ }
|
|
{ }
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static struct hda_verb alc663_init_verbs[] = {
|
|
|
|
+ {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
+ { }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct hda_verb alc272_init_verbs[] = {
|
|
|
|
+ {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
|
|
+ {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
|
|
|
|
+ {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
|
|
|
|
+ {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
+ {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
+ { }
|
|
|
|
+};
|
|
|
|
+
|
|
static struct hda_verb alc662_sue_init_verbs[] = {
|
|
static struct hda_verb alc662_sue_init_verbs[] = {
|
|
{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_FRONT_EVENT},
|
|
{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_FRONT_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_HP_EVENT},
|
|
{0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_HP_EVENT},
|
|
@@ -16609,61 +16821,6 @@ static struct hda_verb alc662_eeepc_ep20_sue_init_verbs[] = {
|
|
{}
|
|
{}
|
|
};
|
|
};
|
|
|
|
|
|
-/*
|
|
|
|
- * generic initialization of ADC, input mixers and output mixers
|
|
|
|
- */
|
|
|
|
-static struct hda_verb alc662_auto_init_verbs[] = {
|
|
|
|
- /*
|
|
|
|
- * Unmute ADC and set the default input to mic-in
|
|
|
|
- */
|
|
|
|
- {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
|
|
|
|
- {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
-
|
|
|
|
- /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
|
|
|
|
- * mixer widget
|
|
|
|
- * Note: PASD motherboards uses the Line In 2 as the input for front
|
|
|
|
- * panel mic (mic 2)
|
|
|
|
- */
|
|
|
|
- /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
|
|
|
|
- {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
|
|
|
|
-
|
|
|
|
- /*
|
|
|
|
- * Set up output mixers (0x0c - 0x0f)
|
|
|
|
- */
|
|
|
|
- /* set vol=0 to output mixers */
|
|
|
|
- {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
- {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
|
|
|
|
-
|
|
|
|
- /* set up input amps for analog loopback */
|
|
|
|
- /* Amp Indices: DAC = 0, mixer = 1 */
|
|
|
|
- {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)},
|
|
|
|
-
|
|
|
|
-
|
|
|
|
- /* 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)},
|
|
|
|
- { }
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
-/* additional verbs for ALC663 */
|
|
|
|
-static struct hda_verb alc663_auto_init_verbs[] = {
|
|
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
|
|
|
|
- {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
|
|
|
|
- { }
|
|
|
|
-};
|
|
|
|
-
|
|
|
|
static struct hda_verb alc663_m51va_init_verbs[] = {
|
|
static struct hda_verb alc663_m51va_init_verbs[] = {
|
|
{0x15, 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},
|
|
{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
|
|
@@ -17414,6 +17571,7 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x1028, 0x02f4, "DELL ZM1", ALC272_DELL_ZM1),
|
|
SND_PCI_QUIRK(0x1028, 0x02f4, "DELL ZM1", ALC272_DELL_ZM1),
|
|
SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC663_ASUS_MODE3),
|
|
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, 0x11c3, "ASUS M70V", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2),
|
|
SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2),
|
|
@@ -17449,6 +17607,7 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x1043, 0x1893, "ASUS M50Vm", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x1893, "ASUS M50Vm", ALC663_ASUS_MODE3),
|
|
SND_PCI_QUIRK(0x1043, 0x1894, "ASUS X55", 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, 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, 0x18d3, "ASUS N81Te", ALC663_ASUS_MODE1),
|
|
SND_PCI_QUIRK(0x1043, 0x18f3, "ASUS N505Tp", 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, 0x1903, "ASUS F5GL", ALC663_ASUS_MODE1),
|
|
@@ -17476,6 +17635,7 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = {
|
|
SND_PCI_QUIRK(0x144d, 0xca00, "Samsung NC10", ALC272_SAMSUNG_NC10),
|
|
SND_PCI_QUIRK(0x144d, 0xca00, "Samsung NC10", ALC272_SAMSUNG_NC10),
|
|
SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
|
|
SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
|
|
ALC662_3ST_6ch_DIG),
|
|
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(0x1565, 0x820f, "Biostar TA780G M2+", ALC662_3ST_6ch_DIG),
|
|
SND_PCI_QUIRK(0x1631, 0xc10c, "PB RS65", ALC663_ASUS_M51VA),
|
|
SND_PCI_QUIRK(0x1631, 0xc10c, "PB RS65", ALC663_ASUS_M51VA),
|
|
SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo", ALC662_LENOVO_101E),
|
|
SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo", ALC662_LENOVO_101E),
|
|
@@ -18094,15 +18254,23 @@ static int alc662_parse_auto_config(struct hda_codec *codec)
|
|
spec->num_mux_defs = 1;
|
|
spec->num_mux_defs = 1;
|
|
spec->input_mux = &spec->private_imux[0];
|
|
spec->input_mux = &spec->private_imux[0];
|
|
|
|
|
|
- add_verb(spec, alc662_auto_init_verbs);
|
|
|
|
- if (codec->vendor_id == 0x10ec0663)
|
|
|
|
- add_verb(spec, alc663_auto_init_verbs);
|
|
|
|
|
|
+ add_verb(spec, alc662_init_verbs);
|
|
|
|
+ if (codec->vendor_id == 0x10ec0272 || codec->vendor_id == 0x10ec0663 ||
|
|
|
|
+ codec->vendor_id == 0x10ec0665)
|
|
|
|
+ add_verb(spec, alc663_init_verbs);
|
|
|
|
+
|
|
|
|
+ if (codec->vendor_id == 0x10ec0272)
|
|
|
|
+ add_verb(spec, alc272_init_verbs);
|
|
|
|
|
|
err = alc_auto_add_mic_boost(codec);
|
|
err = alc_auto_add_mic_boost(codec);
|
|
if (err < 0)
|
|
if (err < 0)
|
|
return err;
|
|
return err;
|
|
|
|
|
|
- alc_ssid_check(codec, 0x15, 0x1b, 0x14);
|
|
|
|
|
|
+ if (codec->vendor_id == 0x10ec0272 || codec->vendor_id == 0x10ec0663 ||
|
|
|
|
+ codec->vendor_id == 0x10ec0665 || codec->vendor_id == 0x10ec0670)
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0x21);
|
|
|
|
+ else
|
|
|
|
+ alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
|
|
|
|
|
|
return 1;
|
|
return 1;
|
|
}
|
|
}
|
|
@@ -18188,11 +18356,20 @@ static int patch_alc662(struct hda_codec *codec)
|
|
|
|
|
|
if (!spec->cap_mixer)
|
|
if (!spec->cap_mixer)
|
|
set_capture_mixer(codec);
|
|
set_capture_mixer(codec);
|
|
- if (codec->vendor_id == 0x10ec0662)
|
|
|
|
|
|
+
|
|
|
|
+ switch (codec->vendor_id) {
|
|
|
|
+ case 0x10ec0662:
|
|
set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
|
|
set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
|
|
- else
|
|
|
|
|
|
+ break;
|
|
|
|
+ case 0x10ec0272:
|
|
|
|
+ case 0x10ec0663:
|
|
|
|
+ case 0x10ec0665:
|
|
set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
|
|
set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
|
|
-
|
|
|
|
|
|
+ break;
|
|
|
|
+ case 0x10ec0273:
|
|
|
|
+ set_beep_amp(spec, 0x0b, 0x03, HDA_INPUT);
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
spec->vmaster_nid = 0x02;
|
|
spec->vmaster_nid = 0x02;
|
|
|
|
|
|
codec->patch_ops = alc_patch_ops;
|
|
codec->patch_ops = alc_patch_ops;
|
|
@@ -18202,7 +18379,6 @@ static int patch_alc662(struct hda_codec *codec)
|
|
if (!spec->loopback.amplist)
|
|
if (!spec->loopback.amplist)
|
|
spec->loopback.amplist = alc662_loopbacks;
|
|
spec->loopback.amplist = alc662_loopbacks;
|
|
#endif
|
|
#endif
|
|
- codec->proc_widget_hook = print_realtek_coef;
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
@@ -18243,6 +18419,8 @@ static struct hda_codec_preset snd_hda_preset_realtek[] = {
|
|
{ .id = 0x10ec0662, .rev = 0x100101, .name = "ALC662 rev1",
|
|
{ .id = 0x10ec0662, .rev = 0x100101, .name = "ALC662 rev1",
|
|
.patch = patch_alc662 },
|
|
.patch = patch_alc662 },
|
|
{ .id = 0x10ec0663, .name = "ALC663", .patch = patch_alc662 },
|
|
{ .id = 0x10ec0663, .name = "ALC663", .patch = patch_alc662 },
|
|
|
|
+ { .id = 0x10ec0665, .name = "ALC665", .patch = patch_alc662 },
|
|
|
|
+ { .id = 0x10ec0670, .name = "ALC670", .patch = patch_alc662 },
|
|
{ .id = 0x10ec0880, .name = "ALC880", .patch = patch_alc880 },
|
|
{ .id = 0x10ec0880, .name = "ALC880", .patch = patch_alc880 },
|
|
{ .id = 0x10ec0882, .name = "ALC882", .patch = patch_alc882 },
|
|
{ .id = 0x10ec0882, .name = "ALC882", .patch = patch_alc882 },
|
|
{ .id = 0x10ec0883, .name = "ALC883", .patch = patch_alc882 },
|
|
{ .id = 0x10ec0883, .name = "ALC883", .patch = patch_alc882 },
|