Merge branch 'akpm'
[linux-2.6/next.git] / sound / pci / hda / alc262_quirks.c
blobc37e0c2939b639463bda169ebd79cf4d06d45f78
1 /*
2 * ALC262 quirk models
3 * included by patch_realtek.c
4 */
6 /* ALC262 models */
7 enum {
8 ALC262_AUTO,
9 ALC262_BASIC,
10 ALC262_HIPPO,
11 ALC262_HIPPO_1,
12 ALC262_FUJITSU,
13 ALC262_BENQ_ED8,
14 ALC262_BENQ_T31,
15 ALC262_ULTRA,
16 ALC262_LENOVO_3000,
17 ALC262_NEC,
18 ALC262_TOSHIBA_S06,
19 ALC262_TOSHIBA_RX1,
20 ALC262_TYAN,
21 ALC262_MODEL_LAST /* last tag */
24 #define ALC262_DIGOUT_NID ALC880_DIGOUT_NID
25 #define ALC262_DIGIN_NID ALC880_DIGIN_NID
27 #define alc262_dac_nids alc260_dac_nids
28 #define alc262_adc_nids alc882_adc_nids
29 #define alc262_adc_nids_alt alc882_adc_nids_alt
30 #define alc262_capsrc_nids alc882_capsrc_nids
31 #define alc262_capsrc_nids_alt alc882_capsrc_nids_alt
33 #define alc262_modes alc260_modes
34 #define alc262_capture_source alc882_capture_source
36 static const hda_nid_t alc262_dmic_adc_nids[1] = {
37 /* ADC0 */
38 0x09
41 static const hda_nid_t alc262_dmic_capsrc_nids[1] = { 0x22 };
43 static const struct snd_kcontrol_new alc262_base_mixer[] = {
44 HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
45 HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
46 HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
47 HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
48 HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
49 HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
50 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
51 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
52 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
53 HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
54 HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
55 HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
56 HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),
57 HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
58 HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
59 HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
60 { } /* end */
63 /* bind hp and internal speaker mute (with plug check) as master switch */
64 static void alc262_hippo_master_update(struct hda_codec *codec)
66 update_speakers(codec);
69 static int alc262_hippo_master_sw_get(struct snd_kcontrol *kcontrol,
70 struct snd_ctl_elem_value *ucontrol)
72 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
73 struct alc_spec *spec = codec->spec;
74 *ucontrol->value.integer.value = !spec->master_mute;
75 return 0;
78 static int alc262_hippo_master_sw_put(struct snd_kcontrol *kcontrol,
79 struct snd_ctl_elem_value *ucontrol)
81 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
82 struct alc_spec *spec = codec->spec;
83 int val = !*ucontrol->value.integer.value;
85 if (val == spec->master_mute)
86 return 0;
87 spec->master_mute = val;
88 alc262_hippo_master_update(codec);
89 return 1;
92 #define ALC262_HIPPO_MASTER_SWITCH \
93 { \
94 .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
95 .name = "Master Playback Switch", \
96 .info = snd_ctl_boolean_mono_info, \
97 .get = alc262_hippo_master_sw_get, \
98 .put = alc262_hippo_master_sw_put, \
99 }, \
101 .iface = NID_MAPPING, \
102 .name = "Master Playback Switch", \
103 .subdevice = SUBDEV_HP(0) | (SUBDEV_LINE(0) << 8) | \
104 (SUBDEV_SPEAKER(0) << 16), \
107 #define alc262_hp_master_sw_get alc262_hippo_master_sw_get
108 #define alc262_hp_master_sw_put alc262_hippo_master_sw_put
110 static const struct snd_kcontrol_new alc262_hippo_mixer[] = {
111 ALC262_HIPPO_MASTER_SWITCH,
112 HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
113 HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
114 HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
115 HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
116 HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
117 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
118 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
119 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
120 HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
121 HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
122 HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
123 HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
124 { } /* end */
127 static const struct snd_kcontrol_new alc262_hippo1_mixer[] = {
128 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
129 ALC262_HIPPO_MASTER_SWITCH,
130 HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
131 HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
132 HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
133 HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
134 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
135 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
136 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
137 HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
138 HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
139 HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
140 { } /* end */
143 /* mute/unmute internal speaker according to the hp jack and mute state */
144 static void alc262_hippo_setup(struct hda_codec *codec)
146 struct alc_spec *spec = codec->spec;
148 spec->autocfg.hp_pins[0] = 0x15;
149 spec->autocfg.speaker_pins[0] = 0x14;
150 spec->automute = 1;
151 spec->automute_mode = ALC_AUTOMUTE_AMP;
154 static void alc262_hippo1_setup(struct hda_codec *codec)
156 struct alc_spec *spec = codec->spec;
158 spec->autocfg.hp_pins[0] = 0x1b;
159 spec->autocfg.speaker_pins[0] = 0x14;
160 spec->automute = 1;
161 spec->automute_mode = ALC_AUTOMUTE_AMP;
165 static const struct snd_kcontrol_new alc262_sony_mixer[] = {
166 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
167 ALC262_HIPPO_MASTER_SWITCH,
168 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
169 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
170 HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
171 HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
172 { } /* end */
175 static const struct snd_kcontrol_new alc262_benq_t31_mixer[] = {
176 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
177 ALC262_HIPPO_MASTER_SWITCH,
178 HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
179 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
180 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
181 HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
182 HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
183 { } /* end */
186 static const struct snd_kcontrol_new alc262_tyan_mixer[] = {
187 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
188 HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
189 HDA_CODEC_VOLUME("Aux Playback Volume", 0x0b, 0x06, HDA_INPUT),
190 HDA_CODEC_MUTE("Aux Playback Switch", 0x0b, 0x06, HDA_INPUT),
191 HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
192 HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
193 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
194 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
195 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
196 HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
197 HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
198 HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
199 { } /* end */
202 static const struct hda_verb alc262_tyan_verbs[] = {
203 /* Headphone automute */
204 {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
205 {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
206 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
208 /* P11 AUX_IN, white 4-pin connector */
209 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
210 {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_1, 0xe1},
211 {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_2, 0x93},
212 {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_3, 0x19},
217 /* unsolicited event for HP jack sensing */
218 static void alc262_tyan_setup(struct hda_codec *codec)
220 struct alc_spec *spec = codec->spec;
222 spec->autocfg.hp_pins[0] = 0x1b;
223 spec->autocfg.speaker_pins[0] = 0x15;
224 spec->automute = 1;
225 spec->automute_mode = ALC_AUTOMUTE_AMP;
229 #define alc262_capture_mixer alc882_capture_mixer
230 #define alc262_capture_alt_mixer alc882_capture_alt_mixer
233 * generic initialization of ADC, input mixers and output mixers
235 static const struct hda_verb alc262_init_verbs[] = {
237 * Unmute ADC0-2 and set the default input to mic-in
239 {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
240 {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
241 {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
242 {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
243 {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
244 {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
246 /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
247 * mixer widget
248 * Note: PASD motherboards uses the Line In 2 as the input for
249 * front panel mic (mic 2)
251 /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
252 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
253 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
254 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
255 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
256 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
259 * Set up output mixers (0x0c - 0x0e)
261 /* set vol=0 to output mixers */
262 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
263 {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
264 {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
265 /* set up input amps for analog loopback */
266 /* Amp Indices: DAC = 0, mixer = 1 */
267 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
268 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
269 {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
270 {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
271 {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
272 {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
274 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
275 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
276 {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
277 {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
278 {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
279 {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
281 {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
282 {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
283 {0x16, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
284 {0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
285 {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
287 {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
288 {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
290 /* FIXME: use matrix-type input source selection */
291 /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
292 /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
293 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
294 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
295 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
296 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
297 /* Input mixer2 */
298 {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
299 {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
300 {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
301 {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
302 /* Input mixer3 */
303 {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
304 {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
305 {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
306 {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
311 static const struct hda_verb alc262_eapd_verbs[] = {
312 {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
313 {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
317 static const struct hda_verb alc262_hippo1_unsol_verbs[] = {
318 {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
319 {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
320 {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
322 {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
323 {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
327 static const struct hda_verb alc262_sony_unsol_verbs[] = {
328 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
329 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
330 {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, // Front Mic
332 {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
333 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
337 static const struct snd_kcontrol_new alc262_toshiba_s06_mixer[] = {
338 HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
339 HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
340 HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
341 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
342 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
343 { } /* end */
346 static const struct hda_verb alc262_toshiba_s06_verbs[] = {
347 {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
348 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
349 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
350 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
351 {0x22, AC_VERB_SET_CONNECT_SEL, 0x09},
352 {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
353 {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
354 {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
358 static void alc262_toshiba_s06_setup(struct hda_codec *codec)
360 struct alc_spec *spec = codec->spec;
362 spec->autocfg.hp_pins[0] = 0x15;
363 spec->autocfg.speaker_pins[0] = 0x14;
364 spec->ext_mic_pin = 0x18;
365 spec->int_mic_pin = 0x12;
366 spec->auto_mic = 1;
367 spec->automute = 1;
368 spec->automute_mode = ALC_AUTOMUTE_PIN;
372 * nec model
373 * 0x15 = headphone
374 * 0x16 = internal speaker
375 * 0x18 = external mic
378 static const struct snd_kcontrol_new alc262_nec_mixer[] = {
379 HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
380 HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x16, 0, 0x0, HDA_OUTPUT),
382 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
383 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
384 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
386 HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
387 HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
388 { } /* end */
391 static const struct hda_verb alc262_nec_verbs[] = {
392 /* Unmute Speaker */
393 {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
395 /* Headphone */
396 {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
397 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
399 /* External mic to headphone */
400 {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
401 /* External mic to speaker */
402 {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
407 * fujitsu model
408 * 0x14 = headphone/spdif-out, 0x15 = internal speaker,
409 * 0x1b = port replicator headphone out
412 static const struct hda_verb alc262_fujitsu_unsol_verbs[] = {
413 {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
414 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
415 {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
416 {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
420 static const struct hda_verb alc262_lenovo_3000_unsol_verbs[] = {
421 {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
422 {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
426 static const struct hda_verb alc262_lenovo_3000_init_verbs[] = {
427 /* Front Mic pin: input vref at 50% */
428 {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
429 {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
433 static const struct hda_input_mux alc262_fujitsu_capture_source = {
434 .num_items = 3,
435 .items = {
436 { "Mic", 0x0 },
437 { "Internal Mic", 0x1 },
438 { "CD", 0x4 },
442 static void alc262_fujitsu_setup(struct hda_codec *codec)
444 struct alc_spec *spec = codec->spec;
446 spec->autocfg.hp_pins[0] = 0x14;
447 spec->autocfg.hp_pins[1] = 0x1b;
448 spec->autocfg.speaker_pins[0] = 0x15;
449 spec->automute = 1;
450 spec->automute_mode = ALC_AUTOMUTE_AMP;
453 /* bind volumes of both NID 0x0c and 0x0d */
454 static const struct hda_bind_ctls alc262_fujitsu_bind_master_vol = {
455 .ops = &snd_hda_bind_vol,
456 .values = {
457 HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT),
458 HDA_COMPOSE_AMP_VAL(0x0d, 3, 0, HDA_OUTPUT),
463 static const struct snd_kcontrol_new alc262_fujitsu_mixer[] = {
464 HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
466 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
467 .name = "Master Playback Switch",
468 .subdevice = HDA_SUBDEV_NID_FLAG | 0x14,
469 .info = snd_ctl_boolean_mono_info,
470 .get = alc262_hp_master_sw_get,
471 .put = alc262_hp_master_sw_put,
474 .iface = NID_MAPPING,
475 .name = "Master Playback Switch",
476 .private_value = 0x1b,
478 HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
479 HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
480 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
481 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
482 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
483 HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
484 HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
485 HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
486 { } /* end */
489 static void alc262_lenovo_3000_setup(struct hda_codec *codec)
491 struct alc_spec *spec = codec->spec;
493 spec->autocfg.hp_pins[0] = 0x1b;
494 spec->autocfg.speaker_pins[0] = 0x14;
495 spec->autocfg.speaker_pins[1] = 0x16;
496 spec->automute = 1;
497 spec->automute_mode = ALC_AUTOMUTE_AMP;
500 static const struct snd_kcontrol_new alc262_lenovo_3000_mixer[] = {
501 HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
503 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
504 .name = "Master Playback Switch",
505 .subdevice = HDA_SUBDEV_NID_FLAG | 0x1b,
506 .info = snd_ctl_boolean_mono_info,
507 .get = alc262_hp_master_sw_get,
508 .put = alc262_hp_master_sw_put,
510 HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
511 HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
512 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
513 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
514 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
515 HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
516 HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
517 HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
518 { } /* end */
521 static const struct snd_kcontrol_new alc262_toshiba_rx1_mixer[] = {
522 HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
523 ALC262_HIPPO_MASTER_SWITCH,
524 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
525 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
526 HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
527 HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
528 HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
529 HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
530 { } /* end */
533 /* additional init verbs for Benq laptops */
534 static const struct hda_verb alc262_EAPD_verbs[] = {
535 {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
536 {0x20, AC_VERB_SET_PROC_COEF, 0x3070},
540 static const struct hda_verb alc262_benq_t31_EAPD_verbs[] = {
541 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
542 {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
544 {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
545 {0x20, AC_VERB_SET_PROC_COEF, 0x3050},
549 /* Samsung Q1 Ultra Vista model setup */
550 static const struct snd_kcontrol_new alc262_ultra_mixer[] = {
551 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
552 HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
553 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
554 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
555 HDA_CODEC_VOLUME("Mic Boost Volume", 0x19, 0, HDA_INPUT),
556 HDA_CODEC_VOLUME("Headphone Mic Boost Volume", 0x15, 0, HDA_INPUT),
557 { } /* end */
560 static const struct hda_verb alc262_ultra_verbs[] = {
561 /* output mixer */
562 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
563 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
564 {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
565 /* speaker */
566 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
567 {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
568 {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
569 {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
570 /* HP */
571 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
572 {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
573 {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
574 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
575 {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
576 /* internal mic */
577 {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
578 {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
579 /* ADC, choose mic */
580 {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
581 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
582 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
583 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
584 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
585 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
586 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
587 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
588 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
589 {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(8)},
593 /* mute/unmute internal speaker according to the hp jack and mute state */
594 static void alc262_ultra_automute(struct hda_codec *codec)
596 struct alc_spec *spec = codec->spec;
597 unsigned int mute;
599 mute = 0;
600 /* auto-mute only when HP is used as HP */
601 if (!spec->cur_mux[0]) {
602 spec->jack_present = snd_hda_jack_detect(codec, 0x15);
603 if (spec->jack_present)
604 mute = HDA_AMP_MUTE;
606 /* mute/unmute internal speaker */
607 snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
608 HDA_AMP_MUTE, mute);
609 /* mute/unmute HP */
610 snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
611 HDA_AMP_MUTE, mute ? 0 : HDA_AMP_MUTE);
614 /* unsolicited event for HP jack sensing */
615 static void alc262_ultra_unsol_event(struct hda_codec *codec,
616 unsigned int res)
618 if ((res >> 26) != ALC_HP_EVENT)
619 return;
620 alc262_ultra_automute(codec);
623 static const struct hda_input_mux alc262_ultra_capture_source = {
624 .num_items = 2,
625 .items = {
626 { "Mic", 0x1 },
627 { "Headphone", 0x7 },
631 static int alc262_ultra_mux_enum_put(struct snd_kcontrol *kcontrol,
632 struct snd_ctl_elem_value *ucontrol)
634 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
635 struct alc_spec *spec = codec->spec;
636 int ret;
638 ret = alc_mux_enum_put(kcontrol, ucontrol);
639 if (!ret)
640 return 0;
641 /* reprogram the HP pin as mic or HP according to the input source */
642 snd_hda_codec_write_cache(codec, 0x15, 0,
643 AC_VERB_SET_PIN_WIDGET_CONTROL,
644 spec->cur_mux[0] ? PIN_VREF80 : PIN_HP);
645 alc262_ultra_automute(codec); /* mute/unmute HP */
646 return ret;
649 static const struct snd_kcontrol_new alc262_ultra_capture_mixer[] = {
650 HDA_CODEC_VOLUME("Capture Volume", 0x07, 0x0, HDA_INPUT),
651 HDA_CODEC_MUTE("Capture Switch", 0x07, 0x0, HDA_INPUT),
653 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
654 .name = "Capture Source",
655 .info = alc_mux_enum_info,
656 .get = alc_mux_enum_get,
657 .put = alc262_ultra_mux_enum_put,
660 .iface = NID_MAPPING,
661 .name = "Capture Source",
662 .private_value = 0x15,
664 { } /* end */
667 static const struct hda_verb alc262_toshiba_rx1_unsol_verbs[] = {
669 {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT }, /* Front Speaker */
670 {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
671 {0x14, AC_VERB_SET_CONNECT_SEL, 0x01},
673 {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* MIC jack */
674 {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* Front MIC */
675 {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
676 {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
678 {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP }, /* HP jack */
679 {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
680 {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
685 * configuration and preset
687 static const char * const alc262_models[ALC262_MODEL_LAST] = {
688 [ALC262_BASIC] = "basic",
689 [ALC262_HIPPO] = "hippo",
690 [ALC262_HIPPO_1] = "hippo_1",
691 [ALC262_FUJITSU] = "fujitsu",
692 [ALC262_BENQ_ED8] = "benq",
693 [ALC262_BENQ_T31] = "benq-t31",
694 [ALC262_TOSHIBA_S06] = "toshiba-s06",
695 [ALC262_TOSHIBA_RX1] = "toshiba-rx1",
696 [ALC262_ULTRA] = "ultra",
697 [ALC262_LENOVO_3000] = "lenovo-3000",
698 [ALC262_NEC] = "nec",
699 [ALC262_TYAN] = "tyan",
700 [ALC262_AUTO] = "auto",
703 static const struct snd_pci_quirk alc262_cfg_tbl[] = {
704 SND_PCI_QUIRK(0x1002, 0x437b, "Hippo", ALC262_HIPPO),
705 SND_PCI_QUIRK(0x1033, 0x8895, "NEC Versa S9100", ALC262_NEC),
706 SND_PCI_QUIRK(0x1179, 0x0001, "Toshiba dynabook SS RX1",
707 ALC262_TOSHIBA_RX1),
708 SND_PCI_QUIRK(0x1179, 0xff7b, "Toshiba S06", ALC262_TOSHIBA_S06),
709 SND_PCI_QUIRK(0x10cf, 0x1397, "Fujitsu", ALC262_FUJITSU),
710 SND_PCI_QUIRK(0x10cf, 0x142d, "Fujitsu Lifebook E8410", ALC262_FUJITSU),
711 SND_PCI_QUIRK(0x10f1, 0x2915, "Tyan Thunder n6650W", ALC262_TYAN),
712 SND_PCI_QUIRK_MASK(0x144d, 0xff00, 0xc032, "Samsung Q1",
713 ALC262_ULTRA),
714 SND_PCI_QUIRK(0x144d, 0xc510, "Samsung Q45", ALC262_HIPPO),
715 SND_PCI_QUIRK(0x17aa, 0x384e, "Lenovo 3000 y410", ALC262_LENOVO_3000),
716 SND_PCI_QUIRK(0x17ff, 0x0560, "Benq ED8", ALC262_BENQ_ED8),
717 SND_PCI_QUIRK(0x17ff, 0x058d, "Benq T31-16", ALC262_BENQ_T31),
718 SND_PCI_QUIRK(0x17ff, 0x058f, "Benq Hippo", ALC262_HIPPO_1),
722 static const struct alc_config_preset alc262_presets[] = {
723 [ALC262_BASIC] = {
724 .mixers = { alc262_base_mixer },
725 .init_verbs = { alc262_init_verbs },
726 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
727 .dac_nids = alc262_dac_nids,
728 .hp_nid = 0x03,
729 .num_channel_mode = ARRAY_SIZE(alc262_modes),
730 .channel_mode = alc262_modes,
731 .input_mux = &alc262_capture_source,
733 [ALC262_HIPPO] = {
734 .mixers = { alc262_hippo_mixer },
735 .init_verbs = { alc262_init_verbs, alc_hp15_unsol_verbs},
736 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
737 .dac_nids = alc262_dac_nids,
738 .hp_nid = 0x03,
739 .dig_out_nid = ALC262_DIGOUT_NID,
740 .num_channel_mode = ARRAY_SIZE(alc262_modes),
741 .channel_mode = alc262_modes,
742 .input_mux = &alc262_capture_source,
743 .unsol_event = alc_sku_unsol_event,
744 .setup = alc262_hippo_setup,
745 .init_hook = alc_inithook,
747 [ALC262_HIPPO_1] = {
748 .mixers = { alc262_hippo1_mixer },
749 .init_verbs = { alc262_init_verbs, alc262_hippo1_unsol_verbs},
750 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
751 .dac_nids = alc262_dac_nids,
752 .hp_nid = 0x02,
753 .dig_out_nid = ALC262_DIGOUT_NID,
754 .num_channel_mode = ARRAY_SIZE(alc262_modes),
755 .channel_mode = alc262_modes,
756 .input_mux = &alc262_capture_source,
757 .unsol_event = alc_sku_unsol_event,
758 .setup = alc262_hippo1_setup,
759 .init_hook = alc_inithook,
761 [ALC262_FUJITSU] = {
762 .mixers = { alc262_fujitsu_mixer },
763 .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
764 alc262_fujitsu_unsol_verbs },
765 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
766 .dac_nids = alc262_dac_nids,
767 .hp_nid = 0x03,
768 .dig_out_nid = ALC262_DIGOUT_NID,
769 .num_channel_mode = ARRAY_SIZE(alc262_modes),
770 .channel_mode = alc262_modes,
771 .input_mux = &alc262_fujitsu_capture_source,
772 .unsol_event = alc_sku_unsol_event,
773 .setup = alc262_fujitsu_setup,
774 .init_hook = alc_inithook,
776 [ALC262_BENQ_ED8] = {
777 .mixers = { alc262_base_mixer },
778 .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs },
779 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
780 .dac_nids = alc262_dac_nids,
781 .hp_nid = 0x03,
782 .num_channel_mode = ARRAY_SIZE(alc262_modes),
783 .channel_mode = alc262_modes,
784 .input_mux = &alc262_capture_source,
786 [ALC262_BENQ_T31] = {
787 .mixers = { alc262_benq_t31_mixer },
788 .init_verbs = { alc262_init_verbs, alc262_benq_t31_EAPD_verbs,
789 alc_hp15_unsol_verbs },
790 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
791 .dac_nids = alc262_dac_nids,
792 .hp_nid = 0x03,
793 .num_channel_mode = ARRAY_SIZE(alc262_modes),
794 .channel_mode = alc262_modes,
795 .input_mux = &alc262_capture_source,
796 .unsol_event = alc_sku_unsol_event,
797 .setup = alc262_hippo_setup,
798 .init_hook = alc_inithook,
800 [ALC262_ULTRA] = {
801 .mixers = { alc262_ultra_mixer },
802 .cap_mixer = alc262_ultra_capture_mixer,
803 .init_verbs = { alc262_ultra_verbs },
804 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
805 .dac_nids = alc262_dac_nids,
806 .num_channel_mode = ARRAY_SIZE(alc262_modes),
807 .channel_mode = alc262_modes,
808 .input_mux = &alc262_ultra_capture_source,
809 .adc_nids = alc262_adc_nids, /* ADC0 */
810 .capsrc_nids = alc262_capsrc_nids,
811 .num_adc_nids = 1, /* single ADC */
812 .unsol_event = alc262_ultra_unsol_event,
813 .init_hook = alc262_ultra_automute,
815 [ALC262_LENOVO_3000] = {
816 .mixers = { alc262_lenovo_3000_mixer },
817 .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
818 alc262_lenovo_3000_unsol_verbs,
819 alc262_lenovo_3000_init_verbs },
820 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
821 .dac_nids = alc262_dac_nids,
822 .hp_nid = 0x03,
823 .dig_out_nid = ALC262_DIGOUT_NID,
824 .num_channel_mode = ARRAY_SIZE(alc262_modes),
825 .channel_mode = alc262_modes,
826 .input_mux = &alc262_fujitsu_capture_source,
827 .unsol_event = alc_sku_unsol_event,
828 .setup = alc262_lenovo_3000_setup,
829 .init_hook = alc_inithook,
831 [ALC262_NEC] = {
832 .mixers = { alc262_nec_mixer },
833 .init_verbs = { alc262_nec_verbs },
834 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
835 .dac_nids = alc262_dac_nids,
836 .hp_nid = 0x03,
837 .num_channel_mode = ARRAY_SIZE(alc262_modes),
838 .channel_mode = alc262_modes,
839 .input_mux = &alc262_capture_source,
841 [ALC262_TOSHIBA_S06] = {
842 .mixers = { alc262_toshiba_s06_mixer },
843 .init_verbs = { alc262_init_verbs, alc262_toshiba_s06_verbs,
844 alc262_eapd_verbs },
845 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
846 .capsrc_nids = alc262_dmic_capsrc_nids,
847 .dac_nids = alc262_dac_nids,
848 .adc_nids = alc262_dmic_adc_nids, /* ADC0 */
849 .num_adc_nids = 1, /* single ADC */
850 .dig_out_nid = ALC262_DIGOUT_NID,
851 .num_channel_mode = ARRAY_SIZE(alc262_modes),
852 .channel_mode = alc262_modes,
853 .unsol_event = alc_sku_unsol_event,
854 .setup = alc262_toshiba_s06_setup,
855 .init_hook = alc_inithook,
857 [ALC262_TOSHIBA_RX1] = {
858 .mixers = { alc262_toshiba_rx1_mixer },
859 .init_verbs = { alc262_init_verbs, alc262_toshiba_rx1_unsol_verbs },
860 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
861 .dac_nids = alc262_dac_nids,
862 .hp_nid = 0x03,
863 .num_channel_mode = ARRAY_SIZE(alc262_modes),
864 .channel_mode = alc262_modes,
865 .input_mux = &alc262_capture_source,
866 .unsol_event = alc_sku_unsol_event,
867 .setup = alc262_hippo_setup,
868 .init_hook = alc_inithook,
870 [ALC262_TYAN] = {
871 .mixers = { alc262_tyan_mixer },
872 .init_verbs = { alc262_init_verbs, alc262_tyan_verbs},
873 .num_dacs = ARRAY_SIZE(alc262_dac_nids),
874 .dac_nids = alc262_dac_nids,
875 .hp_nid = 0x02,
876 .dig_out_nid = ALC262_DIGOUT_NID,
877 .num_channel_mode = ARRAY_SIZE(alc262_modes),
878 .channel_mode = alc262_modes,
879 .input_mux = &alc262_capture_source,
880 .unsol_event = alc_sku_unsol_event,
881 .setup = alc262_tyan_setup,
882 .init_hook = alc_hp_automute,