ALSA: hda - Remove dell, dell-zm1 and samsung-nc10 models for ALC272
[pandora-kernel.git] / sound / pci / hda / alc662_quirks.c
1 /*
2  * ALC662/ALC663/ALC665/ALC670 quirk models
3  * included by patch_realtek.c
4  */
5
6 /* ALC662 models */
7 enum {
8         ALC662_AUTO,
9         ALC662_3ST_2ch_DIG,
10         ALC662_3ST_6ch_DIG,
11         ALC662_3ST_6ch,
12         ALC662_5ST_DIG,
13         ALC662_LENOVO_101E,
14         ALC662_ASUS_EEEPC_P701,
15         ALC662_ASUS_EEEPC_EP20,
16         ALC663_ASUS_M51VA,
17         ALC663_ASUS_G71V,
18         ALC663_ASUS_H13,
19         ALC663_ASUS_G50V,
20         ALC662_ECS,
21         ALC663_ASUS_MODE1,
22         ALC662_ASUS_MODE2,
23         ALC663_ASUS_MODE3,
24         ALC663_ASUS_MODE4,
25         ALC663_ASUS_MODE5,
26         ALC663_ASUS_MODE6,
27         ALC663_ASUS_MODE7,
28         ALC663_ASUS_MODE8,
29         ALC662_MODEL_LAST,
30 };
31
32 #define ALC662_DIGOUT_NID       0x06
33 #define ALC662_DIGIN_NID        0x0a
34
35 static const hda_nid_t alc662_dac_nids[3] = {
36         /* front, rear, clfe */
37         0x02, 0x03, 0x04
38 };
39
40 static const hda_nid_t alc272_dac_nids[2] = {
41         0x02, 0x03
42 };
43
44 static const hda_nid_t alc662_adc_nids[2] = {
45         /* ADC1-2 */
46         0x09, 0x08
47 };
48
49 static const hda_nid_t alc272_adc_nids[1] = {
50         /* ADC1-2 */
51         0x08,
52 };
53
54 static const hda_nid_t alc662_capsrc_nids[2] = { 0x22, 0x23 };
55 static const hda_nid_t alc272_capsrc_nids[1] = { 0x23 };
56
57
58 /* input MUX */
59 /* FIXME: should be a matrix-type input source selection */
60 static const struct hda_input_mux alc662_capture_source = {
61         .num_items = 4,
62         .items = {
63                 { "Mic", 0x0 },
64                 { "Front Mic", 0x1 },
65                 { "Line", 0x2 },
66                 { "CD", 0x4 },
67         },
68 };
69
70 static const struct hda_input_mux alc662_lenovo_101e_capture_source = {
71         .num_items = 2,
72         .items = {
73                 { "Mic", 0x1 },
74                 { "Line", 0x2 },
75         },
76 };
77
78 static const struct hda_input_mux alc663_capture_source = {
79         .num_items = 3,
80         .items = {
81                 { "Mic", 0x0 },
82                 { "Front Mic", 0x1 },
83                 { "Line", 0x2 },
84         },
85 };
86
87 /*
88  * 2ch mode
89  */
90 static const struct hda_channel_mode alc662_3ST_2ch_modes[1] = {
91         { 2, NULL }
92 };
93
94 /*
95  * 2ch mode
96  */
97 static const struct hda_verb alc662_3ST_ch2_init[] = {
98         { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
99         { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
100         { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
101         { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
102         { } /* end */
103 };
104
105 /*
106  * 6ch mode
107  */
108 static const struct hda_verb alc662_3ST_ch6_init[] = {
109         { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
110         { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
111         { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
112         { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
113         { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
114         { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
115         { } /* end */
116 };
117
118 static const struct hda_channel_mode alc662_3ST_6ch_modes[2] = {
119         { 2, alc662_3ST_ch2_init },
120         { 6, alc662_3ST_ch6_init },
121 };
122
123 /*
124  * 2ch mode
125  */
126 static const struct hda_verb alc662_sixstack_ch6_init[] = {
127         { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
128         { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
129         { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
130         { } /* end */
131 };
132
133 /*
134  * 6ch mode
135  */
136 static const struct hda_verb alc662_sixstack_ch8_init[] = {
137         { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
138         { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
139         { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
140         { } /* end */
141 };
142
143 static const struct hda_channel_mode alc662_5stack_modes[2] = {
144         { 2, alc662_sixstack_ch6_init },
145         { 6, alc662_sixstack_ch8_init },
146 };
147
148 /* Pin assignment: Front=0x14, Rear=0x15, CLFE=0x16, Side=0x17
149  *                 Mic=0x18, Front Mic=0x19, Line-In=0x1a, HP=0x1b
150  */
151
152 static const struct snd_kcontrol_new alc662_base_mixer[] = {
153         /* output mixer control */
154         HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
155         HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
156         HDA_CODEC_VOLUME("Surround Playback Volume", 0x3, 0x0, HDA_OUTPUT),
157         HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
158         HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
159         HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
160         HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
161         HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
162         HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
163
164         /*Input mixer control */
165         HDA_CODEC_VOLUME("CD Playback Volume", 0xb, 0x4, HDA_INPUT),
166         HDA_CODEC_MUTE("CD Playback Switch", 0xb, 0x4, HDA_INPUT),
167         HDA_CODEC_VOLUME("Line Playback Volume", 0xb, 0x02, HDA_INPUT),
168         HDA_CODEC_MUTE("Line Playback Switch", 0xb, 0x02, HDA_INPUT),
169         HDA_CODEC_VOLUME("Mic Playback Volume", 0xb, 0x0, HDA_INPUT),
170         HDA_CODEC_MUTE("Mic Playback Switch", 0xb, 0x0, HDA_INPUT),
171         HDA_CODEC_VOLUME("Front Mic Playback Volume", 0xb, 0x01, HDA_INPUT),
172         HDA_CODEC_MUTE("Front Mic Playback Switch", 0xb, 0x01, HDA_INPUT),
173         { } /* end */
174 };
175
176 static const struct snd_kcontrol_new alc662_3ST_2ch_mixer[] = {
177         HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
178         HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
179         HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
180         HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
181         HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
182         HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
183         HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
184         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
185         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
186         HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
187         HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
188         { } /* end */
189 };
190
191 static const struct snd_kcontrol_new alc662_3ST_6ch_mixer[] = {
192         HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
193         HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
194         HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
195         HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
196         HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
197         HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
198         HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
199         HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
200         HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
201         HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
202         HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
203         HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
204         HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
205         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
206         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
207         HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
208         HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
209         { } /* end */
210 };
211
212 static const struct snd_kcontrol_new alc662_lenovo_101e_mixer[] = {
213         HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
214         HDA_BIND_MUTE("Front Playback Switch", 0x02, 2, HDA_INPUT),
215         HDA_CODEC_VOLUME("Speaker Playback Volume", 0x03, 0x0, HDA_OUTPUT),
216         HDA_BIND_MUTE("Speaker Playback Switch", 0x03, 2, HDA_INPUT),
217         HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
218         HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
219         HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
220         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
221         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
222         { } /* end */
223 };
224
225 static const struct snd_kcontrol_new alc662_eeepc_p701_mixer[] = {
226         HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
227         ALC262_HIPPO_MASTER_SWITCH,
228
229         HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
230         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
231         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
232
233         HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
234         HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
235         HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
236         { } /* end */
237 };
238
239 static const struct snd_kcontrol_new alc662_eeepc_ep20_mixer[] = {
240         ALC262_HIPPO_MASTER_SWITCH,
241         HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
242         HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
243         HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
244         HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
245         HDA_BIND_MUTE("MuteCtrl Playback Switch", 0x0c, 2, HDA_INPUT),
246         HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
247         HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
248         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
249         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
250         { } /* end */
251 };
252
253 static const struct hda_bind_ctls alc663_asus_bind_master_vol = {
254         .ops = &snd_hda_bind_vol,
255         .values = {
256                 HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
257                 HDA_COMPOSE_AMP_VAL(0x03, 3, 0, HDA_OUTPUT),
258                 0
259         },
260 };
261
262 static const struct hda_bind_ctls alc663_asus_one_bind_switch = {
263         .ops = &snd_hda_bind_sw,
264         .values = {
265                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
266                 HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
267                 0
268         },
269 };
270
271 static const struct snd_kcontrol_new alc663_m51va_mixer[] = {
272         HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
273         HDA_BIND_SW("Master Playback Switch", &alc663_asus_one_bind_switch),
274         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
275         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
276         { } /* end */
277 };
278
279 static const struct hda_bind_ctls alc663_asus_tree_bind_switch = {
280         .ops = &snd_hda_bind_sw,
281         .values = {
282                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
283                 HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
284                 HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
285                 0
286         },
287 };
288
289 static const struct snd_kcontrol_new alc663_two_hp_m1_mixer[] = {
290         HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
291         HDA_BIND_SW("Master Playback Switch", &alc663_asus_tree_bind_switch),
292         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
293         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
294         HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
295         HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
296
297         { } /* end */
298 };
299
300 static const struct hda_bind_ctls alc663_asus_four_bind_switch = {
301         .ops = &snd_hda_bind_sw,
302         .values = {
303                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
304                 HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
305                 HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
306                 0
307         },
308 };
309
310 static const struct snd_kcontrol_new alc663_two_hp_m2_mixer[] = {
311         HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
312         HDA_BIND_SW("Master Playback Switch", &alc663_asus_four_bind_switch),
313         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
314         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
315         HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
316         HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
317         { } /* end */
318 };
319
320 static const struct snd_kcontrol_new alc662_1bjd_mixer[] = {
321         HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
322         HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
323         HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
324         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
325         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
326         HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
327         HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
328         { } /* end */
329 };
330
331 static const struct hda_bind_ctls alc663_asus_two_bind_master_vol = {
332         .ops = &snd_hda_bind_vol,
333         .values = {
334                 HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
335                 HDA_COMPOSE_AMP_VAL(0x04, 3, 0, HDA_OUTPUT),
336                 0
337         },
338 };
339
340 static const struct hda_bind_ctls alc663_asus_two_bind_switch = {
341         .ops = &snd_hda_bind_sw,
342         .values = {
343                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
344                 HDA_COMPOSE_AMP_VAL(0x16, 3, 0, HDA_OUTPUT),
345                 0
346         },
347 };
348
349 static const struct snd_kcontrol_new alc663_asus_21jd_clfe_mixer[] = {
350         HDA_BIND_VOL("Master Playback Volume",
351                                 &alc663_asus_two_bind_master_vol),
352         HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
353         HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
354         HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
355         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
356         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
357         { } /* end */
358 };
359
360 static const struct snd_kcontrol_new alc663_asus_15jd_clfe_mixer[] = {
361         HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
362         HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
363         HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
364         HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
365         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
366         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
367         { } /* end */
368 };
369
370 static const struct snd_kcontrol_new alc663_g71v_mixer[] = {
371         HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
372         HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
373         HDA_CODEC_VOLUME("Front Playback Volume", 0x03, 0x0, HDA_OUTPUT),
374         HDA_CODEC_MUTE("Front Playback Switch", 0x15, 0x0, HDA_OUTPUT),
375         HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
376
377         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
378         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
379         HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
380         HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
381         { } /* end */
382 };
383
384 static const struct snd_kcontrol_new alc663_g50v_mixer[] = {
385         HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
386         HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
387         HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
388
389         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
390         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
391         HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
392         HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
393         HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
394         HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
395         { } /* end */
396 };
397
398 static const struct hda_bind_ctls alc663_asus_mode7_8_all_bind_switch = {
399         .ops = &snd_hda_bind_sw,
400         .values = {
401                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
402                 HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
403                 HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
404                 HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
405                 HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
406                 0
407         },
408 };
409
410 static const struct hda_bind_ctls alc663_asus_mode7_8_sp_bind_switch = {
411         .ops = &snd_hda_bind_sw,
412         .values = {
413                 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
414                 HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
415                 0
416         },
417 };
418
419 static const struct snd_kcontrol_new alc663_mode7_mixer[] = {
420         HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
421         HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
422         HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
423         HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
424         HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
425         HDA_CODEC_VOLUME("IntMic Playback Volume", 0x0b, 0x0, HDA_INPUT),
426         HDA_CODEC_MUTE("IntMic Playback Switch", 0x0b, 0x0, HDA_INPUT),
427         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
428         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
429         { } /* end */
430 };
431
432 static const struct snd_kcontrol_new alc663_mode8_mixer[] = {
433         HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
434         HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
435         HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
436         HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x15, 0x0, HDA_OUTPUT),
437         HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
438         HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
439         HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
440         { } /* end */
441 };
442
443
444 static const struct snd_kcontrol_new alc662_chmode_mixer[] = {
445         {
446                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
447                 .name = "Channel Mode",
448                 .info = alc_ch_mode_info,
449                 .get = alc_ch_mode_get,
450                 .put = alc_ch_mode_put,
451         },
452         { } /* end */
453 };
454
455 static const struct hda_verb alc662_init_verbs[] = {
456         /* ADC: mute amp left and right */
457         {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
458         {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
459
460         {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
461         {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
462         {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
463         {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
464         {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
465         {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
466
467         /* Front Pin: output 0 (0x0c) */
468         {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
469         {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
470
471         /* Rear Pin: output 1 (0x0d) */
472         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
473         {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
474
475         /* CLFE Pin: output 2 (0x0e) */
476         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
477         {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
478
479         /* Mic (rear) pin: input vref at 80% */
480         {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
481         {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
482         /* Front Mic pin: input vref at 80% */
483         {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
484         {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
485         /* Line In pin: input */
486         {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
487         {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
488         /* Line-2 In: Headphone output (output 0 - 0x0c) */
489         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
490         {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
491         {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
492         /* CD pin widget for input */
493         {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
494
495         /* FIXME: use matrix-type input source selection */
496         /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
497         /* Input mixer */
498         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
499         {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
500
501         { }
502 };
503
504 static const struct hda_verb alc662_eapd_init_verbs[] = {
505         /* always trun on EAPD */
506         {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
507         {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
508         { }
509 };
510
511 static const struct hda_verb alc662_sue_init_verbs[] = {
512         {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_FRONT_EVENT},
513         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_HP_EVENT},
514         {}
515 };
516
517 static const struct hda_verb alc662_eeepc_sue_init_verbs[] = {
518         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
519         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
520         {}
521 };
522
523 /* Set Unsolicited Event*/
524 static const struct hda_verb alc662_eeepc_ep20_sue_init_verbs[] = {
525         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
526         {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
527         {}
528 };
529
530 static const struct hda_verb alc663_m51va_init_verbs[] = {
531         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
532         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
533         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
534         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
535         {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
536         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
537         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
538         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
539         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
540         {}
541 };
542
543 static const struct hda_verb alc663_21jd_amic_init_verbs[] = {
544         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
545         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
546         {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
547         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
548         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
549         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
550         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
551         {}
552 };
553
554 static const struct hda_verb alc662_1bjd_amic_init_verbs[] = {
555         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
556         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
557         {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
558         {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},  /* Headphone */
559         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
560         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
561         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
562         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
563         {}
564 };
565
566 static const struct hda_verb alc663_15jd_amic_init_verbs[] = {
567         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
568         {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
569         {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
570         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
571         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
572         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
573         {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
574         {}
575 };
576
577 static const struct hda_verb alc663_two_hp_amic_m1_init_verbs[] = {
578         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
579         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
580         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
581         {0x21, AC_VERB_SET_CONNECT_SEL, 0x0},   /* Headphone */
582         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
583         {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
584         {0x15, AC_VERB_SET_CONNECT_SEL, 0x0},   /* Headphone */
585         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
586         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
587         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
588         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
589         {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
590         {}
591 };
592
593 static const struct hda_verb alc663_two_hp_amic_m2_init_verbs[] = {
594         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
595         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
596         {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
597         {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
598         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
599         {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
600         {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
601         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
602         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
603         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
604         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
605         {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
606         {}
607 };
608
609 static const struct hda_verb alc663_g71v_init_verbs[] = {
610         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
611         /* {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, */
612         /* {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, */ /* Headphone */
613
614         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
615         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
616         {0x21, AC_VERB_SET_CONNECT_SEL, 0x00},  /* Headphone */
617
618         {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_FRONT_EVENT},
619         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_MIC_EVENT},
620         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC_HP_EVENT},
621         {}
622 };
623
624 static const struct hda_verb alc663_g50v_init_verbs[] = {
625         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
626         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
627         {0x21, AC_VERB_SET_CONNECT_SEL, 0x00},  /* Headphone */
628
629         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
630         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
631         {}
632 };
633
634 static const struct hda_verb alc662_ecs_init_verbs[] = {
635         {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0x701f},
636         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
637         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
638         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
639         {}
640 };
641
642 static const struct hda_verb alc663_mode7_init_verbs[] = {
643         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
644         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
645         {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
646         {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
647         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
648         {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
649         {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01},
650         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
651         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
652         {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
653         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
654         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
655         {0x19, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
656         {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
657         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
658         {}
659 };
660
661 static const struct hda_verb alc663_mode8_init_verbs[] = {
662         {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
663         {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
664         {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
665         {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
666         {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
667         {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
668         {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
669         {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
670         {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
671         {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
672         {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
673         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
674         {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
675         {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
676         {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
677         {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
678         {}
679 };
680
681 static const struct snd_kcontrol_new alc662_auto_capture_mixer[] = {
682         HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
683         HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
684         { } /* end */
685 };
686
687 static const struct snd_kcontrol_new alc272_auto_capture_mixer[] = {
688         HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
689         HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
690         { } /* end */
691 };
692
693 static void alc662_lenovo_101e_setup(struct hda_codec *codec)
694 {
695         struct alc_spec *spec = codec->spec;
696
697         spec->autocfg.hp_pins[0] = 0x1b;
698         spec->autocfg.line_out_pins[0] = 0x14;
699         spec->autocfg.speaker_pins[0] = 0x15;
700         spec->automute = 1;
701         spec->detect_line = 1;
702         spec->automute_lines = 1;
703         spec->automute_mode = ALC_AUTOMUTE_AMP;
704 }
705
706 static void alc662_eeepc_setup(struct hda_codec *codec)
707 {
708         struct alc_spec *spec = codec->spec;
709
710         alc262_hippo1_setup(codec);
711         spec->ext_mic_pin = 0x18;
712         spec->int_mic_pin = 0x19;
713         spec->auto_mic = 1;
714 }
715
716 static void alc662_eeepc_ep20_setup(struct hda_codec *codec)
717 {
718         struct alc_spec *spec = codec->spec;
719
720         spec->autocfg.hp_pins[0] = 0x14;
721         spec->autocfg.speaker_pins[0] = 0x1b;
722         spec->automute = 1;
723         spec->automute_mode = ALC_AUTOMUTE_AMP;
724 }
725
726 static void alc663_m51va_setup(struct hda_codec *codec)
727 {
728         struct alc_spec *spec = codec->spec;
729         spec->autocfg.hp_pins[0] = 0x21;
730         spec->autocfg.speaker_pins[0] = 0x14;
731         spec->automute_mixer_nid[0] = 0x0c;
732         spec->automute = 1;
733         spec->automute_mode = ALC_AUTOMUTE_MIXER;
734         spec->ext_mic_pin = 0x18;
735         spec->int_mic_pin = 0x12;
736         spec->auto_mic = 1;
737 }
738
739 /* ***************** Mode1 ******************************/
740 static void alc663_mode1_setup(struct hda_codec *codec)
741 {
742         struct alc_spec *spec = codec->spec;
743         spec->autocfg.hp_pins[0] = 0x21;
744         spec->autocfg.speaker_pins[0] = 0x14;
745         spec->automute_mixer_nid[0] = 0x0c;
746         spec->automute = 1;
747         spec->automute_mode = ALC_AUTOMUTE_MIXER;
748         spec->ext_mic_pin = 0x18;
749         spec->int_mic_pin = 0x19;
750         spec->auto_mic = 1;
751 }
752
753 /* ***************** Mode2 ******************************/
754 static void alc662_mode2_setup(struct hda_codec *codec)
755 {
756         struct alc_spec *spec = codec->spec;
757         spec->autocfg.hp_pins[0] = 0x1b;
758         spec->autocfg.speaker_pins[0] = 0x14;
759         spec->automute = 1;
760         spec->automute_mode = ALC_AUTOMUTE_PIN;
761         spec->ext_mic_pin = 0x18;
762         spec->int_mic_pin = 0x19;
763         spec->auto_mic = 1;
764 }
765
766 /* ***************** Mode3 ******************************/
767 static void alc663_mode3_setup(struct hda_codec *codec)
768 {
769         struct alc_spec *spec = codec->spec;
770         spec->autocfg.hp_pins[0] = 0x21;
771         spec->autocfg.hp_pins[0] = 0x15;
772         spec->autocfg.speaker_pins[0] = 0x14;
773         spec->automute = 1;
774         spec->automute_mode = ALC_AUTOMUTE_PIN;
775         spec->ext_mic_pin = 0x18;
776         spec->int_mic_pin = 0x19;
777         spec->auto_mic = 1;
778 }
779
780 /* ***************** Mode4 ******************************/
781 static void alc663_mode4_setup(struct hda_codec *codec)
782 {
783         struct alc_spec *spec = codec->spec;
784         spec->autocfg.hp_pins[0] = 0x21;
785         spec->autocfg.speaker_pins[0] = 0x14;
786         spec->autocfg.speaker_pins[1] = 0x16;
787         spec->automute_mixer_nid[0] = 0x0c;
788         spec->automute_mixer_nid[1] = 0x0e;
789         spec->automute = 1;
790         spec->automute_mode = ALC_AUTOMUTE_MIXER;
791         spec->ext_mic_pin = 0x18;
792         spec->int_mic_pin = 0x19;
793         spec->auto_mic = 1;
794 }
795
796 /* ***************** Mode5 ******************************/
797 static void alc663_mode5_setup(struct hda_codec *codec)
798 {
799         struct alc_spec *spec = codec->spec;
800         spec->autocfg.hp_pins[0] = 0x15;
801         spec->autocfg.speaker_pins[0] = 0x14;
802         spec->autocfg.speaker_pins[1] = 0x16;
803         spec->automute_mixer_nid[0] = 0x0c;
804         spec->automute_mixer_nid[1] = 0x0e;
805         spec->automute = 1;
806         spec->automute_mode = ALC_AUTOMUTE_MIXER;
807         spec->ext_mic_pin = 0x18;
808         spec->int_mic_pin = 0x19;
809         spec->auto_mic = 1;
810 }
811
812 /* ***************** Mode6 ******************************/
813 static void alc663_mode6_setup(struct hda_codec *codec)
814 {
815         struct alc_spec *spec = codec->spec;
816         spec->autocfg.hp_pins[0] = 0x1b;
817         spec->autocfg.hp_pins[0] = 0x15;
818         spec->autocfg.speaker_pins[0] = 0x14;
819         spec->automute_mixer_nid[0] = 0x0c;
820         spec->automute = 1;
821         spec->automute_mode = ALC_AUTOMUTE_MIXER;
822         spec->ext_mic_pin = 0x18;
823         spec->int_mic_pin = 0x19;
824         spec->auto_mic = 1;
825 }
826
827 /* ***************** Mode7 ******************************/
828 static void alc663_mode7_setup(struct hda_codec *codec)
829 {
830         struct alc_spec *spec = codec->spec;
831         spec->autocfg.hp_pins[0] = 0x1b;
832         spec->autocfg.hp_pins[0] = 0x21;
833         spec->autocfg.speaker_pins[0] = 0x14;
834         spec->autocfg.speaker_pins[0] = 0x17;
835         spec->automute = 1;
836         spec->automute_mode = ALC_AUTOMUTE_PIN;
837         spec->ext_mic_pin = 0x18;
838         spec->int_mic_pin = 0x19;
839         spec->auto_mic = 1;
840 }
841
842 /* ***************** Mode8 ******************************/
843 static void alc663_mode8_setup(struct hda_codec *codec)
844 {
845         struct alc_spec *spec = codec->spec;
846         spec->autocfg.hp_pins[0] = 0x21;
847         spec->autocfg.hp_pins[1] = 0x15;
848         spec->autocfg.speaker_pins[0] = 0x14;
849         spec->autocfg.speaker_pins[0] = 0x17;
850         spec->automute = 1;
851         spec->automute_mode = ALC_AUTOMUTE_PIN;
852         spec->ext_mic_pin = 0x18;
853         spec->int_mic_pin = 0x12;
854         spec->auto_mic = 1;
855 }
856
857 static void alc663_g71v_setup(struct hda_codec *codec)
858 {
859         struct alc_spec *spec = codec->spec;
860         spec->autocfg.hp_pins[0] = 0x21;
861         spec->autocfg.line_out_pins[0] = 0x15;
862         spec->autocfg.speaker_pins[0] = 0x14;
863         spec->automute = 1;
864         spec->automute_mode = ALC_AUTOMUTE_AMP;
865         spec->detect_line = 1;
866         spec->automute_lines = 1;
867         spec->ext_mic_pin = 0x18;
868         spec->int_mic_pin = 0x12;
869         spec->auto_mic = 1;
870 }
871
872 #define alc663_g50v_setup       alc663_m51va_setup
873
874 static const struct snd_kcontrol_new alc662_ecs_mixer[] = {
875         HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
876         ALC262_HIPPO_MASTER_SWITCH,
877
878         HDA_CODEC_VOLUME("Mic/LineIn Boost Volume", 0x18, 0, HDA_INPUT),
879         HDA_CODEC_VOLUME("Mic/LineIn Playback Volume", 0x0b, 0x0, HDA_INPUT),
880         HDA_CODEC_MUTE("Mic/LineIn Playback Switch", 0x0b, 0x0, HDA_INPUT),
881
882         HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
883         HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
884         HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
885         { } /* end */
886 };
887
888 /*
889  * configuration and preset
890  */
891 static const char * const alc662_models[ALC662_MODEL_LAST] = {
892         [ALC662_3ST_2ch_DIG]    = "3stack-dig",
893         [ALC662_3ST_6ch_DIG]    = "3stack-6ch-dig",
894         [ALC662_3ST_6ch]        = "3stack-6ch",
895         [ALC662_5ST_DIG]        = "5stack-dig",
896         [ALC662_LENOVO_101E]    = "lenovo-101e",
897         [ALC662_ASUS_EEEPC_P701] = "eeepc-p701",
898         [ALC662_ASUS_EEEPC_EP20] = "eeepc-ep20",
899         [ALC662_ECS] = "ecs",
900         [ALC663_ASUS_M51VA] = "m51va",
901         [ALC663_ASUS_G71V] = "g71v",
902         [ALC663_ASUS_H13] = "h13",
903         [ALC663_ASUS_G50V] = "g50v",
904         [ALC663_ASUS_MODE1] = "asus-mode1",
905         [ALC662_ASUS_MODE2] = "asus-mode2",
906         [ALC663_ASUS_MODE3] = "asus-mode3",
907         [ALC663_ASUS_MODE4] = "asus-mode4",
908         [ALC663_ASUS_MODE5] = "asus-mode5",
909         [ALC663_ASUS_MODE6] = "asus-mode6",
910         [ALC663_ASUS_MODE7] = "asus-mode7",
911         [ALC663_ASUS_MODE8] = "asus-mode8",
912         [ALC662_AUTO]           = "auto",
913 };
914
915 static const struct snd_pci_quirk alc662_cfg_tbl[] = {
916         SND_PCI_QUIRK(0x1019, 0x9087, "ECS", ALC662_ECS),
917         SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
918         SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC663_ASUS_MODE3),
919         SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC663_ASUS_MODE1),
920         SND_PCI_QUIRK(0x1043, 0x11c3, "ASUS M70V", ALC663_ASUS_MODE3),
921         SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1),
922         SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2),
923         SND_PCI_QUIRK(0x1043, 0x1203, "ASUS NB", ALC663_ASUS_MODE1),
924         SND_PCI_QUIRK(0x1043, 0x1303, "ASUS G60J", ALC663_ASUS_MODE1),
925         SND_PCI_QUIRK(0x1043, 0x1333, "ASUS G60Jx", ALC663_ASUS_MODE1),
926         SND_PCI_QUIRK(0x1043, 0x1339, "ASUS NB", ALC662_ASUS_MODE2),
927         SND_PCI_QUIRK(0x1043, 0x13e3, "ASUS N71JA", ALC663_ASUS_MODE7),
928         SND_PCI_QUIRK(0x1043, 0x1463, "ASUS N71", ALC663_ASUS_MODE7),
929         SND_PCI_QUIRK(0x1043, 0x14d3, "ASUS G72", ALC663_ASUS_MODE8),
930         SND_PCI_QUIRK(0x1043, 0x1563, "ASUS N90", ALC663_ASUS_MODE3),
931         SND_PCI_QUIRK(0x1043, 0x15d3, "ASUS N50SF F50SF", ALC663_ASUS_MODE1),
932         SND_PCI_QUIRK(0x1043, 0x16c3, "ASUS NB", ALC662_ASUS_MODE2),
933         SND_PCI_QUIRK(0x1043, 0x16f3, "ASUS K40C K50C", ALC662_ASUS_MODE2),
934         SND_PCI_QUIRK(0x1043, 0x1733, "ASUS N81De", ALC663_ASUS_MODE1),
935         SND_PCI_QUIRK(0x1043, 0x1753, "ASUS NB", ALC662_ASUS_MODE2),
936         SND_PCI_QUIRK(0x1043, 0x1763, "ASUS NB", ALC663_ASUS_MODE6),
937         SND_PCI_QUIRK(0x1043, 0x1765, "ASUS NB", ALC663_ASUS_MODE6),
938         SND_PCI_QUIRK(0x1043, 0x1783, "ASUS NB", ALC662_ASUS_MODE2),
939         SND_PCI_QUIRK(0x1043, 0x1793, "ASUS F50GX", ALC663_ASUS_MODE1),
940         SND_PCI_QUIRK(0x1043, 0x17b3, "ASUS F70SL", ALC663_ASUS_MODE3),
941         SND_PCI_QUIRK(0x1043, 0x17c3, "ASUS UX20", ALC663_ASUS_M51VA),
942         SND_PCI_QUIRK(0x1043, 0x17f3, "ASUS X58LE", ALC662_ASUS_MODE2),
943         SND_PCI_QUIRK(0x1043, 0x1813, "ASUS NB", ALC662_ASUS_MODE2),
944         SND_PCI_QUIRK(0x1043, 0x1823, "ASUS NB", ALC663_ASUS_MODE5),
945         SND_PCI_QUIRK(0x1043, 0x1833, "ASUS NB", ALC663_ASUS_MODE6),
946         SND_PCI_QUIRK(0x1043, 0x1843, "ASUS NB", ALC662_ASUS_MODE2),
947         SND_PCI_QUIRK(0x1043, 0x1853, "ASUS F50Z", ALC663_ASUS_MODE1),
948         SND_PCI_QUIRK(0x1043, 0x1864, "ASUS NB", ALC662_ASUS_MODE2),
949         SND_PCI_QUIRK(0x1043, 0x1876, "ASUS NB", ALC662_ASUS_MODE2),
950         SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M51VA", ALC663_ASUS_M51VA),
951         /*SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M50Vr", ALC663_ASUS_MODE1),*/
952         SND_PCI_QUIRK(0x1043, 0x1893, "ASUS M50Vm", ALC663_ASUS_MODE3),
953         SND_PCI_QUIRK(0x1043, 0x1894, "ASUS X55", ALC663_ASUS_MODE3),
954         SND_PCI_QUIRK(0x1043, 0x18b3, "ASUS N80Vc", ALC663_ASUS_MODE1),
955         SND_PCI_QUIRK(0x1043, 0x18c3, "ASUS VX5", ALC663_ASUS_MODE1),
956         SND_PCI_QUIRK(0x1043, 0x18d3, "ASUS N81Te", ALC663_ASUS_MODE1),
957         SND_PCI_QUIRK(0x1043, 0x18f3, "ASUS N505Tp", ALC663_ASUS_MODE1),
958         SND_PCI_QUIRK(0x1043, 0x1903, "ASUS F5GL", ALC663_ASUS_MODE1),
959         SND_PCI_QUIRK(0x1043, 0x1913, "ASUS NB", ALC662_ASUS_MODE2),
960         SND_PCI_QUIRK(0x1043, 0x1933, "ASUS F80Q", ALC662_ASUS_MODE2),
961         SND_PCI_QUIRK(0x1043, 0x1943, "ASUS Vx3V", ALC663_ASUS_MODE1),
962         SND_PCI_QUIRK(0x1043, 0x1953, "ASUS NB", ALC663_ASUS_MODE1),
963         SND_PCI_QUIRK(0x1043, 0x1963, "ASUS X71C", ALC663_ASUS_MODE3),
964         SND_PCI_QUIRK(0x1043, 0x1983, "ASUS N5051A", ALC663_ASUS_MODE1),
965         SND_PCI_QUIRK(0x1043, 0x1993, "ASUS N20", ALC663_ASUS_MODE1),
966         SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS G50V", ALC663_ASUS_G50V),
967         /*SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS NB", ALC663_ASUS_MODE1),*/
968         SND_PCI_QUIRK(0x1043, 0x19b3, "ASUS F7Z", ALC663_ASUS_MODE1),
969         SND_PCI_QUIRK(0x1043, 0x19c3, "ASUS F5Z/F6x", ALC662_ASUS_MODE2),
970         SND_PCI_QUIRK(0x1043, 0x19d3, "ASUS NB", ALC663_ASUS_M51VA),
971         SND_PCI_QUIRK(0x1043, 0x19e3, "ASUS NB", ALC663_ASUS_MODE1),
972         SND_PCI_QUIRK(0x1043, 0x19f3, "ASUS NB", ALC663_ASUS_MODE4),
973         SND_PCI_QUIRK(0x1043, 0x8290, "ASUS P5GC-MX", ALC662_3ST_6ch_DIG),
974         SND_PCI_QUIRK(0x1043, 0x82a1, "ASUS Eeepc", ALC662_ASUS_EEEPC_P701),
975         SND_PCI_QUIRK(0x1043, 0x82d1, "ASUS Eeepc EP20", ALC662_ASUS_EEEPC_EP20),
976         SND_PCI_QUIRK(0x105b, 0x0cd6, "Foxconn", ALC662_ECS),
977         SND_PCI_QUIRK(0x105b, 0x0d47, "Foxconn 45CMX/45GMX/45CMX-K",
978                       ALC662_3ST_6ch_DIG),
979         SND_PCI_QUIRK(0x1179, 0xff6e, "Toshiba NB20x", ALC662_AUTO),
980         SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
981                       ALC662_3ST_6ch_DIG),
982         SND_PCI_QUIRK(0x152d, 0x2304, "Quanta WH1", ALC663_ASUS_H13),
983         SND_PCI_QUIRK(0x1565, 0x820f, "Biostar TA780G M2+", ALC662_3ST_6ch_DIG),
984         SND_PCI_QUIRK(0x1631, 0xc10c, "PB RS65", ALC663_ASUS_M51VA),
985         SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo", ALC662_LENOVO_101E),
986         SND_PCI_QUIRK(0x1849, 0x3662, "ASROCK K10N78FullHD-hSLI R3.0",
987                                         ALC662_3ST_6ch_DIG),
988         SND_PCI_QUIRK_MASK(0x1854, 0xf000, 0x2000, "ASUS H13-200x",
989                            ALC663_ASUS_H13),
990         SND_PCI_QUIRK(0x1991, 0x5628, "Ordissimo EVE", ALC662_LENOVO_101E),
991         {}
992 };
993
994 static const struct alc_config_preset alc662_presets[] = {
995         [ALC662_3ST_2ch_DIG] = {
996                 .mixers = { alc662_3ST_2ch_mixer },
997                 .init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
998                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
999                 .dac_nids = alc662_dac_nids,
1000                 .dig_out_nid = ALC662_DIGOUT_NID,
1001                 .dig_in_nid = ALC662_DIGIN_NID,
1002                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1003                 .channel_mode = alc662_3ST_2ch_modes,
1004                 .input_mux = &alc662_capture_source,
1005         },
1006         [ALC662_3ST_6ch_DIG] = {
1007                 .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
1008                 .init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
1009                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1010                 .dac_nids = alc662_dac_nids,
1011                 .dig_out_nid = ALC662_DIGOUT_NID,
1012                 .dig_in_nid = ALC662_DIGIN_NID,
1013                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
1014                 .channel_mode = alc662_3ST_6ch_modes,
1015                 .need_dac_fix = 1,
1016                 .input_mux = &alc662_capture_source,
1017         },
1018         [ALC662_3ST_6ch] = {
1019                 .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
1020                 .init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
1021                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1022                 .dac_nids = alc662_dac_nids,
1023                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
1024                 .channel_mode = alc662_3ST_6ch_modes,
1025                 .need_dac_fix = 1,
1026                 .input_mux = &alc662_capture_source,
1027         },
1028         [ALC662_5ST_DIG] = {
1029                 .mixers = { alc662_base_mixer, alc662_chmode_mixer },
1030                 .init_verbs = { alc662_init_verbs, alc662_eapd_init_verbs },
1031                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1032                 .dac_nids = alc662_dac_nids,
1033                 .dig_out_nid = ALC662_DIGOUT_NID,
1034                 .dig_in_nid = ALC662_DIGIN_NID,
1035                 .num_channel_mode = ARRAY_SIZE(alc662_5stack_modes),
1036                 .channel_mode = alc662_5stack_modes,
1037                 .input_mux = &alc662_capture_source,
1038         },
1039         [ALC662_LENOVO_101E] = {
1040                 .mixers = { alc662_lenovo_101e_mixer },
1041                 .init_verbs = { alc662_init_verbs,
1042                                 alc662_eapd_init_verbs,
1043                                 alc662_sue_init_verbs },
1044                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1045                 .dac_nids = alc662_dac_nids,
1046                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1047                 .channel_mode = alc662_3ST_2ch_modes,
1048                 .input_mux = &alc662_lenovo_101e_capture_source,
1049                 .unsol_event = alc_sku_unsol_event,
1050                 .setup = alc662_lenovo_101e_setup,
1051                 .init_hook = alc_inithook,
1052         },
1053         [ALC662_ASUS_EEEPC_P701] = {
1054                 .mixers = { alc662_eeepc_p701_mixer },
1055                 .init_verbs = { alc662_init_verbs,
1056                                 alc662_eapd_init_verbs,
1057                                 alc662_eeepc_sue_init_verbs },
1058                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1059                 .dac_nids = alc662_dac_nids,
1060                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1061                 .channel_mode = alc662_3ST_2ch_modes,
1062                 .unsol_event = alc_sku_unsol_event,
1063                 .setup = alc662_eeepc_setup,
1064                 .init_hook = alc_inithook,
1065         },
1066         [ALC662_ASUS_EEEPC_EP20] = {
1067                 .mixers = { alc662_eeepc_ep20_mixer,
1068                             alc662_chmode_mixer },
1069                 .init_verbs = { alc662_init_verbs,
1070                                 alc662_eapd_init_verbs,
1071                                 alc662_eeepc_ep20_sue_init_verbs },
1072                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1073                 .dac_nids = alc662_dac_nids,
1074                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
1075                 .channel_mode = alc662_3ST_6ch_modes,
1076                 .input_mux = &alc662_lenovo_101e_capture_source,
1077                 .unsol_event = alc_sku_unsol_event,
1078                 .setup = alc662_eeepc_ep20_setup,
1079                 .init_hook = alc_inithook,
1080         },
1081         [ALC662_ECS] = {
1082                 .mixers = { alc662_ecs_mixer },
1083                 .init_verbs = { alc662_init_verbs,
1084                                 alc662_eapd_init_verbs,
1085                                 alc662_ecs_init_verbs },
1086                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1087                 .dac_nids = alc662_dac_nids,
1088                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1089                 .channel_mode = alc662_3ST_2ch_modes,
1090                 .unsol_event = alc_sku_unsol_event,
1091                 .setup = alc662_eeepc_setup,
1092                 .init_hook = alc_inithook,
1093         },
1094         [ALC663_ASUS_M51VA] = {
1095                 .mixers = { alc663_m51va_mixer },
1096                 .init_verbs = { alc662_init_verbs,
1097                                 alc662_eapd_init_verbs,
1098                                 alc663_m51va_init_verbs },
1099                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1100                 .dac_nids = alc662_dac_nids,
1101                 .dig_out_nid = ALC662_DIGOUT_NID,
1102                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1103                 .channel_mode = alc662_3ST_2ch_modes,
1104                 .unsol_event = alc_sku_unsol_event,
1105                 .setup = alc663_m51va_setup,
1106                 .init_hook = alc_inithook,
1107         },
1108         [ALC663_ASUS_G71V] = {
1109                 .mixers = { alc663_g71v_mixer },
1110                 .init_verbs = { alc662_init_verbs,
1111                                 alc662_eapd_init_verbs,
1112                                 alc663_g71v_init_verbs },
1113                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1114                 .dac_nids = alc662_dac_nids,
1115                 .dig_out_nid = ALC662_DIGOUT_NID,
1116                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1117                 .channel_mode = alc662_3ST_2ch_modes,
1118                 .unsol_event = alc_sku_unsol_event,
1119                 .setup = alc663_g71v_setup,
1120                 .init_hook = alc_inithook,
1121         },
1122         [ALC663_ASUS_H13] = {
1123                 .mixers = { alc663_m51va_mixer },
1124                 .init_verbs = { alc662_init_verbs,
1125                                 alc662_eapd_init_verbs,
1126                                 alc663_m51va_init_verbs },
1127                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1128                 .dac_nids = alc662_dac_nids,
1129                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1130                 .channel_mode = alc662_3ST_2ch_modes,
1131                 .setup = alc663_m51va_setup,
1132                 .unsol_event = alc_sku_unsol_event,
1133                 .init_hook = alc_inithook,
1134         },
1135         [ALC663_ASUS_G50V] = {
1136                 .mixers = { alc663_g50v_mixer },
1137                 .init_verbs = { alc662_init_verbs,
1138                                 alc662_eapd_init_verbs,
1139                                 alc663_g50v_init_verbs },
1140                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1141                 .dac_nids = alc662_dac_nids,
1142                 .dig_out_nid = ALC662_DIGOUT_NID,
1143                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
1144                 .channel_mode = alc662_3ST_6ch_modes,
1145                 .input_mux = &alc663_capture_source,
1146                 .unsol_event = alc_sku_unsol_event,
1147                 .setup = alc663_g50v_setup,
1148                 .init_hook = alc_inithook,
1149         },
1150         [ALC663_ASUS_MODE1] = {
1151                 .mixers = { alc663_m51va_mixer },
1152                 .cap_mixer = alc662_auto_capture_mixer,
1153                 .init_verbs = { alc662_init_verbs,
1154                                 alc662_eapd_init_verbs,
1155                                 alc663_21jd_amic_init_verbs },
1156                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1157                 .hp_nid = 0x03,
1158                 .dac_nids = alc662_dac_nids,
1159                 .dig_out_nid = ALC662_DIGOUT_NID,
1160                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1161                 .channel_mode = alc662_3ST_2ch_modes,
1162                 .unsol_event = alc_sku_unsol_event,
1163                 .setup = alc663_mode1_setup,
1164                 .init_hook = alc_inithook,
1165         },
1166         [ALC662_ASUS_MODE2] = {
1167                 .mixers = { alc662_1bjd_mixer },
1168                 .cap_mixer = alc662_auto_capture_mixer,
1169                 .init_verbs = { alc662_init_verbs,
1170                                 alc662_eapd_init_verbs,
1171                                 alc662_1bjd_amic_init_verbs },
1172                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1173                 .dac_nids = alc662_dac_nids,
1174                 .dig_out_nid = ALC662_DIGOUT_NID,
1175                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1176                 .channel_mode = alc662_3ST_2ch_modes,
1177                 .unsol_event = alc_sku_unsol_event,
1178                 .setup = alc662_mode2_setup,
1179                 .init_hook = alc_inithook,
1180         },
1181         [ALC663_ASUS_MODE3] = {
1182                 .mixers = { alc663_two_hp_m1_mixer },
1183                 .cap_mixer = alc662_auto_capture_mixer,
1184                 .init_verbs = { alc662_init_verbs,
1185                                 alc662_eapd_init_verbs,
1186                                 alc663_two_hp_amic_m1_init_verbs },
1187                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1188                 .hp_nid = 0x03,
1189                 .dac_nids = alc662_dac_nids,
1190                 .dig_out_nid = ALC662_DIGOUT_NID,
1191                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1192                 .channel_mode = alc662_3ST_2ch_modes,
1193                 .unsol_event = alc_sku_unsol_event,
1194                 .setup = alc663_mode3_setup,
1195                 .init_hook = alc_inithook,
1196         },
1197         [ALC663_ASUS_MODE4] = {
1198                 .mixers = { alc663_asus_21jd_clfe_mixer },
1199                 .cap_mixer = alc662_auto_capture_mixer,
1200                 .init_verbs = { alc662_init_verbs,
1201                                 alc662_eapd_init_verbs,
1202                                 alc663_21jd_amic_init_verbs},
1203                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1204                 .hp_nid = 0x03,
1205                 .dac_nids = alc662_dac_nids,
1206                 .dig_out_nid = ALC662_DIGOUT_NID,
1207                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1208                 .channel_mode = alc662_3ST_2ch_modes,
1209                 .unsol_event = alc_sku_unsol_event,
1210                 .setup = alc663_mode4_setup,
1211                 .init_hook = alc_inithook,
1212         },
1213         [ALC663_ASUS_MODE5] = {
1214                 .mixers = { alc663_asus_15jd_clfe_mixer },
1215                 .cap_mixer = alc662_auto_capture_mixer,
1216                 .init_verbs = { alc662_init_verbs,
1217                                 alc662_eapd_init_verbs,
1218                                 alc663_15jd_amic_init_verbs },
1219                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1220                 .hp_nid = 0x03,
1221                 .dac_nids = alc662_dac_nids,
1222                 .dig_out_nid = ALC662_DIGOUT_NID,
1223                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1224                 .channel_mode = alc662_3ST_2ch_modes,
1225                 .unsol_event = alc_sku_unsol_event,
1226                 .setup = alc663_mode5_setup,
1227                 .init_hook = alc_inithook,
1228         },
1229         [ALC663_ASUS_MODE6] = {
1230                 .mixers = { alc663_two_hp_m2_mixer },
1231                 .cap_mixer = alc662_auto_capture_mixer,
1232                 .init_verbs = { alc662_init_verbs,
1233                                 alc662_eapd_init_verbs,
1234                                 alc663_two_hp_amic_m2_init_verbs },
1235                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1236                 .hp_nid = 0x03,
1237                 .dac_nids = alc662_dac_nids,
1238                 .dig_out_nid = ALC662_DIGOUT_NID,
1239                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1240                 .channel_mode = alc662_3ST_2ch_modes,
1241                 .unsol_event = alc_sku_unsol_event,
1242                 .setup = alc663_mode6_setup,
1243                 .init_hook = alc_inithook,
1244         },
1245         [ALC663_ASUS_MODE7] = {
1246                 .mixers = { alc663_mode7_mixer },
1247                 .cap_mixer = alc662_auto_capture_mixer,
1248                 .init_verbs = { alc662_init_verbs,
1249                                 alc662_eapd_init_verbs,
1250                                 alc663_mode7_init_verbs },
1251                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1252                 .hp_nid = 0x03,
1253                 .dac_nids = alc662_dac_nids,
1254                 .dig_out_nid = ALC662_DIGOUT_NID,
1255                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1256                 .channel_mode = alc662_3ST_2ch_modes,
1257                 .unsol_event = alc_sku_unsol_event,
1258                 .setup = alc663_mode7_setup,
1259                 .init_hook = alc_inithook,
1260         },
1261         [ALC663_ASUS_MODE8] = {
1262                 .mixers = { alc663_mode8_mixer },
1263                 .cap_mixer = alc662_auto_capture_mixer,
1264                 .init_verbs = { alc662_init_verbs,
1265                                 alc662_eapd_init_verbs,
1266                                 alc663_mode8_init_verbs },
1267                 .num_dacs = ARRAY_SIZE(alc662_dac_nids),
1268                 .hp_nid = 0x03,
1269                 .dac_nids = alc662_dac_nids,
1270                 .dig_out_nid = ALC662_DIGOUT_NID,
1271                 .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
1272                 .channel_mode = alc662_3ST_2ch_modes,
1273                 .unsol_event = alc_sku_unsol_event,
1274                 .setup = alc663_mode8_setup,
1275                 .init_hook = alc_inithook,
1276         },
1277 };