8eb6508cd991214e4c06de4891d959059913d998
[~shefty/rdma-dev.git] / sound / pci / hda / patch_sigmatel.c
1 /*
2  * Universal Interface for Intel High Definition Audio Codec
3  *
4  * HD audio interface patch for SigmaTel STAC92xx
5  *
6  * Copyright (c) 2005 Embedded Alley Solutions, Inc.
7  * Matt Porter <mporter@embeddedalley.com>
8  *
9  * Based on patch_cmedia.c and patch_realtek.c
10  * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
11  *
12  *  This driver is free software; you can redistribute it and/or modify
13  *  it under the terms of the GNU General Public License as published by
14  *  the Free Software Foundation; either version 2 of the License, or
15  *  (at your option) any later version.
16  *
17  *  This driver is distributed in the hope that it will be useful,
18  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
19  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20  *  GNU General Public License for more details.
21  *
22  *  You should have received a copy of the GNU General Public License
23  *  along with this program; if not, write to the Free Software
24  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
25  */
26
27 #include <linux/init.h>
28 #include <linux/delay.h>
29 #include <linux/slab.h>
30 #include <linux/pci.h>
31 #include <linux/dmi.h>
32 #include <sound/core.h>
33 #include <sound/asoundef.h>
34 #include <sound/jack.h>
35 #include "hda_codec.h"
36 #include "hda_local.h"
37 #include "hda_beep.h"
38
39 enum {
40         STAC_VREF_EVENT = 1,
41         STAC_INSERT_EVENT,
42         STAC_PWR_EVENT,
43         STAC_HP_EVENT,
44         STAC_LO_EVENT,
45         STAC_MIC_EVENT,
46 };
47
48 enum {
49         STAC_AUTO,
50         STAC_REF,
51         STAC_9200_OQO,
52         STAC_9200_DELL_D21,
53         STAC_9200_DELL_D22,
54         STAC_9200_DELL_D23,
55         STAC_9200_DELL_M21,
56         STAC_9200_DELL_M22,
57         STAC_9200_DELL_M23,
58         STAC_9200_DELL_M24,
59         STAC_9200_DELL_M25,
60         STAC_9200_DELL_M26,
61         STAC_9200_DELL_M27,
62         STAC_9200_M4,
63         STAC_9200_M4_2,
64         STAC_9200_PANASONIC,
65         STAC_9200_MODELS
66 };
67
68 enum {
69         STAC_9205_AUTO,
70         STAC_9205_REF,
71         STAC_9205_DELL_M42,
72         STAC_9205_DELL_M43,
73         STAC_9205_DELL_M44,
74         STAC_9205_EAPD,
75         STAC_9205_MODELS
76 };
77
78 enum {
79         STAC_92HD73XX_AUTO,
80         STAC_92HD73XX_NO_JD, /* no jack-detection */
81         STAC_92HD73XX_REF,
82         STAC_92HD73XX_INTEL,
83         STAC_DELL_M6_AMIC,
84         STAC_DELL_M6_DMIC,
85         STAC_DELL_M6_BOTH,
86         STAC_DELL_EQ,
87         STAC_ALIENWARE_M17X,
88         STAC_92HD73XX_MODELS
89 };
90
91 enum {
92         STAC_92HD83XXX_AUTO,
93         STAC_92HD83XXX_REF,
94         STAC_92HD83XXX_PWR_REF,
95         STAC_DELL_S14,
96         STAC_92HD83XXX_MODELS
97 };
98
99 enum {
100         STAC_92HD71BXX_AUTO,
101         STAC_92HD71BXX_REF,
102         STAC_DELL_M4_1,
103         STAC_DELL_M4_2,
104         STAC_DELL_M4_3,
105         STAC_HP_M4,
106         STAC_HP_DV5,
107         STAC_HP_HDX,
108         STAC_HP_DV4_1222NR,
109         STAC_92HD71BXX_MODELS
110 };
111
112 enum {
113         STAC_925x_AUTO,
114         STAC_925x_REF,
115         STAC_M1,
116         STAC_M1_2,
117         STAC_M2,
118         STAC_M2_2,
119         STAC_M3,
120         STAC_M5,
121         STAC_M6,
122         STAC_925x_MODELS
123 };
124
125 enum {
126         STAC_922X_AUTO,
127         STAC_D945_REF,
128         STAC_D945GTP3,
129         STAC_D945GTP5,
130         STAC_INTEL_MAC_V1,
131         STAC_INTEL_MAC_V2,
132         STAC_INTEL_MAC_V3,
133         STAC_INTEL_MAC_V4,
134         STAC_INTEL_MAC_V5,
135         STAC_INTEL_MAC_AUTO, /* This model is selected if no module parameter
136                               * is given, one of the above models will be
137                               * chosen according to the subsystem id. */
138         /* for backward compatibility */
139         STAC_MACMINI,
140         STAC_MACBOOK,
141         STAC_MACBOOK_PRO_V1,
142         STAC_MACBOOK_PRO_V2,
143         STAC_IMAC_INTEL,
144         STAC_IMAC_INTEL_20,
145         STAC_ECS_202,
146         STAC_922X_DELL_D81,
147         STAC_922X_DELL_D82,
148         STAC_922X_DELL_M81,
149         STAC_922X_DELL_M82,
150         STAC_922X_MODELS
151 };
152
153 enum {
154         STAC_927X_AUTO,
155         STAC_D965_REF_NO_JD, /* no jack-detection */
156         STAC_D965_REF,
157         STAC_D965_3ST,
158         STAC_D965_5ST,
159         STAC_D965_5ST_NO_FP,
160         STAC_DELL_3ST,
161         STAC_DELL_BIOS,
162         STAC_927X_VOLKNOB,
163         STAC_927X_MODELS
164 };
165
166 enum {
167         STAC_9872_AUTO,
168         STAC_9872_VAIO,
169         STAC_9872_MODELS
170 };
171
172 struct sigmatel_event {
173         hda_nid_t nid;
174         unsigned char type;
175         unsigned char tag;
176         int data;
177 };
178
179 struct sigmatel_jack {
180         hda_nid_t nid;
181         int type;
182         struct snd_jack *jack;
183 };
184
185 struct sigmatel_mic_route {
186         hda_nid_t pin;
187         signed char mux_idx;
188         signed char dmux_idx;
189 };
190
191 struct sigmatel_spec {
192         struct snd_kcontrol_new *mixers[4];
193         unsigned int num_mixers;
194
195         int board_config;
196         unsigned int eapd_switch: 1;
197         unsigned int surr_switch: 1;
198         unsigned int alt_switch: 1;
199         unsigned int hp_detect: 1;
200         unsigned int spdif_mute: 1;
201         unsigned int check_volume_offset:1;
202         unsigned int auto_mic:1;
203
204         /* gpio lines */
205         unsigned int eapd_mask;
206         unsigned int gpio_mask;
207         unsigned int gpio_dir;
208         unsigned int gpio_data;
209         unsigned int gpio_mute;
210         unsigned int gpio_led;
211
212         /* stream */
213         unsigned int stream_delay;
214
215         /* analog loopback */
216         struct snd_kcontrol_new *aloopback_ctl;
217         unsigned char aloopback_mask;
218         unsigned char aloopback_shift;
219
220         /* power management */
221         unsigned int num_pwrs;
222         unsigned int *pwr_mapping;
223         hda_nid_t *pwr_nids;
224         hda_nid_t *dac_list;
225
226         /* jack detection */
227         struct snd_array jacks;
228
229         /* events */
230         struct snd_array events;
231
232         /* playback */
233         struct hda_input_mux *mono_mux;
234         unsigned int cur_mmux;
235         struct hda_multi_out multiout;
236         hda_nid_t dac_nids[5];
237         hda_nid_t hp_dacs[5];
238         hda_nid_t speaker_dacs[5];
239
240         int volume_offset;
241
242         /* capture */
243         hda_nid_t *adc_nids;
244         unsigned int num_adcs;
245         hda_nid_t *mux_nids;
246         unsigned int num_muxes;
247         hda_nid_t *dmic_nids;
248         unsigned int num_dmics;
249         hda_nid_t *dmux_nids;
250         unsigned int num_dmuxes;
251         hda_nid_t *smux_nids;
252         unsigned int num_smuxes;
253         unsigned int num_analog_muxes;
254
255         unsigned long *capvols; /* amp-volume attr: HDA_COMPOSE_AMP_VAL() */
256         unsigned long *capsws; /* amp-mute attr: HDA_COMPOSE_AMP_VAL() */
257         unsigned int num_caps; /* number of capture volume/switch elements */
258
259         struct sigmatel_mic_route ext_mic;
260         struct sigmatel_mic_route int_mic;
261
262         const char **spdif_labels;
263
264         hda_nid_t dig_in_nid;
265         hda_nid_t mono_nid;
266         hda_nid_t anabeep_nid;
267         hda_nid_t digbeep_nid;
268
269         /* pin widgets */
270         hda_nid_t *pin_nids;
271         unsigned int num_pins;
272
273         /* codec specific stuff */
274         struct hda_verb *init;
275         struct snd_kcontrol_new *mixer;
276
277         /* capture source */
278         struct hda_input_mux *dinput_mux;
279         unsigned int cur_dmux[2];
280         struct hda_input_mux *input_mux;
281         unsigned int cur_mux[3];
282         struct hda_input_mux *sinput_mux;
283         unsigned int cur_smux[2];
284         unsigned int cur_amux;
285         hda_nid_t *amp_nids;
286         unsigned int powerdown_adcs;
287
288         /* i/o switches */
289         unsigned int io_switch[2];
290         unsigned int clfe_swap;
291         hda_nid_t line_switch;  /* shared line-in for input and output */
292         hda_nid_t mic_switch;   /* shared mic-in for input and output */
293         hda_nid_t hp_switch; /* NID of HP as line-out */
294         unsigned int aloopback;
295
296         struct hda_pcm pcm_rec[2];      /* PCM information */
297
298         /* dynamic controls and input_mux */
299         struct auto_pin_cfg autocfg;
300         struct snd_array kctls;
301         struct hda_input_mux private_dimux;
302         struct hda_input_mux private_imux;
303         struct hda_input_mux private_smux;
304         struct hda_input_mux private_mono_mux;
305 };
306
307 static hda_nid_t stac9200_adc_nids[1] = {
308         0x03,
309 };
310
311 static hda_nid_t stac9200_mux_nids[1] = {
312         0x0c,
313 };
314
315 static hda_nid_t stac9200_dac_nids[1] = {
316         0x02,
317 };
318
319 static hda_nid_t stac92hd73xx_pwr_nids[8] = {
320         0x0a, 0x0b, 0x0c, 0xd, 0x0e,
321         0x0f, 0x10, 0x11
322 };
323
324 static hda_nid_t stac92hd73xx_slave_dig_outs[2] = {
325         0x26, 0,
326 };
327
328 static hda_nid_t stac92hd73xx_adc_nids[2] = {
329         0x1a, 0x1b
330 };
331
332 #define STAC92HD73XX_NUM_DMICS  2
333 static hda_nid_t stac92hd73xx_dmic_nids[STAC92HD73XX_NUM_DMICS + 1] = {
334         0x13, 0x14, 0
335 };
336
337 #define STAC92HD73_DAC_COUNT 5
338
339 static hda_nid_t stac92hd73xx_mux_nids[2] = {
340         0x20, 0x21,
341 };
342
343 static hda_nid_t stac92hd73xx_dmux_nids[2] = {
344         0x20, 0x21,
345 };
346
347 static hda_nid_t stac92hd73xx_smux_nids[2] = {
348         0x22, 0x23,
349 };
350
351 #define STAC92HD73XX_NUM_CAPS   2
352 static unsigned long stac92hd73xx_capvols[] = {
353         HDA_COMPOSE_AMP_VAL(0x20, 3, 0, HDA_OUTPUT),
354         HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
355 };
356 #define stac92hd73xx_capsws     stac92hd73xx_capvols
357
358 #define STAC92HD83_DAC_COUNT 3
359
360 static hda_nid_t stac92hd83xxx_mux_nids[2] = {
361         0x17, 0x18,
362 };
363
364 static hda_nid_t stac92hd83xxx_adc_nids[2] = {
365         0x15, 0x16,
366 };
367
368 static hda_nid_t stac92hd83xxx_pwr_nids[4] = {
369         0xa, 0xb, 0xd, 0xe,
370 };
371
372 static hda_nid_t stac92hd83xxx_slave_dig_outs[2] = {
373         0x1e, 0,
374 };
375
376 static unsigned int stac92hd83xxx_pwr_mapping[4] = {
377         0x03, 0x0c, 0x20, 0x40,
378 };
379
380 #define STAC92HD83XXX_NUM_CAPS  2
381 static unsigned long stac92hd83xxx_capvols[] = {
382         HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
383         HDA_COMPOSE_AMP_VAL(0x18, 3, 0, HDA_OUTPUT),
384 };
385 #define stac92hd83xxx_capsws    stac92hd83xxx_capvols
386
387 static hda_nid_t stac92hd71bxx_pwr_nids[3] = {
388         0x0a, 0x0d, 0x0f
389 };
390
391 static hda_nid_t stac92hd71bxx_adc_nids[2] = {
392         0x12, 0x13,
393 };
394
395 static hda_nid_t stac92hd71bxx_mux_nids[2] = {
396         0x1a, 0x1b
397 };
398
399 static hda_nid_t stac92hd71bxx_dmux_nids[2] = {
400         0x1c, 0x1d,
401 };
402
403 static hda_nid_t stac92hd71bxx_smux_nids[2] = {
404         0x24, 0x25,
405 };
406
407 #define STAC92HD71BXX_NUM_DMICS 2
408 static hda_nid_t stac92hd71bxx_dmic_nids[STAC92HD71BXX_NUM_DMICS + 1] = {
409         0x18, 0x19, 0
410 };
411
412 static hda_nid_t stac92hd71bxx_slave_dig_outs[2] = {
413         0x22, 0
414 };
415
416 #define STAC92HD71BXX_NUM_CAPS          2
417 static unsigned long stac92hd71bxx_capvols[] = {
418         HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_OUTPUT),
419         HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
420 };
421 #define stac92hd71bxx_capsws    stac92hd71bxx_capvols
422
423 static hda_nid_t stac925x_adc_nids[1] = {
424         0x03,
425 };
426
427 static hda_nid_t stac925x_mux_nids[1] = {
428         0x0f,
429 };
430
431 static hda_nid_t stac925x_dac_nids[1] = {
432         0x02,
433 };
434
435 #define STAC925X_NUM_DMICS      1
436 static hda_nid_t stac925x_dmic_nids[STAC925X_NUM_DMICS + 1] = {
437         0x15, 0
438 };
439
440 static hda_nid_t stac925x_dmux_nids[1] = {
441         0x14,
442 };
443
444 static unsigned long stac925x_capvols[] = {
445         HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_OUTPUT),
446 };
447 static unsigned long stac925x_capsws[] = {
448         HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
449 };
450
451 static hda_nid_t stac922x_adc_nids[2] = {
452         0x06, 0x07,
453 };
454
455 static hda_nid_t stac922x_mux_nids[2] = {
456         0x12, 0x13,
457 };
458
459 #define STAC922X_NUM_CAPS       2
460 static unsigned long stac922x_capvols[] = {
461         HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_INPUT),
462         HDA_COMPOSE_AMP_VAL(0x18, 3, 0, HDA_INPUT),
463 };
464 #define stac922x_capsws         stac922x_capvols
465
466 static hda_nid_t stac927x_slave_dig_outs[2] = {
467         0x1f, 0,
468 };
469
470 static hda_nid_t stac927x_adc_nids[3] = {
471         0x07, 0x08, 0x09
472 };
473
474 static hda_nid_t stac927x_mux_nids[3] = {
475         0x15, 0x16, 0x17
476 };
477
478 static hda_nid_t stac927x_smux_nids[1] = {
479         0x21,
480 };
481
482 static hda_nid_t stac927x_dac_nids[6] = {
483         0x02, 0x03, 0x04, 0x05, 0x06, 0
484 };
485
486 static hda_nid_t stac927x_dmux_nids[1] = {
487         0x1b,
488 };
489
490 #define STAC927X_NUM_DMICS 2
491 static hda_nid_t stac927x_dmic_nids[STAC927X_NUM_DMICS + 1] = {
492         0x13, 0x14, 0
493 };
494
495 #define STAC927X_NUM_CAPS       3
496 static unsigned long stac927x_capvols[] = {
497         HDA_COMPOSE_AMP_VAL(0x18, 3, 0, HDA_INPUT),
498         HDA_COMPOSE_AMP_VAL(0x19, 3, 0, HDA_INPUT),
499         HDA_COMPOSE_AMP_VAL(0x1a, 3, 0, HDA_INPUT),
500 };
501 static unsigned long stac927x_capsws[] = {
502         HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
503         HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_OUTPUT),
504         HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
505 };
506
507 static const char *stac927x_spdif_labels[5] = {
508         "Digital Playback", "ADAT", "Analog Mux 1",
509         "Analog Mux 2", "Analog Mux 3"
510 };
511
512 static hda_nid_t stac9205_adc_nids[2] = {
513         0x12, 0x13
514 };
515
516 static hda_nid_t stac9205_mux_nids[2] = {
517         0x19, 0x1a
518 };
519
520 static hda_nid_t stac9205_dmux_nids[1] = {
521         0x1d,
522 };
523
524 static hda_nid_t stac9205_smux_nids[1] = {
525         0x21,
526 };
527
528 #define STAC9205_NUM_DMICS      2
529 static hda_nid_t stac9205_dmic_nids[STAC9205_NUM_DMICS + 1] = {
530         0x17, 0x18, 0
531 };
532
533 #define STAC9205_NUM_CAPS       2
534 static unsigned long stac9205_capvols[] = {
535         HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_INPUT),
536         HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_INPUT),
537 };
538 static unsigned long stac9205_capsws[] = {
539         HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
540         HDA_COMPOSE_AMP_VAL(0x1e, 3, 0, HDA_OUTPUT),
541 };
542
543 static hda_nid_t stac9200_pin_nids[8] = {
544         0x08, 0x09, 0x0d, 0x0e, 
545         0x0f, 0x10, 0x11, 0x12,
546 };
547
548 static hda_nid_t stac925x_pin_nids[8] = {
549         0x07, 0x08, 0x0a, 0x0b, 
550         0x0c, 0x0d, 0x10, 0x11,
551 };
552
553 static hda_nid_t stac922x_pin_nids[10] = {
554         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
555         0x0f, 0x10, 0x11, 0x15, 0x1b,
556 };
557
558 static hda_nid_t stac92hd73xx_pin_nids[13] = {
559         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
560         0x0f, 0x10, 0x11, 0x12, 0x13,
561         0x14, 0x22, 0x23
562 };
563
564 static hda_nid_t stac92hd83xxx_pin_nids[10] = {
565         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
566         0x0f, 0x10, 0x11, 0x1f, 0x20,
567 };
568
569 #define STAC92HD71BXX_NUM_PINS 13
570 static hda_nid_t stac92hd71bxx_pin_nids_4port[STAC92HD71BXX_NUM_PINS] = {
571         0x0a, 0x0b, 0x0c, 0x0d, 0x00,
572         0x00, 0x14, 0x18, 0x19, 0x1e,
573         0x1f, 0x20, 0x27
574 };
575 static hda_nid_t stac92hd71bxx_pin_nids_6port[STAC92HD71BXX_NUM_PINS] = {
576         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
577         0x0f, 0x14, 0x18, 0x19, 0x1e,
578         0x1f, 0x20, 0x27
579 };
580
581 static hda_nid_t stac927x_pin_nids[14] = {
582         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
583         0x0f, 0x10, 0x11, 0x12, 0x13,
584         0x14, 0x21, 0x22, 0x23,
585 };
586
587 static hda_nid_t stac9205_pin_nids[12] = {
588         0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
589         0x0f, 0x14, 0x16, 0x17, 0x18,
590         0x21, 0x22,
591 };
592
593 static int stac92xx_dmux_enum_info(struct snd_kcontrol *kcontrol,
594                                    struct snd_ctl_elem_info *uinfo)
595 {
596         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
597         struct sigmatel_spec *spec = codec->spec;
598         return snd_hda_input_mux_info(spec->dinput_mux, uinfo);
599 }
600
601 static int stac92xx_dmux_enum_get(struct snd_kcontrol *kcontrol,
602                                   struct snd_ctl_elem_value *ucontrol)
603 {
604         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
605         struct sigmatel_spec *spec = codec->spec;
606         unsigned int dmux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
607
608         ucontrol->value.enumerated.item[0] = spec->cur_dmux[dmux_idx];
609         return 0;
610 }
611
612 static int stac92xx_dmux_enum_put(struct snd_kcontrol *kcontrol,
613                                   struct snd_ctl_elem_value *ucontrol)
614 {
615         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
616         struct sigmatel_spec *spec = codec->spec;
617         unsigned int dmux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
618
619         return snd_hda_input_mux_put(codec, spec->dinput_mux, ucontrol,
620                         spec->dmux_nids[dmux_idx], &spec->cur_dmux[dmux_idx]);
621 }
622
623 static int stac92xx_smux_enum_info(struct snd_kcontrol *kcontrol,
624                                    struct snd_ctl_elem_info *uinfo)
625 {
626         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
627         struct sigmatel_spec *spec = codec->spec;
628         return snd_hda_input_mux_info(spec->sinput_mux, uinfo);
629 }
630
631 static int stac92xx_smux_enum_get(struct snd_kcontrol *kcontrol,
632                                   struct snd_ctl_elem_value *ucontrol)
633 {
634         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
635         struct sigmatel_spec *spec = codec->spec;
636         unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
637
638         ucontrol->value.enumerated.item[0] = spec->cur_smux[smux_idx];
639         return 0;
640 }
641
642 static int stac92xx_smux_enum_put(struct snd_kcontrol *kcontrol,
643                                   struct snd_ctl_elem_value *ucontrol)
644 {
645         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
646         struct sigmatel_spec *spec = codec->spec;
647         struct hda_input_mux *smux = &spec->private_smux;
648         unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
649         int err, val;
650         hda_nid_t nid;
651
652         err = snd_hda_input_mux_put(codec, spec->sinput_mux, ucontrol,
653                         spec->smux_nids[smux_idx], &spec->cur_smux[smux_idx]);
654         if (err < 0)
655                 return err;
656
657         if (spec->spdif_mute) {
658                 if (smux_idx == 0)
659                         nid = spec->multiout.dig_out_nid;
660                 else
661                         nid = codec->slave_dig_outs[smux_idx - 1];
662                 if (spec->cur_smux[smux_idx] == smux->num_items - 1)
663                         val = HDA_AMP_MUTE;
664                 else
665                         val = 0;
666                 /* un/mute SPDIF out */
667                 snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
668                                          HDA_AMP_MUTE, val);
669         }
670         return 0;
671 }
672
673 static unsigned int stac92xx_vref_set(struct hda_codec *codec,
674                                         hda_nid_t nid, unsigned int new_vref)
675 {
676         int error;
677         unsigned int pincfg;
678         pincfg = snd_hda_codec_read(codec, nid, 0,
679                                 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
680
681         pincfg &= 0xff;
682         pincfg &= ~(AC_PINCTL_VREFEN | AC_PINCTL_IN_EN | AC_PINCTL_OUT_EN);
683         pincfg |= new_vref;
684
685         if (new_vref == AC_PINCTL_VREF_HIZ)
686                 pincfg |= AC_PINCTL_OUT_EN;
687         else
688                 pincfg |= AC_PINCTL_IN_EN;
689
690         error = snd_hda_codec_write_cache(codec, nid, 0,
691                                         AC_VERB_SET_PIN_WIDGET_CONTROL, pincfg);
692         if (error < 0)
693                 return error;
694         else
695                 return 1;
696 }
697
698 static unsigned int stac92xx_vref_get(struct hda_codec *codec, hda_nid_t nid)
699 {
700         unsigned int vref;
701         vref = snd_hda_codec_read(codec, nid, 0,
702                                 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
703         vref &= AC_PINCTL_VREFEN;
704         return vref;
705 }
706
707 static int stac92xx_mux_enum_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
708 {
709         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
710         struct sigmatel_spec *spec = codec->spec;
711         return snd_hda_input_mux_info(spec->input_mux, uinfo);
712 }
713
714 static int stac92xx_mux_enum_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
715 {
716         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
717         struct sigmatel_spec *spec = codec->spec;
718         unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
719
720         ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];
721         return 0;
722 }
723
724 static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
725 {
726         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
727         struct sigmatel_spec *spec = codec->spec;
728         unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
729         const struct hda_input_mux *imux = spec->input_mux;
730         unsigned int idx, prev_idx;
731
732         idx = ucontrol->value.enumerated.item[0];
733         if (idx >= imux->num_items)
734                 idx = imux->num_items - 1;
735         prev_idx = spec->cur_mux[adc_idx];
736         if (prev_idx == idx)
737                 return 0;
738         if (idx < spec->num_analog_muxes) {
739                 snd_hda_codec_write_cache(codec, spec->mux_nids[adc_idx], 0,
740                                           AC_VERB_SET_CONNECT_SEL,
741                                           imux->items[idx].index);
742                 if (prev_idx >= spec->num_analog_muxes) {
743                         imux = spec->dinput_mux;
744                         /* 0 = analog */
745                         snd_hda_codec_write_cache(codec,
746                                                   spec->dmux_nids[adc_idx], 0,
747                                                   AC_VERB_SET_CONNECT_SEL,
748                                                   imux->items[0].index);
749                 }
750         } else {
751                 imux = spec->dinput_mux;
752                 snd_hda_codec_write_cache(codec, spec->dmux_nids[adc_idx], 0,
753                                           AC_VERB_SET_CONNECT_SEL,
754                                           imux->items[idx - 1].index);
755         }
756         spec->cur_mux[adc_idx] = idx;
757         return 1;
758 }
759
760 static int stac92xx_mono_mux_enum_info(struct snd_kcontrol *kcontrol,
761         struct snd_ctl_elem_info *uinfo)
762 {
763         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
764         struct sigmatel_spec *spec = codec->spec;
765         return snd_hda_input_mux_info(spec->mono_mux, uinfo);
766 }
767
768 static int stac92xx_mono_mux_enum_get(struct snd_kcontrol *kcontrol,
769         struct snd_ctl_elem_value *ucontrol)
770 {
771         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
772         struct sigmatel_spec *spec = codec->spec;
773
774         ucontrol->value.enumerated.item[0] = spec->cur_mmux;
775         return 0;
776 }
777
778 static int stac92xx_mono_mux_enum_put(struct snd_kcontrol *kcontrol,
779         struct snd_ctl_elem_value *ucontrol)
780 {
781         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
782         struct sigmatel_spec *spec = codec->spec;
783
784         return snd_hda_input_mux_put(codec, spec->mono_mux, ucontrol,
785                                      spec->mono_nid, &spec->cur_mmux);
786 }
787
788 #define stac92xx_aloopback_info snd_ctl_boolean_mono_info
789
790 static int stac92xx_aloopback_get(struct snd_kcontrol *kcontrol,
791         struct snd_ctl_elem_value *ucontrol)
792 {
793         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
794         unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
795         struct sigmatel_spec *spec = codec->spec;
796
797         ucontrol->value.integer.value[0] = !!(spec->aloopback &
798                                               (spec->aloopback_mask << idx));
799         return 0;
800 }
801
802 static int stac92xx_aloopback_put(struct snd_kcontrol *kcontrol,
803                 struct snd_ctl_elem_value *ucontrol)
804 {
805         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
806         struct sigmatel_spec *spec = codec->spec;
807         unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
808         unsigned int dac_mode;
809         unsigned int val, idx_val;
810
811         idx_val = spec->aloopback_mask << idx;
812         if (ucontrol->value.integer.value[0])
813                 val = spec->aloopback | idx_val;
814         else
815                 val = spec->aloopback & ~idx_val;
816         if (spec->aloopback == val)
817                 return 0;
818
819         spec->aloopback = val;
820
821         /* Only return the bits defined by the shift value of the
822          * first two bytes of the mask
823          */
824         dac_mode = snd_hda_codec_read(codec, codec->afg, 0,
825                                       kcontrol->private_value & 0xFFFF, 0x0);
826         dac_mode >>= spec->aloopback_shift;
827
828         if (spec->aloopback & idx_val) {
829                 snd_hda_power_up(codec);
830                 dac_mode |= idx_val;
831         } else {
832                 snd_hda_power_down(codec);
833                 dac_mode &= ~idx_val;
834         }
835
836         snd_hda_codec_write_cache(codec, codec->afg, 0,
837                 kcontrol->private_value >> 16, dac_mode);
838
839         return 1;
840 }
841
842 static struct hda_verb stac9200_core_init[] = {
843         /* set dac0mux for dac converter */
844         { 0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
845         {}
846 };
847
848 static struct hda_verb stac9200_eapd_init[] = {
849         /* set dac0mux for dac converter */
850         {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
851         {0x08, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
852         {}
853 };
854
855 static struct hda_verb dell_eq_core_init[] = {
856         /* set master volume to max value without distortion
857          * and direct control */
858         { 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xec},
859         {}
860 };
861
862 static struct hda_verb stac92hd73xx_core_init[] = {
863         /* set master volume and direct control */
864         { 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
865         {}
866 };
867
868 static struct hda_verb stac92hd83xxx_core_init[] = {
869         /* power state controls amps */
870         { 0x01, AC_VERB_SET_EAPD, 1 << 2},
871         {}
872 };
873
874 static struct hda_verb stac92hd71bxx_core_init[] = {
875         /* set master volume and direct control */
876         { 0x28, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
877         {}
878 };
879
880 static struct hda_verb stac92hd71bxx_unmute_core_init[] = {
881         /* unmute right and left channels for nodes 0x0f, 0xa, 0x0d */
882         { 0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
883         { 0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
884         { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
885         {}
886 };
887
888 static struct hda_verb stac925x_core_init[] = {
889         /* set dac0mux for dac converter */
890         { 0x06, AC_VERB_SET_CONNECT_SEL, 0x00},
891         /* mute the master volume */
892         { 0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
893         {}
894 };
895
896 static struct hda_verb stac922x_core_init[] = {
897         /* set master volume and direct control */      
898         { 0x16, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
899         {}
900 };
901
902 static struct hda_verb d965_core_init[] = {
903         /* set master volume and direct control */      
904         { 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
905         /* unmute node 0x1b */
906         { 0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
907         /* select node 0x03 as DAC */   
908         { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
909         {}
910 };
911
912 static struct hda_verb dell_3st_core_init[] = {
913         /* don't set delta bit */
914         {0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
915         /* unmute node 0x1b */
916         {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
917         /* select node 0x03 as DAC */
918         {0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
919         {}
920 };
921
922 static struct hda_verb stac927x_core_init[] = {
923         /* set master volume and direct control */      
924         { 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
925         /* enable analog pc beep path */
926         { 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
927         {}
928 };
929
930 static struct hda_verb stac927x_volknob_core_init[] = {
931         /* don't set delta bit */
932         {0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
933         /* enable analog pc beep path */
934         {0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
935         {}
936 };
937
938 static struct hda_verb stac9205_core_init[] = {
939         /* set master volume and direct control */      
940         { 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
941         /* enable analog pc beep path */
942         { 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
943         {}
944 };
945
946 #define STAC_MONO_MUX \
947         { \
948                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
949                 .name = "Mono Mux", \
950                 .count = 1, \
951                 .info = stac92xx_mono_mux_enum_info, \
952                 .get = stac92xx_mono_mux_enum_get, \
953                 .put = stac92xx_mono_mux_enum_put, \
954         }
955
956 #define STAC_ANALOG_LOOPBACK(verb_read, verb_write, cnt) \
957         { \
958                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
959                 .name  = "Analog Loopback", \
960                 .count = cnt, \
961                 .info  = stac92xx_aloopback_info, \
962                 .get   = stac92xx_aloopback_get, \
963                 .put   = stac92xx_aloopback_put, \
964                 .private_value = verb_read | (verb_write << 16), \
965         }
966
967 #define DC_BIAS(xname, idx, nid) \
968         { \
969                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
970                 .name = xname, \
971                 .index = idx, \
972                 .info = stac92xx_dc_bias_info, \
973                 .get = stac92xx_dc_bias_get, \
974                 .put = stac92xx_dc_bias_put, \
975                 .private_value = nid, \
976         }
977
978 static struct snd_kcontrol_new stac9200_mixer[] = {
979         HDA_CODEC_VOLUME("Master Playback Volume", 0xb, 0, HDA_OUTPUT),
980         HDA_CODEC_MUTE("Master Playback Switch", 0xb, 0, HDA_OUTPUT),
981         HDA_CODEC_VOLUME("Capture Volume", 0x0a, 0, HDA_OUTPUT),
982         HDA_CODEC_MUTE("Capture Switch", 0x0a, 0, HDA_OUTPUT),
983         { } /* end */
984 };
985
986 static struct snd_kcontrol_new stac92hd73xx_6ch_loopback[] = {
987         STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 3),
988         {}
989 };
990
991 static struct snd_kcontrol_new stac92hd73xx_8ch_loopback[] = {
992         STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 4),
993         {}
994 };
995
996 static struct snd_kcontrol_new stac92hd73xx_10ch_loopback[] = {
997         STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 5),
998         {}
999 };
1000
1001
1002 static struct snd_kcontrol_new stac92hd71bxx_loopback[] = {
1003         STAC_ANALOG_LOOPBACK(0xFA0, 0x7A0, 2)
1004 };
1005
1006 static struct snd_kcontrol_new stac925x_mixer[] = {
1007         HDA_CODEC_VOLUME("Master Playback Volume", 0x0e, 0, HDA_OUTPUT),
1008         HDA_CODEC_MUTE("Master Playback Switch", 0x0e, 0, HDA_OUTPUT),
1009         { } /* end */
1010 };
1011
1012 static struct snd_kcontrol_new stac9205_loopback[] = {
1013         STAC_ANALOG_LOOPBACK(0xFE0, 0x7E0, 1),
1014         {}
1015 };
1016
1017 static struct snd_kcontrol_new stac927x_loopback[] = {
1018         STAC_ANALOG_LOOPBACK(0xFEB, 0x7EB, 1),
1019         {}
1020 };
1021
1022 static struct snd_kcontrol_new stac_dmux_mixer = {
1023         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1024         .name = "Digital Input Source",
1025         /* count set later */
1026         .info = stac92xx_dmux_enum_info,
1027         .get = stac92xx_dmux_enum_get,
1028         .put = stac92xx_dmux_enum_put,
1029 };
1030
1031 static struct snd_kcontrol_new stac_smux_mixer = {
1032         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1033         .name = "IEC958 Playback Source",
1034         /* count set later */
1035         .info = stac92xx_smux_enum_info,
1036         .get = stac92xx_smux_enum_get,
1037         .put = stac92xx_smux_enum_put,
1038 };
1039
1040 static const char *slave_vols[] = {
1041         "Front Playback Volume",
1042         "Surround Playback Volume",
1043         "Center Playback Volume",
1044         "LFE Playback Volume",
1045         "Side Playback Volume",
1046         "Headphone Playback Volume",
1047         "Speaker Playback Volume",
1048         NULL
1049 };
1050
1051 static const char *slave_sws[] = {
1052         "Front Playback Switch",
1053         "Surround Playback Switch",
1054         "Center Playback Switch",
1055         "LFE Playback Switch",
1056         "Side Playback Switch",
1057         "Headphone Playback Switch",
1058         "Speaker Playback Switch",
1059         "IEC958 Playback Switch",
1060         NULL
1061 };
1062
1063 static void stac92xx_free_kctls(struct hda_codec *codec);
1064 static int stac92xx_add_jack(struct hda_codec *codec, hda_nid_t nid, int type);
1065
1066 static int stac92xx_build_controls(struct hda_codec *codec)
1067 {
1068         struct sigmatel_spec *spec = codec->spec;
1069         struct auto_pin_cfg *cfg = &spec->autocfg;
1070         hda_nid_t nid;
1071         int err;
1072         int i;
1073
1074         if (spec->mixer) {
1075                 err = snd_hda_add_new_ctls(codec, spec->mixer);
1076                 if (err < 0)
1077                         return err;
1078         }
1079
1080         for (i = 0; i < spec->num_mixers; i++) {
1081                 err = snd_hda_add_new_ctls(codec, spec->mixers[i]);
1082                 if (err < 0)
1083                         return err;
1084         }
1085         if (!spec->auto_mic && spec->num_dmuxes > 0 &&
1086             snd_hda_get_bool_hint(codec, "separate_dmux") == 1) {
1087                 stac_dmux_mixer.count = spec->num_dmuxes;
1088                 err = snd_hda_ctl_add(codec,
1089                                   snd_ctl_new1(&stac_dmux_mixer, codec));
1090                 if (err < 0)
1091                         return err;
1092         }
1093         if (spec->num_smuxes > 0) {
1094                 int wcaps = get_wcaps(codec, spec->multiout.dig_out_nid);
1095                 struct hda_input_mux *smux = &spec->private_smux;
1096                 /* check for mute support on SPDIF out */
1097                 if (wcaps & AC_WCAP_OUT_AMP) {
1098                         smux->items[smux->num_items].label = "Off";
1099                         smux->items[smux->num_items].index = 0;
1100                         smux->num_items++;
1101                         spec->spdif_mute = 1;
1102                 }
1103                 stac_smux_mixer.count = spec->num_smuxes;
1104                 err = snd_hda_ctl_add(codec,
1105                                   snd_ctl_new1(&stac_smux_mixer, codec));
1106                 if (err < 0)
1107                         return err;
1108         }
1109
1110         if (spec->multiout.dig_out_nid) {
1111                 err = snd_hda_create_spdif_out_ctls(codec, spec->multiout.dig_out_nid);
1112                 if (err < 0)
1113                         return err;
1114                 err = snd_hda_create_spdif_share_sw(codec,
1115                                                     &spec->multiout);
1116                 if (err < 0)
1117                         return err;
1118                 spec->multiout.share_spdif = 1;
1119         }
1120         if (spec->dig_in_nid && !(spec->gpio_dir & 0x01)) {
1121                 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in_nid);
1122                 if (err < 0)
1123                         return err;
1124         }
1125
1126         /* if we have no master control, let's create it */
1127         if (!snd_hda_find_mixer_ctl(codec, "Master Playback Volume")) {
1128                 unsigned int vmaster_tlv[4];
1129                 snd_hda_set_vmaster_tlv(codec, spec->multiout.dac_nids[0],
1130                                         HDA_OUTPUT, vmaster_tlv);
1131                 /* correct volume offset */
1132                 vmaster_tlv[2] += vmaster_tlv[3] * spec->volume_offset;
1133                 err = snd_hda_add_vmaster(codec, "Master Playback Volume",
1134                                           vmaster_tlv, slave_vols);
1135                 if (err < 0)
1136                         return err;
1137         }
1138         if (!snd_hda_find_mixer_ctl(codec, "Master Playback Switch")) {
1139                 err = snd_hda_add_vmaster(codec, "Master Playback Switch",
1140                                           NULL, slave_sws);
1141                 if (err < 0)
1142                         return err;
1143         }
1144
1145         if (spec->aloopback_ctl &&
1146             snd_hda_get_bool_hint(codec, "loopback") == 1) {
1147                 err = snd_hda_add_new_ctls(codec, spec->aloopback_ctl);
1148                 if (err < 0)
1149                         return err;
1150         }
1151
1152         stac92xx_free_kctls(codec); /* no longer needed */
1153
1154         /* create jack input elements */
1155         if (spec->hp_detect) {
1156                 for (i = 0; i < cfg->hp_outs; i++) {
1157                         int type = SND_JACK_HEADPHONE;
1158                         nid = cfg->hp_pins[i];
1159                         /* jack detection */
1160                         if (cfg->hp_outs == i)
1161                                 type |= SND_JACK_LINEOUT;
1162                         err = stac92xx_add_jack(codec, nid, type);
1163                         if (err < 0)
1164                                 return err;
1165                 }
1166         }
1167         for (i = 0; i < cfg->line_outs; i++) {
1168                 err = stac92xx_add_jack(codec, cfg->line_out_pins[i],
1169                                         SND_JACK_LINEOUT);
1170                 if (err < 0)
1171                         return err;
1172         }
1173         for (i = 0; i < AUTO_PIN_LAST; i++) {
1174                 nid = cfg->input_pins[i];
1175                 if (nid) {
1176                         err = stac92xx_add_jack(codec, nid,
1177                                                 SND_JACK_MICROPHONE);
1178                         if (err < 0)
1179                                 return err;
1180                 }
1181         }
1182
1183         return 0;       
1184 }
1185
1186 static unsigned int ref9200_pin_configs[8] = {
1187         0x01c47010, 0x01447010, 0x0221401f, 0x01114010,
1188         0x02a19020, 0x01a19021, 0x90100140, 0x01813122,
1189 };
1190
1191 static unsigned int gateway9200_m4_pin_configs[8] = {
1192         0x400000fe, 0x404500f4, 0x400100f0, 0x90110010,
1193         0x400100f1, 0x02a1902e, 0x500000f2, 0x500000f3,
1194 };
1195 static unsigned int gateway9200_m4_2_pin_configs[8] = {
1196         0x400000fe, 0x404500f4, 0x400100f0, 0x90110010,
1197         0x400100f1, 0x02a1902e, 0x500000f2, 0x500000f3,
1198 };
1199
1200 /*
1201     STAC 9200 pin configs for
1202     102801A8
1203     102801DE
1204     102801E8
1205 */
1206 static unsigned int dell9200_d21_pin_configs[8] = {
1207         0x400001f0, 0x400001f1, 0x02214030, 0x01014010, 
1208         0x02a19020, 0x01a19021, 0x90100140, 0x01813122,
1209 };
1210
1211 /* 
1212     STAC 9200 pin configs for
1213     102801C0
1214     102801C1
1215 */
1216 static unsigned int dell9200_d22_pin_configs[8] = {
1217         0x400001f0, 0x400001f1, 0x0221401f, 0x01014010, 
1218         0x01813020, 0x02a19021, 0x90100140, 0x400001f2,
1219 };
1220
1221 /* 
1222     STAC 9200 pin configs for
1223     102801C4 (Dell Dimension E310)
1224     102801C5
1225     102801C7
1226     102801D9
1227     102801DA
1228     102801E3
1229 */
1230 static unsigned int dell9200_d23_pin_configs[8] = {
1231         0x400001f0, 0x400001f1, 0x0221401f, 0x01014010, 
1232         0x01813020, 0x01a19021, 0x90100140, 0x400001f2, 
1233 };
1234
1235
1236 /* 
1237     STAC 9200-32 pin configs for
1238     102801B5 (Dell Inspiron 630m)
1239     102801D8 (Dell Inspiron 640m)
1240 */
1241 static unsigned int dell9200_m21_pin_configs[8] = {
1242         0x40c003fa, 0x03441340, 0x0321121f, 0x90170310,
1243         0x408003fb, 0x03a11020, 0x401003fc, 0x403003fd,
1244 };
1245
1246 /* 
1247     STAC 9200-32 pin configs for
1248     102801C2 (Dell Latitude D620)
1249     102801C8 
1250     102801CC (Dell Latitude D820)
1251     102801D4 
1252     102801D6 
1253 */
1254 static unsigned int dell9200_m22_pin_configs[8] = {
1255         0x40c003fa, 0x0144131f, 0x0321121f, 0x90170310, 
1256         0x90a70321, 0x03a11020, 0x401003fb, 0x40f000fc,
1257 };
1258
1259 /* 
1260     STAC 9200-32 pin configs for
1261     102801CE (Dell XPS M1710)
1262     102801CF (Dell Precision M90)
1263 */
1264 static unsigned int dell9200_m23_pin_configs[8] = {
1265         0x40c003fa, 0x01441340, 0x0421421f, 0x90170310,
1266         0x408003fb, 0x04a1102e, 0x90170311, 0x403003fc,
1267 };
1268
1269 /*
1270     STAC 9200-32 pin configs for 
1271     102801C9
1272     102801CA
1273     102801CB (Dell Latitude 120L)
1274     102801D3
1275 */
1276 static unsigned int dell9200_m24_pin_configs[8] = {
1277         0x40c003fa, 0x404003fb, 0x0321121f, 0x90170310, 
1278         0x408003fc, 0x03a11020, 0x401003fd, 0x403003fe, 
1279 };
1280
1281 /*
1282     STAC 9200-32 pin configs for
1283     102801BD (Dell Inspiron E1505n)
1284     102801EE
1285     102801EF
1286 */
1287 static unsigned int dell9200_m25_pin_configs[8] = {
1288         0x40c003fa, 0x01441340, 0x0421121f, 0x90170310, 
1289         0x408003fb, 0x04a11020, 0x401003fc, 0x403003fd,
1290 };
1291
1292 /*
1293     STAC 9200-32 pin configs for
1294     102801F5 (Dell Inspiron 1501)
1295     102801F6
1296 */
1297 static unsigned int dell9200_m26_pin_configs[8] = {
1298         0x40c003fa, 0x404003fb, 0x0421121f, 0x90170310, 
1299         0x408003fc, 0x04a11020, 0x401003fd, 0x403003fe,
1300 };
1301
1302 /*
1303     STAC 9200-32
1304     102801CD (Dell Inspiron E1705/9400)
1305 */
1306 static unsigned int dell9200_m27_pin_configs[8] = {
1307         0x40c003fa, 0x01441340, 0x0421121f, 0x90170310,
1308         0x90170310, 0x04a11020, 0x90170310, 0x40f003fc,
1309 };
1310
1311 static unsigned int oqo9200_pin_configs[8] = {
1312         0x40c000f0, 0x404000f1, 0x0221121f, 0x02211210,
1313         0x90170111, 0x90a70120, 0x400000f2, 0x400000f3,
1314 };
1315
1316
1317 static unsigned int *stac9200_brd_tbl[STAC_9200_MODELS] = {
1318         [STAC_REF] = ref9200_pin_configs,
1319         [STAC_9200_OQO] = oqo9200_pin_configs,
1320         [STAC_9200_DELL_D21] = dell9200_d21_pin_configs,
1321         [STAC_9200_DELL_D22] = dell9200_d22_pin_configs,
1322         [STAC_9200_DELL_D23] = dell9200_d23_pin_configs,
1323         [STAC_9200_DELL_M21] = dell9200_m21_pin_configs,
1324         [STAC_9200_DELL_M22] = dell9200_m22_pin_configs,
1325         [STAC_9200_DELL_M23] = dell9200_m23_pin_configs,
1326         [STAC_9200_DELL_M24] = dell9200_m24_pin_configs,
1327         [STAC_9200_DELL_M25] = dell9200_m25_pin_configs,
1328         [STAC_9200_DELL_M26] = dell9200_m26_pin_configs,
1329         [STAC_9200_DELL_M27] = dell9200_m27_pin_configs,
1330         [STAC_9200_M4] = gateway9200_m4_pin_configs,
1331         [STAC_9200_M4_2] = gateway9200_m4_2_pin_configs,
1332         [STAC_9200_PANASONIC] = ref9200_pin_configs,
1333 };
1334
1335 static const char *stac9200_models[STAC_9200_MODELS] = {
1336         [STAC_AUTO] = "auto",
1337         [STAC_REF] = "ref",
1338         [STAC_9200_OQO] = "oqo",
1339         [STAC_9200_DELL_D21] = "dell-d21",
1340         [STAC_9200_DELL_D22] = "dell-d22",
1341         [STAC_9200_DELL_D23] = "dell-d23",
1342         [STAC_9200_DELL_M21] = "dell-m21",
1343         [STAC_9200_DELL_M22] = "dell-m22",
1344         [STAC_9200_DELL_M23] = "dell-m23",
1345         [STAC_9200_DELL_M24] = "dell-m24",
1346         [STAC_9200_DELL_M25] = "dell-m25",
1347         [STAC_9200_DELL_M26] = "dell-m26",
1348         [STAC_9200_DELL_M27] = "dell-m27",
1349         [STAC_9200_M4] = "gateway-m4",
1350         [STAC_9200_M4_2] = "gateway-m4-2",
1351         [STAC_9200_PANASONIC] = "panasonic",
1352 };
1353
1354 static struct snd_pci_quirk stac9200_cfg_tbl[] = {
1355         /* SigmaTel reference board */
1356         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1357                       "DFI LanParty", STAC_REF),
1358         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1359                       "DFI LanParty", STAC_REF),
1360         /* Dell laptops have BIOS problem */
1361         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a8,
1362                       "unknown Dell", STAC_9200_DELL_D21),
1363         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01b5,
1364                       "Dell Inspiron 630m", STAC_9200_DELL_M21),
1365         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bd,
1366                       "Dell Inspiron E1505n", STAC_9200_DELL_M25),
1367         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c0,
1368                       "unknown Dell", STAC_9200_DELL_D22),
1369         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c1,
1370                       "unknown Dell", STAC_9200_DELL_D22),
1371         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c2,
1372                       "Dell Latitude D620", STAC_9200_DELL_M22),
1373         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c5,
1374                       "unknown Dell", STAC_9200_DELL_D23),
1375         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c7,
1376                       "unknown Dell", STAC_9200_DELL_D23),
1377         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c8,
1378                       "unknown Dell", STAC_9200_DELL_M22),
1379         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c9,
1380                       "unknown Dell", STAC_9200_DELL_M24),
1381         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ca,
1382                       "unknown Dell", STAC_9200_DELL_M24),
1383         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cb,
1384                       "Dell Latitude 120L", STAC_9200_DELL_M24),
1385         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cc,
1386                       "Dell Latitude D820", STAC_9200_DELL_M22),
1387         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cd,
1388                       "Dell Inspiron E1705/9400", STAC_9200_DELL_M27),
1389         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ce,
1390                       "Dell XPS M1710", STAC_9200_DELL_M23),
1391         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cf,
1392                       "Dell Precision M90", STAC_9200_DELL_M23),
1393         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d3,
1394                       "unknown Dell", STAC_9200_DELL_M22),
1395         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d4,
1396                       "unknown Dell", STAC_9200_DELL_M22),
1397         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d6,
1398                       "unknown Dell", STAC_9200_DELL_M22),
1399         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d8,
1400                       "Dell Inspiron 640m", STAC_9200_DELL_M21),
1401         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d9,
1402                       "unknown Dell", STAC_9200_DELL_D23),
1403         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01da,
1404                       "unknown Dell", STAC_9200_DELL_D23),
1405         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01de,
1406                       "unknown Dell", STAC_9200_DELL_D21),
1407         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e3,
1408                       "unknown Dell", STAC_9200_DELL_D23),
1409         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e8,
1410                       "unknown Dell", STAC_9200_DELL_D21),
1411         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ee,
1412                       "unknown Dell", STAC_9200_DELL_M25),
1413         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ef,
1414                       "unknown Dell", STAC_9200_DELL_M25),
1415         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f5,
1416                       "Dell Inspiron 1501", STAC_9200_DELL_M26),
1417         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f6,
1418                       "unknown Dell", STAC_9200_DELL_M26),
1419         /* Panasonic */
1420         SND_PCI_QUIRK(0x10f7, 0x8338, "Panasonic CF-74", STAC_9200_PANASONIC),
1421         /* Gateway machines needs EAPD to be set on resume */
1422         SND_PCI_QUIRK(0x107b, 0x0205, "Gateway S-7110M", STAC_9200_M4),
1423         SND_PCI_QUIRK(0x107b, 0x0317, "Gateway MT3423, MX341*", STAC_9200_M4_2),
1424         SND_PCI_QUIRK(0x107b, 0x0318, "Gateway ML3019, MT3707", STAC_9200_M4_2),
1425         /* OQO Mobile */
1426         SND_PCI_QUIRK(0x1106, 0x3288, "OQO Model 2", STAC_9200_OQO),
1427         {} /* terminator */
1428 };
1429
1430 static unsigned int ref925x_pin_configs[8] = {
1431         0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
1432         0x90a70320, 0x02214210, 0x01019020, 0x9033032e,
1433 };
1434
1435 static unsigned int stac925xM1_pin_configs[8] = {
1436         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1437         0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
1438 };
1439
1440 static unsigned int stac925xM1_2_pin_configs[8] = {
1441         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1442         0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
1443 };
1444
1445 static unsigned int stac925xM2_pin_configs[8] = {
1446         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1447         0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
1448 };
1449
1450 static unsigned int stac925xM2_2_pin_configs[8] = {
1451         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1452         0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
1453 };
1454
1455 static unsigned int stac925xM3_pin_configs[8] = {
1456         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1457         0x40a000f0, 0x90100210, 0x400003f1, 0x503303f3,
1458 };
1459
1460 static unsigned int stac925xM5_pin_configs[8] = {
1461         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1462         0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
1463 };
1464
1465 static unsigned int stac925xM6_pin_configs[8] = {
1466         0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1467         0x40a000f0, 0x90100210, 0x400003f1, 0x90330320,
1468 };
1469
1470 static unsigned int *stac925x_brd_tbl[STAC_925x_MODELS] = {
1471         [STAC_REF] = ref925x_pin_configs,
1472         [STAC_M1] = stac925xM1_pin_configs,
1473         [STAC_M1_2] = stac925xM1_2_pin_configs,
1474         [STAC_M2] = stac925xM2_pin_configs,
1475         [STAC_M2_2] = stac925xM2_2_pin_configs,
1476         [STAC_M3] = stac925xM3_pin_configs,
1477         [STAC_M5] = stac925xM5_pin_configs,
1478         [STAC_M6] = stac925xM6_pin_configs,
1479 };
1480
1481 static const char *stac925x_models[STAC_925x_MODELS] = {
1482         [STAC_925x_AUTO] = "auto",
1483         [STAC_REF] = "ref",
1484         [STAC_M1] = "m1",
1485         [STAC_M1_2] = "m1-2",
1486         [STAC_M2] = "m2",
1487         [STAC_M2_2] = "m2-2",
1488         [STAC_M3] = "m3",
1489         [STAC_M5] = "m5",
1490         [STAC_M6] = "m6",
1491 };
1492
1493 static struct snd_pci_quirk stac925x_codec_id_cfg_tbl[] = {
1494         SND_PCI_QUIRK(0x107b, 0x0316, "Gateway M255", STAC_M2),
1495         SND_PCI_QUIRK(0x107b, 0x0366, "Gateway MP6954", STAC_M5),
1496         SND_PCI_QUIRK(0x107b, 0x0461, "Gateway NX560XL", STAC_M1),
1497         SND_PCI_QUIRK(0x107b, 0x0681, "Gateway NX860", STAC_M2),
1498         SND_PCI_QUIRK(0x107b, 0x0367, "Gateway MX6453", STAC_M1_2),
1499         /* Not sure about the brand name for those */
1500         SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M1),
1501         SND_PCI_QUIRK(0x107b, 0x0507, "Gateway mobile", STAC_M3),
1502         SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M6),
1503         SND_PCI_QUIRK(0x107b, 0x0685, "Gateway mobile", STAC_M2_2),
1504         {} /* terminator */
1505 };
1506
1507 static struct snd_pci_quirk stac925x_cfg_tbl[] = {
1508         /* SigmaTel reference board */
1509         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, "DFI LanParty", STAC_REF),
1510         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, "DFI LanParty", STAC_REF),
1511         SND_PCI_QUIRK(0x8384, 0x7632, "Stac9202 Reference Board", STAC_REF),
1512
1513         /* Default table for unknown ID */
1514         SND_PCI_QUIRK(0x1002, 0x437b, "Gateway mobile", STAC_M2_2),
1515
1516         {} /* terminator */
1517 };
1518
1519 static unsigned int ref92hd73xx_pin_configs[13] = {
1520         0x02214030, 0x02a19040, 0x01a19020, 0x02214030,
1521         0x0181302e, 0x01014010, 0x01014020, 0x01014030,
1522         0x02319040, 0x90a000f0, 0x90a000f0, 0x01452050,
1523         0x01452050,
1524 };
1525
1526 static unsigned int dell_m6_pin_configs[13] = {
1527         0x0321101f, 0x4f00000f, 0x4f0000f0, 0x90170110,
1528         0x03a11020, 0x0321101f, 0x4f0000f0, 0x4f0000f0,
1529         0x4f0000f0, 0x90a60160, 0x4f0000f0, 0x4f0000f0,
1530         0x4f0000f0,
1531 };
1532
1533 static unsigned int alienware_m17x_pin_configs[13] = {
1534         0x0321101f, 0x0321101f, 0x03a11020, 0x03014020,
1535         0x90170110, 0x4f0000f0, 0x4f0000f0, 0x4f0000f0,
1536         0x4f0000f0, 0x90a60160, 0x4f0000f0, 0x4f0000f0,
1537         0x904601b0,
1538 };
1539
1540 static unsigned int *stac92hd73xx_brd_tbl[STAC_92HD73XX_MODELS] = {
1541         [STAC_92HD73XX_REF]     = ref92hd73xx_pin_configs,
1542         [STAC_DELL_M6_AMIC]     = dell_m6_pin_configs,
1543         [STAC_DELL_M6_DMIC]     = dell_m6_pin_configs,
1544         [STAC_DELL_M6_BOTH]     = dell_m6_pin_configs,
1545         [STAC_DELL_EQ]  = dell_m6_pin_configs,
1546         [STAC_ALIENWARE_M17X]   = alienware_m17x_pin_configs,
1547 };
1548
1549 static const char *stac92hd73xx_models[STAC_92HD73XX_MODELS] = {
1550         [STAC_92HD73XX_AUTO] = "auto",
1551         [STAC_92HD73XX_NO_JD] = "no-jd",
1552         [STAC_92HD73XX_REF] = "ref",
1553         [STAC_92HD73XX_INTEL] = "intel",
1554         [STAC_DELL_M6_AMIC] = "dell-m6-amic",
1555         [STAC_DELL_M6_DMIC] = "dell-m6-dmic",
1556         [STAC_DELL_M6_BOTH] = "dell-m6",
1557         [STAC_DELL_EQ] = "dell-eq",
1558         [STAC_ALIENWARE_M17X] = "alienware",
1559 };
1560
1561 static struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = {
1562         /* SigmaTel reference board */
1563         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1564                                 "DFI LanParty", STAC_92HD73XX_REF),
1565         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1566                                 "DFI LanParty", STAC_92HD73XX_REF),
1567         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5002,
1568                                 "Intel DG45ID", STAC_92HD73XX_INTEL),
1569         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5003,
1570                                 "Intel DG45FC", STAC_92HD73XX_INTEL),
1571         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0254,
1572                                 "Dell Studio 1535", STAC_DELL_M6_DMIC),
1573         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0255,
1574                                 "unknown Dell", STAC_DELL_M6_DMIC),
1575         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0256,
1576                                 "unknown Dell", STAC_DELL_M6_BOTH),
1577         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0257,
1578                                 "unknown Dell", STAC_DELL_M6_BOTH),
1579         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025e,
1580                                 "unknown Dell", STAC_DELL_M6_AMIC),
1581         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025f,
1582                                 "unknown Dell", STAC_DELL_M6_AMIC),
1583         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0271,
1584                                 "unknown Dell", STAC_DELL_M6_DMIC),
1585         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0272,
1586                                 "unknown Dell", STAC_DELL_M6_DMIC),
1587         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x029f,
1588                                 "Dell Studio 1537", STAC_DELL_M6_DMIC),
1589         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0,
1590                                 "Dell Studio 17", STAC_DELL_M6_DMIC),
1591         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02be,
1592                                 "Dell Studio 1555", STAC_DELL_M6_DMIC),
1593         {} /* terminator */
1594 };
1595
1596 static struct snd_pci_quirk stac92hd73xx_codec_id_cfg_tbl[] = {
1597         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a1,
1598                       "Alienware M17x", STAC_ALIENWARE_M17X),
1599         {} /* terminator */
1600 };
1601
1602 static unsigned int ref92hd83xxx_pin_configs[10] = {
1603         0x02214030, 0x02211010, 0x02a19020, 0x02170130,
1604         0x01014050, 0x01819040, 0x01014020, 0x90a3014e,
1605         0x01451160, 0x98560170,
1606 };
1607
1608 static unsigned int dell_s14_pin_configs[10] = {
1609         0x0221403f, 0x0221101f, 0x02a19020, 0x90170110,
1610         0x40f000f0, 0x40f000f0, 0x40f000f0, 0x90a60160,
1611         0x40f000f0, 0x40f000f0,
1612 };
1613
1614 static unsigned int *stac92hd83xxx_brd_tbl[STAC_92HD83XXX_MODELS] = {
1615         [STAC_92HD83XXX_REF] = ref92hd83xxx_pin_configs,
1616         [STAC_92HD83XXX_PWR_REF] = ref92hd83xxx_pin_configs,
1617         [STAC_DELL_S14] = dell_s14_pin_configs,
1618 };
1619
1620 static const char *stac92hd83xxx_models[STAC_92HD83XXX_MODELS] = {
1621         [STAC_92HD83XXX_AUTO] = "auto",
1622         [STAC_92HD83XXX_REF] = "ref",
1623         [STAC_92HD83XXX_PWR_REF] = "mic-ref",
1624         [STAC_DELL_S14] = "dell-s14",
1625 };
1626
1627 static struct snd_pci_quirk stac92hd83xxx_cfg_tbl[] = {
1628         /* SigmaTel reference board */
1629         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1630                       "DFI LanParty", STAC_92HD83XXX_REF),
1631         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1632                       "DFI LanParty", STAC_92HD83XXX_REF),
1633         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ba,
1634                       "unknown Dell", STAC_DELL_S14),
1635         {} /* terminator */
1636 };
1637
1638 static unsigned int ref92hd71bxx_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1639         0x02214030, 0x02a19040, 0x01a19020, 0x01014010,
1640         0x0181302e, 0x01014010, 0x01019020, 0x90a000f0,
1641         0x90a000f0, 0x01452050, 0x01452050, 0x00000000,
1642         0x00000000
1643 };
1644
1645 static unsigned int dell_m4_1_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1646         0x0421101f, 0x04a11221, 0x40f000f0, 0x90170110,
1647         0x23a1902e, 0x23014250, 0x40f000f0, 0x90a000f0,
1648         0x40f000f0, 0x4f0000f0, 0x4f0000f0, 0x00000000,
1649         0x00000000
1650 };
1651
1652 static unsigned int dell_m4_2_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1653         0x0421101f, 0x04a11221, 0x90a70330, 0x90170110,
1654         0x23a1902e, 0x23014250, 0x40f000f0, 0x40f000f0,
1655         0x40f000f0, 0x044413b0, 0x044413b0, 0x00000000,
1656         0x00000000
1657 };
1658
1659 static unsigned int dell_m4_3_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1660         0x0421101f, 0x04a11221, 0x90a70330, 0x90170110,
1661         0x40f000f0, 0x40f000f0, 0x40f000f0, 0x90a000f0,
1662         0x40f000f0, 0x044413b0, 0x044413b0, 0x00000000,
1663         0x00000000
1664 };
1665
1666 static unsigned int *stac92hd71bxx_brd_tbl[STAC_92HD71BXX_MODELS] = {
1667         [STAC_92HD71BXX_REF] = ref92hd71bxx_pin_configs,
1668         [STAC_DELL_M4_1]        = dell_m4_1_pin_configs,
1669         [STAC_DELL_M4_2]        = dell_m4_2_pin_configs,
1670         [STAC_DELL_M4_3]        = dell_m4_3_pin_configs,
1671         [STAC_HP_M4]            = NULL,
1672         [STAC_HP_DV5]           = NULL,
1673         [STAC_HP_HDX]           = NULL,
1674         [STAC_HP_DV4_1222NR]    = NULL,
1675 };
1676
1677 static const char *stac92hd71bxx_models[STAC_92HD71BXX_MODELS] = {
1678         [STAC_92HD71BXX_AUTO] = "auto",
1679         [STAC_92HD71BXX_REF] = "ref",
1680         [STAC_DELL_M4_1] = "dell-m4-1",
1681         [STAC_DELL_M4_2] = "dell-m4-2",
1682         [STAC_DELL_M4_3] = "dell-m4-3",
1683         [STAC_HP_M4] = "hp-m4",
1684         [STAC_HP_DV5] = "hp-dv5",
1685         [STAC_HP_HDX] = "hp-hdx",
1686         [STAC_HP_DV4_1222NR] = "hp-dv4-1222nr",
1687 };
1688
1689 static struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = {
1690         /* SigmaTel reference board */
1691         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1692                       "DFI LanParty", STAC_92HD71BXX_REF),
1693         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1694                       "DFI LanParty", STAC_92HD71BXX_REF),
1695         SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30fb,
1696                       "HP dv4-1222nr", STAC_HP_DV4_1222NR),
1697         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x1720,
1698                           "HP", STAC_HP_DV5),
1699         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3080,
1700                       "HP", STAC_HP_DV5),
1701         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x30f0,
1702                       "HP dv4-7", STAC_HP_DV5),
1703         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3600,
1704                       "HP dv4-7", STAC_HP_DV5),
1705         SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3610,
1706                       "HP HDX", STAC_HP_HDX),  /* HDX18 */
1707         SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361a,
1708                       "HP mini 1000", STAC_HP_M4),
1709         SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361b,
1710                       "HP HDX", STAC_HP_HDX),  /* HDX16 */
1711         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3620,
1712                       "HP dv6", STAC_HP_DV5),
1713         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x7010,
1714                       "HP", STAC_HP_DV5),
1715         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0233,
1716                                 "unknown Dell", STAC_DELL_M4_1),
1717         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0234,
1718                                 "unknown Dell", STAC_DELL_M4_1),
1719         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0250,
1720                                 "unknown Dell", STAC_DELL_M4_1),
1721         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024f,
1722                                 "unknown Dell", STAC_DELL_M4_1),
1723         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024d,
1724                                 "unknown Dell", STAC_DELL_M4_1),
1725         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0251,
1726                                 "unknown Dell", STAC_DELL_M4_1),
1727         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0277,
1728                                 "unknown Dell", STAC_DELL_M4_1),
1729         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0263,
1730                                 "unknown Dell", STAC_DELL_M4_2),
1731         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0265,
1732                                 "unknown Dell", STAC_DELL_M4_2),
1733         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0262,
1734                                 "unknown Dell", STAC_DELL_M4_2),
1735         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0264,
1736                                 "unknown Dell", STAC_DELL_M4_2),
1737         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02aa,
1738                                 "unknown Dell", STAC_DELL_M4_3),
1739         {} /* terminator */
1740 };
1741
1742 static unsigned int ref922x_pin_configs[10] = {
1743         0x01014010, 0x01016011, 0x01012012, 0x0221401f,
1744         0x01813122, 0x01011014, 0x01441030, 0x01c41030,
1745         0x40000100, 0x40000100,
1746 };
1747
1748 /*
1749     STAC 922X pin configs for
1750     102801A7
1751     102801AB
1752     102801A9
1753     102801D1
1754     102801D2
1755 */
1756 static unsigned int dell_922x_d81_pin_configs[10] = {
1757         0x02214030, 0x01a19021, 0x01111012, 0x01114010,
1758         0x02a19020, 0x01117011, 0x400001f0, 0x400001f1,
1759         0x01813122, 0x400001f2,
1760 };
1761
1762 /*
1763     STAC 922X pin configs for
1764     102801AC
1765     102801D0
1766 */
1767 static unsigned int dell_922x_d82_pin_configs[10] = {
1768         0x02214030, 0x01a19021, 0x01111012, 0x01114010,
1769         0x02a19020, 0x01117011, 0x01451140, 0x400001f0,
1770         0x01813122, 0x400001f1,
1771 };
1772
1773 /*
1774     STAC 922X pin configs for
1775     102801BF
1776 */
1777 static unsigned int dell_922x_m81_pin_configs[10] = {
1778         0x0321101f, 0x01112024, 0x01111222, 0x91174220,
1779         0x03a11050, 0x01116221, 0x90a70330, 0x01452340, 
1780         0x40C003f1, 0x405003f0,
1781 };
1782
1783 /*
1784     STAC 9221 A1 pin configs for
1785     102801D7 (Dell XPS M1210)
1786 */
1787 static unsigned int dell_922x_m82_pin_configs[10] = {
1788         0x02211211, 0x408103ff, 0x02a1123e, 0x90100310, 
1789         0x408003f1, 0x0221121f, 0x03451340, 0x40c003f2, 
1790         0x508003f3, 0x405003f4, 
1791 };
1792
1793 static unsigned int d945gtp3_pin_configs[10] = {
1794         0x0221401f, 0x01a19022, 0x01813021, 0x01014010,
1795         0x40000100, 0x40000100, 0x40000100, 0x40000100,
1796         0x02a19120, 0x40000100,
1797 };
1798
1799 static unsigned int d945gtp5_pin_configs[10] = {
1800         0x0221401f, 0x01011012, 0x01813024, 0x01014010,
1801         0x01a19021, 0x01016011, 0x01452130, 0x40000100,
1802         0x02a19320, 0x40000100,
1803 };
1804
1805 static unsigned int intel_mac_v1_pin_configs[10] = {
1806         0x0121e21f, 0x400000ff, 0x9017e110, 0x400000fd,
1807         0x400000fe, 0x0181e020, 0x1145e030, 0x11c5e240,
1808         0x400000fc, 0x400000fb,
1809 };
1810
1811 static unsigned int intel_mac_v2_pin_configs[10] = {
1812         0x0121e21f, 0x90a7012e, 0x9017e110, 0x400000fd,
1813         0x400000fe, 0x0181e020, 0x1145e230, 0x500000fa,
1814         0x400000fc, 0x400000fb,
1815 };
1816
1817 static unsigned int intel_mac_v3_pin_configs[10] = {
1818         0x0121e21f, 0x90a7012e, 0x9017e110, 0x400000fd,
1819         0x400000fe, 0x0181e020, 0x1145e230, 0x11c5e240,
1820         0x400000fc, 0x400000fb,
1821 };
1822
1823 static unsigned int intel_mac_v4_pin_configs[10] = {
1824         0x0321e21f, 0x03a1e02e, 0x9017e110, 0x9017e11f,
1825         0x400000fe, 0x0381e020, 0x1345e230, 0x13c5e240,
1826         0x400000fc, 0x400000fb,
1827 };
1828
1829 static unsigned int intel_mac_v5_pin_configs[10] = {
1830         0x0321e21f, 0x03a1e02e, 0x9017e110, 0x9017e11f,
1831         0x400000fe, 0x0381e020, 0x1345e230, 0x13c5e240,
1832         0x400000fc, 0x400000fb,
1833 };
1834
1835 static unsigned int ecs202_pin_configs[10] = {
1836         0x0221401f, 0x02a19020, 0x01a19020, 0x01114010,
1837         0x408000f0, 0x01813022, 0x074510a0, 0x40c400f1,
1838         0x9037012e, 0x40e000f2,
1839 };
1840
1841 static unsigned int *stac922x_brd_tbl[STAC_922X_MODELS] = {
1842         [STAC_D945_REF] = ref922x_pin_configs,
1843         [STAC_D945GTP3] = d945gtp3_pin_configs,
1844         [STAC_D945GTP5] = d945gtp5_pin_configs,
1845         [STAC_INTEL_MAC_V1] = intel_mac_v1_pin_configs,
1846         [STAC_INTEL_MAC_V2] = intel_mac_v2_pin_configs,
1847         [STAC_INTEL_MAC_V3] = intel_mac_v3_pin_configs,
1848         [STAC_INTEL_MAC_V4] = intel_mac_v4_pin_configs,
1849         [STAC_INTEL_MAC_V5] = intel_mac_v5_pin_configs,
1850         [STAC_INTEL_MAC_AUTO] = intel_mac_v3_pin_configs,
1851         /* for backward compatibility */
1852         [STAC_MACMINI] = intel_mac_v3_pin_configs,
1853         [STAC_MACBOOK] = intel_mac_v5_pin_configs,
1854         [STAC_MACBOOK_PRO_V1] = intel_mac_v3_pin_configs,
1855         [STAC_MACBOOK_PRO_V2] = intel_mac_v3_pin_configs,
1856         [STAC_IMAC_INTEL] = intel_mac_v2_pin_configs,
1857         [STAC_IMAC_INTEL_20] = intel_mac_v3_pin_configs,
1858         [STAC_ECS_202] = ecs202_pin_configs,
1859         [STAC_922X_DELL_D81] = dell_922x_d81_pin_configs,
1860         [STAC_922X_DELL_D82] = dell_922x_d82_pin_configs,       
1861         [STAC_922X_DELL_M81] = dell_922x_m81_pin_configs,
1862         [STAC_922X_DELL_M82] = dell_922x_m82_pin_configs,       
1863 };
1864
1865 static const char *stac922x_models[STAC_922X_MODELS] = {
1866         [STAC_922X_AUTO] = "auto",
1867         [STAC_D945_REF] = "ref",
1868         [STAC_D945GTP5] = "5stack",
1869         [STAC_D945GTP3] = "3stack",
1870         [STAC_INTEL_MAC_V1] = "intel-mac-v1",
1871         [STAC_INTEL_MAC_V2] = "intel-mac-v2",
1872         [STAC_INTEL_MAC_V3] = "intel-mac-v3",
1873         [STAC_INTEL_MAC_V4] = "intel-mac-v4",
1874         [STAC_INTEL_MAC_V5] = "intel-mac-v5",
1875         [STAC_INTEL_MAC_AUTO] = "intel-mac-auto",
1876         /* for backward compatibility */
1877         [STAC_MACMINI]  = "macmini",
1878         [STAC_MACBOOK]  = "macbook",
1879         [STAC_MACBOOK_PRO_V1]   = "macbook-pro-v1",
1880         [STAC_MACBOOK_PRO_V2]   = "macbook-pro",
1881         [STAC_IMAC_INTEL] = "imac-intel",
1882         [STAC_IMAC_INTEL_20] = "imac-intel-20",
1883         [STAC_ECS_202] = "ecs202",
1884         [STAC_922X_DELL_D81] = "dell-d81",
1885         [STAC_922X_DELL_D82] = "dell-d82",
1886         [STAC_922X_DELL_M81] = "dell-m81",
1887         [STAC_922X_DELL_M82] = "dell-m82",
1888 };
1889
1890 static struct snd_pci_quirk stac922x_cfg_tbl[] = {
1891         /* SigmaTel reference board */
1892         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1893                       "DFI LanParty", STAC_D945_REF),
1894         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1895                       "DFI LanParty", STAC_D945_REF),
1896         /* Intel 945G based systems */
1897         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0101,
1898                       "Intel D945G", STAC_D945GTP3),
1899         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0202,
1900                       "Intel D945G", STAC_D945GTP3),
1901         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0606,
1902                       "Intel D945G", STAC_D945GTP3),
1903         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0601,
1904                       "Intel D945G", STAC_D945GTP3),
1905         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0111,
1906                       "Intel D945G", STAC_D945GTP3),
1907         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1115,
1908                       "Intel D945G", STAC_D945GTP3),
1909         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1116,
1910                       "Intel D945G", STAC_D945GTP3),
1911         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1117,
1912                       "Intel D945G", STAC_D945GTP3),
1913         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1118,
1914                       "Intel D945G", STAC_D945GTP3),
1915         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1119,
1916                       "Intel D945G", STAC_D945GTP3),
1917         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x8826,
1918                       "Intel D945G", STAC_D945GTP3),
1919         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5049,
1920                       "Intel D945G", STAC_D945GTP3),
1921         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5055,
1922                       "Intel D945G", STAC_D945GTP3),
1923         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5048,
1924                       "Intel D945G", STAC_D945GTP3),
1925         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0110,
1926                       "Intel D945G", STAC_D945GTP3),
1927         /* Intel D945G 5-stack systems */
1928         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0404,
1929                       "Intel D945G", STAC_D945GTP5),
1930         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0303,
1931                       "Intel D945G", STAC_D945GTP5),
1932         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0013,
1933                       "Intel D945G", STAC_D945GTP5),
1934         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0417,
1935                       "Intel D945G", STAC_D945GTP5),
1936         /* Intel 945P based systems */
1937         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0b0b,
1938                       "Intel D945P", STAC_D945GTP3),
1939         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0112,
1940                       "Intel D945P", STAC_D945GTP3),
1941         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0d0d,
1942                       "Intel D945P", STAC_D945GTP3),
1943         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0909,
1944                       "Intel D945P", STAC_D945GTP3),
1945         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0505,
1946                       "Intel D945P", STAC_D945GTP3),
1947         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0707,
1948                       "Intel D945P", STAC_D945GTP5),
1949         /* other intel */
1950         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0204,
1951                       "Intel D945", STAC_D945_REF),
1952         /* other systems  */
1953         /* Apple Intel Mac (Mac Mini, MacBook, MacBook Pro...) */
1954         SND_PCI_QUIRK(0x8384, 0x7680,
1955                       "Mac", STAC_INTEL_MAC_AUTO),
1956         /* Dell systems  */
1957         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a7,
1958                       "unknown Dell", STAC_922X_DELL_D81),
1959         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a9,
1960                       "unknown Dell", STAC_922X_DELL_D81),
1961         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ab,
1962                       "unknown Dell", STAC_922X_DELL_D81),
1963         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ac,
1964                       "unknown Dell", STAC_922X_DELL_D82),
1965         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bf,
1966                       "unknown Dell", STAC_922X_DELL_M81),
1967         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d0,
1968                       "unknown Dell", STAC_922X_DELL_D82),
1969         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d1,
1970                       "unknown Dell", STAC_922X_DELL_D81),
1971         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d2,
1972                       "unknown Dell", STAC_922X_DELL_D81),
1973         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d7,
1974                       "Dell XPS M1210", STAC_922X_DELL_M82),
1975         /* ECS/PC Chips boards */
1976         SND_PCI_QUIRK_MASK(0x1019, 0xf000, 0x2000,
1977                       "ECS/PC chips", STAC_ECS_202),
1978         {} /* terminator */
1979 };
1980
1981 static unsigned int ref927x_pin_configs[14] = {
1982         0x02214020, 0x02a19080, 0x0181304e, 0x01014010,
1983         0x01a19040, 0x01011012, 0x01016011, 0x0101201f, 
1984         0x183301f0, 0x18a001f0, 0x18a001f0, 0x01442070,
1985         0x01c42190, 0x40000100,
1986 };
1987
1988 static unsigned int d965_3st_pin_configs[14] = {
1989         0x0221401f, 0x02a19120, 0x40000100, 0x01014011,
1990         0x01a19021, 0x01813024, 0x40000100, 0x40000100,
1991         0x40000100, 0x40000100, 0x40000100, 0x40000100,
1992         0x40000100, 0x40000100
1993 };
1994
1995 static unsigned int d965_5st_pin_configs[14] = {
1996         0x02214020, 0x02a19080, 0x0181304e, 0x01014010,
1997         0x01a19040, 0x01011012, 0x01016011, 0x40000100,
1998         0x40000100, 0x40000100, 0x40000100, 0x01442070,
1999         0x40000100, 0x40000100
2000 };
2001
2002 static unsigned int d965_5st_no_fp_pin_configs[14] = {
2003         0x40000100, 0x40000100, 0x0181304e, 0x01014010,
2004         0x01a19040, 0x01011012, 0x01016011, 0x40000100,
2005         0x40000100, 0x40000100, 0x40000100, 0x01442070,
2006         0x40000100, 0x40000100
2007 };
2008
2009 static unsigned int dell_3st_pin_configs[14] = {
2010         0x02211230, 0x02a11220, 0x01a19040, 0x01114210,
2011         0x01111212, 0x01116211, 0x01813050, 0x01112214,
2012         0x403003fa, 0x90a60040, 0x90a60040, 0x404003fb,
2013         0x40c003fc, 0x40000100
2014 };
2015
2016 static unsigned int *stac927x_brd_tbl[STAC_927X_MODELS] = {
2017         [STAC_D965_REF_NO_JD] = ref927x_pin_configs,
2018         [STAC_D965_REF]  = ref927x_pin_configs,
2019         [STAC_D965_3ST]  = d965_3st_pin_configs,
2020         [STAC_D965_5ST]  = d965_5st_pin_configs,
2021         [STAC_D965_5ST_NO_FP]  = d965_5st_no_fp_pin_configs,
2022         [STAC_DELL_3ST]  = dell_3st_pin_configs,
2023         [STAC_DELL_BIOS] = NULL,
2024         [STAC_927X_VOLKNOB] = NULL,
2025 };
2026
2027 static const char *stac927x_models[STAC_927X_MODELS] = {
2028         [STAC_927X_AUTO]        = "auto",
2029         [STAC_D965_REF_NO_JD]   = "ref-no-jd",
2030         [STAC_D965_REF]         = "ref",
2031         [STAC_D965_3ST]         = "3stack",
2032         [STAC_D965_5ST]         = "5stack",
2033         [STAC_D965_5ST_NO_FP]   = "5stack-no-fp",
2034         [STAC_DELL_3ST]         = "dell-3stack",
2035         [STAC_DELL_BIOS]        = "dell-bios",
2036         [STAC_927X_VOLKNOB]     = "volknob",
2037 };
2038
2039 static struct snd_pci_quirk stac927x_cfg_tbl[] = {
2040         /* SigmaTel reference board */
2041         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2042                       "DFI LanParty", STAC_D965_REF),
2043         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2044                       "DFI LanParty", STAC_D965_REF),
2045          /* Intel 946 based systems */
2046         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x3d01, "Intel D946", STAC_D965_3ST),
2047         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xa301, "Intel D946", STAC_D965_3ST),
2048         /* 965 based 3 stack systems */
2049         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2100,
2050                            "Intel D965", STAC_D965_3ST),
2051         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2000,
2052                            "Intel D965", STAC_D965_3ST),
2053         /* Dell 3 stack systems */
2054         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f7, "Dell XPS M1730", STAC_DELL_3ST),
2055         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01dd, "Dell Dimension E520", STAC_DELL_3ST),
2056         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01ed, "Dell     ", STAC_DELL_3ST),
2057         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f4, "Dell     ", STAC_DELL_3ST),
2058         /* Dell 3 stack systems with verb table in BIOS */
2059         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f3, "Dell Inspiron 1420", STAC_DELL_BIOS),
2060         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0227, "Dell Vostro 1400  ", STAC_DELL_BIOS),
2061         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022e, "Dell     ", STAC_DELL_BIOS),
2062         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022f, "Dell Inspiron 1525", STAC_DELL_BIOS),
2063         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0242, "Dell     ", STAC_DELL_BIOS),
2064         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0243, "Dell     ", STAC_DELL_BIOS),
2065         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x02ff, "Dell     ", STAC_DELL_BIOS),
2066         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0209, "Dell XPS 1330", STAC_DELL_BIOS),
2067         /* 965 based 5 stack systems */
2068         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2300,
2069                            "Intel D965", STAC_D965_5ST),
2070         SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2500,
2071                            "Intel D965", STAC_D965_5ST),
2072         /* volume-knob fixes */
2073         SND_PCI_QUIRK_VENDOR(0x10cf, "FSC", STAC_927X_VOLKNOB),
2074         {} /* terminator */
2075 };
2076
2077 static unsigned int ref9205_pin_configs[12] = {
2078         0x40000100, 0x40000100, 0x01016011, 0x01014010,
2079         0x01813122, 0x01a19021, 0x01019020, 0x40000100,
2080         0x90a000f0, 0x90a000f0, 0x01441030, 0x01c41030
2081 };
2082
2083 /*
2084     STAC 9205 pin configs for
2085     102801F1
2086     102801F2
2087     102801FC
2088     102801FD
2089     10280204
2090     1028021F
2091     10280228 (Dell Vostro 1500)
2092 */
2093 static unsigned int dell_9205_m42_pin_configs[12] = {
2094         0x0321101F, 0x03A11020, 0x400003FA, 0x90170310,
2095         0x400003FB, 0x400003FC, 0x400003FD, 0x40F000F9,
2096         0x90A60330, 0x400003FF, 0x0144131F, 0x40C003FE,
2097 };
2098
2099 /*
2100     STAC 9205 pin configs for
2101     102801F9
2102     102801FA
2103     102801FE
2104     102801FF (Dell Precision M4300)
2105     10280206
2106     10280200
2107     10280201
2108 */
2109 static unsigned int dell_9205_m43_pin_configs[12] = {
2110         0x0321101f, 0x03a11020, 0x90a70330, 0x90170310,
2111         0x400000fe, 0x400000ff, 0x400000fd, 0x40f000f9,
2112         0x400000fa, 0x400000fc, 0x0144131f, 0x40c003f8,
2113 };
2114
2115 static unsigned int dell_9205_m44_pin_configs[12] = {
2116         0x0421101f, 0x04a11020, 0x400003fa, 0x90170310,
2117         0x400003fb, 0x400003fc, 0x400003fd, 0x400003f9,
2118         0x90a60330, 0x400003ff, 0x01441340, 0x40c003fe,
2119 };
2120
2121 static unsigned int *stac9205_brd_tbl[STAC_9205_MODELS] = {
2122         [STAC_9205_REF] = ref9205_pin_configs,
2123         [STAC_9205_DELL_M42] = dell_9205_m42_pin_configs,
2124         [STAC_9205_DELL_M43] = dell_9205_m43_pin_configs,
2125         [STAC_9205_DELL_M44] = dell_9205_m44_pin_configs,
2126         [STAC_9205_EAPD] = NULL,
2127 };
2128
2129 static const char *stac9205_models[STAC_9205_MODELS] = {
2130         [STAC_9205_AUTO] = "auto",
2131         [STAC_9205_REF] = "ref",
2132         [STAC_9205_DELL_M42] = "dell-m42",
2133         [STAC_9205_DELL_M43] = "dell-m43",
2134         [STAC_9205_DELL_M44] = "dell-m44",
2135         [STAC_9205_EAPD] = "eapd",
2136 };
2137
2138 static struct snd_pci_quirk stac9205_cfg_tbl[] = {
2139         /* SigmaTel reference board */
2140         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2141                       "DFI LanParty", STAC_9205_REF),
2142         SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xfb30,
2143                       "SigmaTel", STAC_9205_REF),
2144         SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2145                       "DFI LanParty", STAC_9205_REF),
2146         /* Dell */
2147         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f1,
2148                       "unknown Dell", STAC_9205_DELL_M42),
2149         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f2,
2150                       "unknown Dell", STAC_9205_DELL_M42),
2151         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f8,
2152                       "Dell Precision", STAC_9205_DELL_M43),
2153         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f9,
2154                       "Dell Precision", STAC_9205_DELL_M43),
2155         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fa,
2156                       "Dell Precision", STAC_9205_DELL_M43),
2157         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fc,
2158                       "unknown Dell", STAC_9205_DELL_M42),
2159         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fd,
2160                       "unknown Dell", STAC_9205_DELL_M42),
2161         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fe,
2162                       "Dell Precision", STAC_9205_DELL_M43),
2163         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ff,
2164                       "Dell Precision M4300", STAC_9205_DELL_M43),
2165         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0204,
2166                       "unknown Dell", STAC_9205_DELL_M42),
2167         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0206,
2168                       "Dell Precision", STAC_9205_DELL_M43),
2169         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021b,
2170                       "Dell Precision", STAC_9205_DELL_M43),
2171         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021c,
2172                       "Dell Precision", STAC_9205_DELL_M43),
2173         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021f,
2174                       "Dell Inspiron", STAC_9205_DELL_M44),
2175         SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0228,
2176                       "Dell Vostro 1500", STAC_9205_DELL_M42),
2177         /* Gateway */
2178         SND_PCI_QUIRK(0x107b, 0x0560, "Gateway T6834c", STAC_9205_EAPD),
2179         SND_PCI_QUIRK(0x107b, 0x0565, "Gateway T1616", STAC_9205_EAPD),
2180         {} /* terminator */
2181 };
2182
2183 static void stac92xx_set_config_regs(struct hda_codec *codec,
2184                                      unsigned int *pincfgs)
2185 {
2186         int i;
2187         struct sigmatel_spec *spec = codec->spec;
2188
2189         if (!pincfgs)
2190                 return;
2191
2192         for (i = 0; i < spec->num_pins; i++)
2193                 if (spec->pin_nids[i] && pincfgs[i])
2194                         snd_hda_codec_set_pincfg(codec, spec->pin_nids[i],
2195                                                  pincfgs[i]);
2196 }
2197
2198 /*
2199  * Analog playback callbacks
2200  */
2201 static int stac92xx_playback_pcm_open(struct hda_pcm_stream *hinfo,
2202                                       struct hda_codec *codec,
2203                                       struct snd_pcm_substream *substream)
2204 {
2205         struct sigmatel_spec *spec = codec->spec;
2206         if (spec->stream_delay)
2207                 msleep(spec->stream_delay);
2208         return snd_hda_multi_out_analog_open(codec, &spec->multiout, substream,
2209                                              hinfo);
2210 }
2211
2212 static int stac92xx_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2213                                          struct hda_codec *codec,
2214                                          unsigned int stream_tag,
2215                                          unsigned int format,
2216                                          struct snd_pcm_substream *substream)
2217 {
2218         struct sigmatel_spec *spec = codec->spec;
2219         return snd_hda_multi_out_analog_prepare(codec, &spec->multiout, stream_tag, format, substream);
2220 }
2221
2222 static int stac92xx_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2223                                         struct hda_codec *codec,
2224                                         struct snd_pcm_substream *substream)
2225 {
2226         struct sigmatel_spec *spec = codec->spec;
2227         return snd_hda_multi_out_analog_cleanup(codec, &spec->multiout);
2228 }
2229
2230 /*
2231  * Digital playback callbacks
2232  */
2233 static int stac92xx_dig_playback_pcm_open(struct hda_pcm_stream *hinfo,
2234                                           struct hda_codec *codec,
2235                                           struct snd_pcm_substream *substream)
2236 {
2237         struct sigmatel_spec *spec = codec->spec;
2238         return snd_hda_multi_out_dig_open(codec, &spec->multiout);
2239 }
2240
2241 static int stac92xx_dig_playback_pcm_close(struct hda_pcm_stream *hinfo,
2242                                            struct hda_codec *codec,
2243                                            struct snd_pcm_substream *substream)
2244 {
2245         struct sigmatel_spec *spec = codec->spec;
2246         return snd_hda_multi_out_dig_close(codec, &spec->multiout);
2247 }
2248
2249 static int stac92xx_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2250                                          struct hda_codec *codec,
2251                                          unsigned int stream_tag,
2252                                          unsigned int format,
2253                                          struct snd_pcm_substream *substream)
2254 {
2255         struct sigmatel_spec *spec = codec->spec;
2256         return snd_hda_multi_out_dig_prepare(codec, &spec->multiout,
2257                                              stream_tag, format, substream);
2258 }
2259
2260 static int stac92xx_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2261                                         struct hda_codec *codec,
2262                                         struct snd_pcm_substream *substream)
2263 {
2264         struct sigmatel_spec *spec = codec->spec;
2265         return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
2266 }
2267
2268
2269 /*
2270  * Analog capture callbacks
2271  */
2272 static int stac92xx_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
2273                                         struct hda_codec *codec,
2274                                         unsigned int stream_tag,
2275                                         unsigned int format,
2276                                         struct snd_pcm_substream *substream)
2277 {
2278         struct sigmatel_spec *spec = codec->spec;
2279         hda_nid_t nid = spec->adc_nids[substream->number];
2280
2281         if (spec->powerdown_adcs) {
2282                 msleep(40);
2283                 snd_hda_codec_write(codec, nid, 0,
2284                         AC_VERB_SET_POWER_STATE, AC_PWRST_D0);
2285         }
2286         snd_hda_codec_setup_stream(codec, nid, stream_tag, 0, format);
2287         return 0;
2288 }
2289
2290 static int stac92xx_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
2291                                         struct hda_codec *codec,
2292                                         struct snd_pcm_substream *substream)
2293 {
2294         struct sigmatel_spec *spec = codec->spec;
2295         hda_nid_t nid = spec->adc_nids[substream->number];
2296
2297         snd_hda_codec_cleanup_stream(codec, nid);
2298         if (spec->powerdown_adcs)
2299                 snd_hda_codec_write(codec, nid, 0,
2300                         AC_VERB_SET_POWER_STATE, AC_PWRST_D3);
2301         return 0;
2302 }
2303
2304 static struct hda_pcm_stream stac92xx_pcm_digital_playback = {
2305         .substreams = 1,
2306         .channels_min = 2,
2307         .channels_max = 2,
2308         /* NID is set in stac92xx_build_pcms */
2309         .ops = {
2310                 .open = stac92xx_dig_playback_pcm_open,
2311                 .close = stac92xx_dig_playback_pcm_close,
2312                 .prepare = stac92xx_dig_playback_pcm_prepare,
2313                 .cleanup = stac92xx_dig_playback_pcm_cleanup
2314         },
2315 };
2316
2317 static struct hda_pcm_stream stac92xx_pcm_digital_capture = {
2318         .substreams = 1,
2319         .channels_min = 2,
2320         .channels_max = 2,
2321         /* NID is set in stac92xx_build_pcms */
2322 };
2323
2324 static struct hda_pcm_stream stac92xx_pcm_analog_playback = {
2325         .substreams = 1,
2326         .channels_min = 2,
2327         .channels_max = 8,
2328         .nid = 0x02, /* NID to query formats and rates */
2329         .ops = {
2330                 .open = stac92xx_playback_pcm_open,
2331                 .prepare = stac92xx_playback_pcm_prepare,
2332                 .cleanup = stac92xx_playback_pcm_cleanup
2333         },
2334 };
2335
2336 static struct hda_pcm_stream stac92xx_pcm_analog_alt_playback = {
2337         .substreams = 1,
2338         .channels_min = 2,
2339         .channels_max = 2,
2340         .nid = 0x06, /* NID to query formats and rates */
2341         .ops = {
2342                 .open = stac92xx_playback_pcm_open,
2343                 .prepare = stac92xx_playback_pcm_prepare,
2344                 .cleanup = stac92xx_playback_pcm_cleanup
2345         },
2346 };
2347
2348 static struct hda_pcm_stream stac92xx_pcm_analog_capture = {
2349         .channels_min = 2,
2350         .channels_max = 2,
2351         /* NID + .substreams is set in stac92xx_build_pcms */
2352         .ops = {
2353                 .prepare = stac92xx_capture_pcm_prepare,
2354                 .cleanup = stac92xx_capture_pcm_cleanup
2355         },
2356 };
2357
2358 static int stac92xx_build_pcms(struct hda_codec *codec)
2359 {
2360         struct sigmatel_spec *spec = codec->spec;
2361         struct hda_pcm *info = spec->pcm_rec;
2362
2363         codec->num_pcms = 1;
2364         codec->pcm_info = info;
2365
2366         info->name = "STAC92xx Analog";
2367         info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_analog_playback;
2368         info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid =
2369                 spec->multiout.dac_nids[0];
2370         info->stream[SNDRV_PCM_STREAM_CAPTURE] = stac92xx_pcm_analog_capture;
2371         info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adc_nids[0];
2372         info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = spec->num_adcs;
2373
2374         if (spec->alt_switch) {
2375                 codec->num_pcms++;
2376                 info++;
2377                 info->name = "STAC92xx Analog Alt";
2378                 info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_analog_alt_playback;
2379         }
2380
2381         if (spec->multiout.dig_out_nid || spec->dig_in_nid) {
2382                 codec->num_pcms++;
2383                 info++;
2384                 info->name = "STAC92xx Digital";
2385                 info->pcm_type = spec->autocfg.dig_out_type[0];
2386                 if (spec->multiout.dig_out_nid) {
2387                         info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_digital_playback;
2388                         info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->multiout.dig_out_nid;
2389                 }
2390                 if (spec->dig_in_nid) {
2391                         info->stream[SNDRV_PCM_STREAM_CAPTURE] = stac92xx_pcm_digital_capture;
2392                         info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in_nid;
2393                 }
2394         }
2395
2396         return 0;
2397 }
2398
2399 static unsigned int stac92xx_get_default_vref(struct hda_codec *codec,
2400                                         hda_nid_t nid)
2401 {
2402         unsigned int pincap = snd_hda_query_pin_caps(codec, nid);
2403         pincap = (pincap & AC_PINCAP_VREF) >> AC_PINCAP_VREF_SHIFT;
2404         if (pincap & AC_PINCAP_VREF_100)
2405                 return AC_PINCTL_VREF_100;
2406         if (pincap & AC_PINCAP_VREF_80)
2407                 return AC_PINCTL_VREF_80;
2408         if (pincap & AC_PINCAP_VREF_50)
2409                 return AC_PINCTL_VREF_50;
2410         if (pincap & AC_PINCAP_VREF_GRD)
2411                 return AC_PINCTL_VREF_GRD;
2412         return 0;
2413 }
2414
2415 static void stac92xx_auto_set_pinctl(struct hda_codec *codec, hda_nid_t nid, int pin_type)
2416
2417 {
2418         snd_hda_codec_write_cache(codec, nid, 0,
2419                                   AC_VERB_SET_PIN_WIDGET_CONTROL, pin_type);
2420 }
2421
2422 #define stac92xx_hp_switch_info         snd_ctl_boolean_mono_info
2423
2424 static int stac92xx_hp_switch_get(struct snd_kcontrol *kcontrol,
2425                         struct snd_ctl_elem_value *ucontrol)
2426 {
2427         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2428         struct sigmatel_spec *spec = codec->spec;
2429
2430         ucontrol->value.integer.value[0] = !!spec->hp_switch;
2431         return 0;
2432 }
2433
2434 static void stac_issue_unsol_event(struct hda_codec *codec, hda_nid_t nid);
2435
2436 static int stac92xx_hp_switch_put(struct snd_kcontrol *kcontrol,
2437                         struct snd_ctl_elem_value *ucontrol)
2438 {
2439         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2440         struct sigmatel_spec *spec = codec->spec;
2441         int nid = kcontrol->private_value;
2442  
2443         spec->hp_switch = ucontrol->value.integer.value[0] ? nid : 0;
2444
2445         /* check to be sure that the ports are upto date with
2446          * switch changes
2447          */
2448         stac_issue_unsol_event(codec, nid);
2449
2450         return 1;
2451 }
2452
2453 static int stac92xx_dc_bias_info(struct snd_kcontrol *kcontrol,
2454                                 struct snd_ctl_elem_info *uinfo)
2455 {
2456         int i;
2457         static char *texts[] = {
2458                 "Mic In", "Line In", "Line Out"
2459         };
2460
2461         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2462         struct sigmatel_spec *spec = codec->spec;
2463         hda_nid_t nid = kcontrol->private_value;
2464
2465         if (nid == spec->mic_switch || nid == spec->line_switch)
2466                 i = 3;
2467         else
2468                 i = 2;
2469
2470         uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2471         uinfo->value.enumerated.items = i;
2472         uinfo->count = 1;
2473         if (uinfo->value.enumerated.item >= i)
2474                 uinfo->value.enumerated.item = i-1;
2475         strcpy(uinfo->value.enumerated.name,
2476                 texts[uinfo->value.enumerated.item]);
2477
2478         return 0;
2479 }
2480
2481 static int stac92xx_dc_bias_get(struct snd_kcontrol *kcontrol,
2482                                 struct snd_ctl_elem_value *ucontrol)
2483 {
2484         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2485         hda_nid_t nid = kcontrol->private_value;
2486         unsigned int vref = stac92xx_vref_get(codec, nid);
2487
2488         if (vref == stac92xx_get_default_vref(codec, nid))
2489                 ucontrol->value.enumerated.item[0] = 0;
2490         else if (vref == AC_PINCTL_VREF_GRD)
2491                 ucontrol->value.enumerated.item[0] = 1;
2492         else if (vref == AC_PINCTL_VREF_HIZ)
2493                 ucontrol->value.enumerated.item[0] = 2;
2494
2495         return 0;
2496 }
2497
2498 static int stac92xx_dc_bias_put(struct snd_kcontrol *kcontrol,
2499                                 struct snd_ctl_elem_value *ucontrol)
2500 {
2501         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2502         unsigned int new_vref = 0;
2503         int error;
2504         hda_nid_t nid = kcontrol->private_value;
2505
2506         if (ucontrol->value.enumerated.item[0] == 0)
2507                 new_vref = stac92xx_get_default_vref(codec, nid);
2508         else if (ucontrol->value.enumerated.item[0] == 1)
2509                 new_vref = AC_PINCTL_VREF_GRD;
2510         else if (ucontrol->value.enumerated.item[0] == 2)
2511                 new_vref = AC_PINCTL_VREF_HIZ;
2512         else
2513                 return 0;
2514
2515         if (new_vref != stac92xx_vref_get(codec, nid)) {
2516                 error = stac92xx_vref_set(codec, nid, new_vref);
2517                 return error;
2518         }
2519
2520         return 0;
2521 }
2522
2523 static int stac92xx_io_switch_info(struct snd_kcontrol *kcontrol,
2524                                 struct snd_ctl_elem_info *uinfo)
2525 {
2526         static char *texts[2];
2527         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2528         struct sigmatel_spec *spec = codec->spec;
2529
2530         if (kcontrol->private_value == spec->line_switch)
2531                 texts[0] = "Line In";
2532         else
2533                 texts[0] = "Mic In";
2534         texts[1] = "Line Out";
2535         uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2536         uinfo->value.enumerated.items = 2;
2537         uinfo->count = 1;
2538
2539         if (uinfo->value.enumerated.item >= 2)
2540                 uinfo->value.enumerated.item = 1;
2541         strcpy(uinfo->value.enumerated.name,
2542                 texts[uinfo->value.enumerated.item]);
2543
2544         return 0;
2545 }
2546
2547 static int stac92xx_io_switch_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2548 {
2549         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2550         struct sigmatel_spec *spec = codec->spec;
2551         hda_nid_t nid = kcontrol->private_value;
2552         int io_idx = (nid == spec->mic_switch) ? 1 : 0;
2553
2554         ucontrol->value.enumerated.item[0] = spec->io_switch[io_idx];
2555         return 0;
2556 }
2557
2558 static int stac92xx_io_switch_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2559 {
2560         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2561         struct sigmatel_spec *spec = codec->spec;
2562         hda_nid_t nid = kcontrol->private_value;
2563         int io_idx = (nid == spec->mic_switch) ? 1 : 0;
2564         unsigned short val = !!ucontrol->value.enumerated.item[0];
2565
2566         spec->io_switch[io_idx] = val;
2567
2568         if (val)
2569                 stac92xx_auto_set_pinctl(codec, nid, AC_PINCTL_OUT_EN);
2570         else {
2571                 unsigned int pinctl = AC_PINCTL_IN_EN;
2572                 if (io_idx) /* set VREF for mic */
2573                         pinctl |= stac92xx_get_default_vref(codec, nid);
2574                 stac92xx_auto_set_pinctl(codec, nid, pinctl);
2575         }
2576
2577         /* check the auto-mute again: we need to mute/unmute the speaker
2578          * appropriately according to the pin direction
2579          */
2580         if (spec->hp_detect)
2581                 stac_issue_unsol_event(codec, nid);
2582
2583         return 1;
2584 }
2585
2586 #define stac92xx_clfe_switch_info snd_ctl_boolean_mono_info
2587
2588 static int stac92xx_clfe_switch_get(struct snd_kcontrol *kcontrol,
2589                 struct snd_ctl_elem_value *ucontrol)
2590 {
2591         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2592         struct sigmatel_spec *spec = codec->spec;
2593
2594         ucontrol->value.integer.value[0] = spec->clfe_swap;
2595         return 0;
2596 }
2597
2598 static int stac92xx_clfe_switch_put(struct snd_kcontrol *kcontrol,
2599                 struct snd_ctl_elem_value *ucontrol)
2600 {
2601         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2602         struct sigmatel_spec *spec = codec->spec;
2603         hda_nid_t nid = kcontrol->private_value & 0xff;
2604         unsigned int val = !!ucontrol->value.integer.value[0];
2605
2606         if (spec->clfe_swap == val)
2607                 return 0;
2608
2609         spec->clfe_swap = val;
2610
2611         snd_hda_codec_write_cache(codec, nid, 0, AC_VERB_SET_EAPD_BTLENABLE,
2612                 spec->clfe_swap ? 0x4 : 0x0);
2613
2614         return 1;
2615 }
2616
2617 #define STAC_CODEC_HP_SWITCH(xname) \
2618         { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2619           .name = xname, \
2620           .index = 0, \
2621           .info = stac92xx_hp_switch_info, \
2622           .get = stac92xx_hp_switch_get, \
2623           .put = stac92xx_hp_switch_put, \
2624         }
2625
2626 #define STAC_CODEC_IO_SWITCH(xname, xpval) \
2627         { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2628           .name = xname, \
2629           .index = 0, \
2630           .info = stac92xx_io_switch_info, \
2631           .get = stac92xx_io_switch_get, \
2632           .put = stac92xx_io_switch_put, \
2633           .private_value = xpval, \
2634         }
2635
2636 #define STAC_CODEC_CLFE_SWITCH(xname, xpval) \
2637         { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2638           .name = xname, \
2639           .index = 0, \
2640           .info = stac92xx_clfe_switch_info, \
2641           .get = stac92xx_clfe_switch_get, \
2642           .put = stac92xx_clfe_switch_put, \
2643           .private_value = xpval, \
2644         }
2645
2646 enum {
2647         STAC_CTL_WIDGET_VOL,
2648         STAC_CTL_WIDGET_MUTE,
2649         STAC_CTL_WIDGET_MONO_MUX,
2650         STAC_CTL_WIDGET_HP_SWITCH,
2651         STAC_CTL_WIDGET_IO_SWITCH,
2652         STAC_CTL_WIDGET_CLFE_SWITCH,
2653         STAC_CTL_WIDGET_DC_BIAS
2654 };
2655
2656 static struct snd_kcontrol_new stac92xx_control_templates[] = {
2657         HDA_CODEC_VOLUME(NULL, 0, 0, 0),
2658         HDA_CODEC_MUTE(NULL, 0, 0, 0),
2659         STAC_MONO_MUX,
2660         STAC_CODEC_HP_SWITCH(NULL),
2661         STAC_CODEC_IO_SWITCH(NULL, 0),
2662         STAC_CODEC_CLFE_SWITCH(NULL, 0),
2663         DC_BIAS(NULL, 0, 0),
2664 };
2665
2666 /* add dynamic controls */
2667 static struct snd_kcontrol_new *
2668 stac_control_new(struct sigmatel_spec *spec,
2669                  struct snd_kcontrol_new *ktemp,
2670                  const char *name)
2671 {
2672         struct snd_kcontrol_new *knew;
2673
2674         snd_array_init(&spec->kctls, sizeof(*knew), 32);
2675         knew = snd_array_new(&spec->kctls);
2676         if (!knew)
2677                 return NULL;
2678         *knew = *ktemp;
2679         knew->name = kstrdup(name, GFP_KERNEL);
2680         if (!knew->name) {
2681                 /* roolback */
2682                 memset(knew, 0, sizeof(*knew));
2683                 spec->kctls.alloced--;
2684                 return NULL;
2685         }
2686         return knew;
2687 }
2688
2689 static int stac92xx_add_control_temp(struct sigmatel_spec *spec,
2690                                      struct snd_kcontrol_new *ktemp,
2691                                      int idx, const char *name,
2692                                      unsigned long val)
2693 {
2694         struct snd_kcontrol_new *knew = stac_control_new(spec, ktemp, name);
2695         if (!knew)
2696                 return -ENOMEM;
2697         knew->index = idx;
2698         knew->private_value = val;
2699         return 0;
2700 }
2701
2702 static inline int stac92xx_add_control_idx(struct sigmatel_spec *spec,
2703                                            int type, int idx, const char *name,
2704                                            unsigned long val)
2705 {
2706         return stac92xx_add_control_temp(spec,
2707                                          &stac92xx_control_templates[type],
2708                                          idx, name, val);
2709 }
2710
2711
2712 /* add dynamic controls */
2713 static inline int stac92xx_add_control(struct sigmatel_spec *spec, int type,
2714                                        const char *name, unsigned long val)
2715 {
2716         return stac92xx_add_control_idx(spec, type, 0, name, val);
2717 }
2718
2719 static struct snd_kcontrol_new stac_input_src_temp = {
2720         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
2721         .name = "Input Source",
2722         .info = stac92xx_mux_enum_info,
2723         .get = stac92xx_mux_enum_get,
2724         .put = stac92xx_mux_enum_put,
2725 };
2726
2727 static inline int stac92xx_add_jack_mode_control(struct hda_codec *codec,
2728                                                 hda_nid_t nid, int idx)
2729 {
2730         int def_conf = snd_hda_codec_get_pincfg(codec, nid);
2731         int control = 0;
2732         struct sigmatel_spec *spec = codec->spec;
2733         char name[22];
2734
2735         if (!((get_defcfg_connect(def_conf)) & AC_JACK_PORT_FIXED)) {
2736                 if (stac92xx_get_default_vref(codec, nid) == AC_PINCTL_VREF_GRD
2737                         && nid == spec->line_switch)
2738                         control = STAC_CTL_WIDGET_IO_SWITCH;
2739                 else if (snd_hda_query_pin_caps(codec, nid)
2740                         & (AC_PINCAP_VREF_GRD << AC_PINCAP_VREF_SHIFT))
2741                         control = STAC_CTL_WIDGET_DC_BIAS;
2742                 else if (nid == spec->mic_switch)
2743                         control = STAC_CTL_WIDGET_IO_SWITCH;
2744         }
2745
2746         if (control) {
2747                 strcpy(name, auto_pin_cfg_labels[idx]);
2748                 return stac92xx_add_control(codec->spec, control,
2749                                         strcat(name, " Jack Mode"), nid);
2750         }
2751
2752         return 0;
2753 }
2754
2755 static int stac92xx_add_input_source(struct sigmatel_spec *spec)
2756 {
2757         struct snd_kcontrol_new *knew;
2758         struct hda_input_mux *imux = &spec->private_imux;
2759
2760         if (spec->auto_mic)
2761                 return 0; /* no need for input source */
2762         if (!spec->num_adcs || imux->num_items <= 1)
2763                 return 0; /* no need for input source control */
2764         knew = stac_control_new(spec, &stac_input_src_temp,
2765                                 stac_input_src_temp.name);
2766         if (!knew)
2767                 return -ENOMEM;
2768         knew->count = spec->num_adcs;
2769         return 0;
2770 }
2771
2772 /* check whether the line-input can be used as line-out */
2773 static hda_nid_t check_line_out_switch(struct hda_codec *codec)
2774 {
2775         struct sigmatel_spec *spec = codec->spec;
2776         struct auto_pin_cfg *cfg = &spec->autocfg;
2777         hda_nid_t nid;
2778         unsigned int pincap;
2779
2780         if (cfg->line_out_type != AUTO_PIN_LINE_OUT)
2781                 return 0;
2782         nid = cfg->input_pins[AUTO_PIN_LINE];
2783         pincap = snd_hda_query_pin_caps(codec, nid);
2784         if (pincap & AC_PINCAP_OUT)
2785                 return nid;
2786         return 0;
2787 }
2788
2789 /* check whether the mic-input can be used as line-out */
2790 static hda_nid_t check_mic_out_switch(struct hda_codec *codec)
2791 {
2792         struct sigmatel_spec *spec = codec->spec;
2793         struct auto_pin_cfg *cfg = &spec->autocfg;
2794         unsigned int def_conf, pincap;
2795         unsigned int mic_pin;
2796
2797         if (cfg->line_out_type != AUTO_PIN_LINE_OUT)
2798                 return 0;
2799         mic_pin = AUTO_PIN_MIC;
2800         for (;;) {
2801                 hda_nid_t nid = cfg->input_pins[mic_pin];
2802                 def_conf = snd_hda_codec_get_pincfg(codec, nid);
2803                 /* some laptops have an internal analog microphone
2804                  * which can't be used as a output */
2805                 if (get_defcfg_connect(def_conf) != AC_JACK_PORT_FIXED) {
2806                         pincap = snd_hda_query_pin_caps(codec, nid);
2807                         if (pincap & AC_PINCAP_OUT)
2808                                 return nid;
2809                 }
2810                 if (mic_pin == AUTO_PIN_MIC)
2811                         mic_pin = AUTO_PIN_FRONT_MIC;
2812                 else
2813                         break;
2814         }
2815         return 0;
2816 }
2817
2818 static int is_in_dac_nids(struct sigmatel_spec *spec, hda_nid_t nid)
2819 {
2820         int i;
2821         
2822         for (i = 0; i < spec->multiout.num_dacs; i++) {
2823                 if (spec->multiout.dac_nids[i] == nid)
2824                         return 1;
2825         }
2826
2827         return 0;
2828 }
2829
2830 static int check_all_dac_nids(struct sigmatel_spec *spec, hda_nid_t nid)
2831 {
2832         int i;
2833         if (is_in_dac_nids(spec, nid))
2834                 return 1;
2835         for (i = 0; i < spec->autocfg.hp_outs; i++)
2836                 if (spec->hp_dacs[i] == nid)
2837                         return 1;
2838         for (i = 0; i < spec->autocfg.speaker_outs; i++)
2839                 if (spec->speaker_dacs[i] == nid)
2840                         return 1;
2841         return 0;
2842 }
2843
2844 static hda_nid_t get_unassigned_dac(struct hda_codec *codec, hda_nid_t nid)
2845 {
2846         struct sigmatel_spec *spec = codec->spec;
2847         int j, conn_len;
2848         hda_nid_t conn[HDA_MAX_CONNECTIONS];
2849         unsigned int wcaps, wtype;
2850
2851         conn_len = snd_hda_get_connections(codec, nid, conn,
2852                                            HDA_MAX_CONNECTIONS);
2853         for (j = 0; j < conn_len; j++) {
2854                 wcaps = get_wcaps(codec, conn[j]);
2855                 wtype = get_wcaps_type(wcaps);
2856                 /* we check only analog outputs */
2857                 if (wtype != AC_WID_AUD_OUT || (wcaps & AC_WCAP_DIGITAL))
2858                         continue;
2859                 /* if this route has a free DAC, assign it */
2860                 if (!check_all_dac_nids(spec, conn[j])) {
2861                         if (conn_len > 1) {
2862                                 /* select this DAC in the pin's input mux */
2863                                 snd_hda_codec_write_cache(codec, nid, 0,
2864                                                   AC_VERB_SET_CONNECT_SEL, j);
2865                         }
2866                         return conn[j];
2867                 }
2868         }
2869         /* if all DACs are already assigned, connect to the primary DAC */
2870         if (conn_len > 1) {
2871                 for (j = 0; j < conn_len; j++) {
2872                         if (conn[j] == spec->multiout.dac_nids[0]) {
2873                                 snd_hda_codec_write_cache(codec, nid, 0,
2874                                                   AC_VERB_SET_CONNECT_SEL, j);
2875                                 break;
2876                         }
2877                 }
2878         }
2879         return 0;
2880 }
2881
2882 static int add_spec_dacs(struct sigmatel_spec *spec, hda_nid_t nid);
2883 static int add_spec_extra_dacs(struct sigmatel_spec *spec, hda_nid_t nid);
2884
2885 /*
2886  * Fill in the dac_nids table from the parsed pin configuration
2887  * This function only works when every pin in line_out_pins[]
2888  * contains atleast one DAC in its connection list. Some 92xx
2889  * codecs are not connected directly to a DAC, such as the 9200
2890  * and 9202/925x. For those, dac_nids[] must be hard-coded.
2891  */
2892 static int stac92xx_auto_fill_dac_nids(struct hda_codec *codec)
2893 {
2894         struct sigmatel_spec *spec = codec->spec;
2895         struct auto_pin_cfg *cfg = &spec->autocfg;
2896         int i;
2897         hda_nid_t nid, dac;
2898         
2899         for (i = 0; i < cfg->line_outs; i++) {
2900                 nid = cfg->line_out_pins[i];
2901                 dac = get_unassigned_dac(codec, nid);
2902                 if (!dac) {
2903                         if (spec->multiout.num_dacs > 0) {
2904                                 /* we have already working output pins,
2905                                  * so let's drop the broken ones again
2906                                  */
2907                                 cfg->line_outs = spec->multiout.num_dacs;
2908                                 break;
2909                         }
2910                         /* error out, no available DAC found */
2911                         snd_printk(KERN_ERR
2912                                    "%s: No available DAC for pin 0x%x\n",
2913                                    __func__, nid);
2914                         return -ENODEV;
2915                 }
2916                 add_spec_dacs(spec, dac);
2917         }
2918
2919         for (i = 0; i < cfg->hp_outs; i++) {
2920                 nid = cfg->hp_pins[i];
2921                 dac = get_unassigned_dac(codec, nid);
2922                 if (dac) {
2923                         if (!spec->multiout.hp_nid)
2924                                 spec->multiout.hp_nid = dac;
2925                         else
2926                                 add_spec_extra_dacs(spec, dac);
2927                 }
2928                 spec->hp_dacs[i] = dac;
2929         }
2930
2931         for (i = 0; i < cfg->speaker_outs; i++) {
2932                 nid = cfg->speaker_pins[i];
2933                 dac = get_unassigned_dac(codec, nid);
2934                 if (dac)
2935                         add_spec_extra_dacs(spec, dac);
2936                 spec->speaker_dacs[i] = dac;
2937         }
2938
2939         /* add line-in as output */
2940         nid = check_line_out_switch(codec);
2941         if (nid) {
2942                 dac = get_unassigned_dac(codec, nid);
2943                 if (dac) {
2944                         snd_printdd("STAC: Add line-in 0x%x as output %d\n",
2945                                     nid, cfg->line_outs);
2946                         cfg->line_out_pins[cfg->line_outs] = nid;
2947                         cfg->line_outs++;
2948                         spec->line_switch = nid;
2949                         add_spec_dacs(spec, dac);
2950                 }
2951         }
2952         /* add mic as output */
2953         nid = check_mic_out_switch(codec);
2954         if (nid) {
2955                 dac = get_unassigned_dac(codec, nid);
2956                 if (dac) {
2957                         snd_printdd("STAC: Add mic-in 0x%x as output %d\n",
2958                                     nid, cfg->line_outs);
2959                         cfg->line_out_pins[cfg->line_outs] = nid;
2960                         cfg->line_outs++;
2961                         spec->mic_switch = nid;
2962                         add_spec_dacs(spec, dac);
2963                 }
2964         }
2965
2966         snd_printd("stac92xx: dac_nids=%d (0x%x/0x%x/0x%x/0x%x/0x%x)\n",
2967                    spec->multiout.num_dacs,
2968                    spec->multiout.dac_nids[0],
2969                    spec->multiout.dac_nids[1],
2970                    spec->multiout.dac_nids[2],
2971                    spec->multiout.dac_nids[3],
2972                    spec->multiout.dac_nids[4]);
2973
2974         return 0;
2975 }
2976
2977 /* create volume control/switch for the given prefx type */
2978 static int create_controls_idx(struct hda_codec *codec, const char *pfx,
2979                                int idx, hda_nid_t nid, int chs)
2980 {
2981         struct sigmatel_spec *spec = codec->spec;
2982         char name[32];
2983         int err;
2984
2985         if (!spec->check_volume_offset) {
2986                 unsigned int caps, step, nums, db_scale;
2987                 caps = query_amp_caps(codec, nid, HDA_OUTPUT);
2988                 step = (caps & AC_AMPCAP_STEP_SIZE) >>
2989                         AC_AMPCAP_STEP_SIZE_SHIFT;
2990                 step = (step + 1) * 25; /* in .01dB unit */
2991                 nums = (caps & AC_AMPCAP_NUM_STEPS) >>
2992                         AC_AMPCAP_NUM_STEPS_SHIFT;
2993                 db_scale = nums * step;
2994                 /* if dB scale is over -64dB, and finer enough,
2995                  * let's reduce it to half
2996                  */
2997                 if (db_scale > 6400 && nums >= 0x1f)
2998                         spec->volume_offset = nums / 2;
2999                 spec->check_volume_offset = 1;
3000         }
3001
3002         sprintf(name, "%s Playback Volume", pfx);
3003         err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_VOL, idx, name,
3004                 HDA_COMPOSE_AMP_VAL_OFS(nid, chs, 0, HDA_OUTPUT,
3005                                         spec->volume_offset));
3006         if (err < 0)
3007                 return err;
3008         sprintf(name, "%s Playback Switch", pfx);
3009         err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_MUTE, idx, name,
3010                                    HDA_COMPOSE_AMP_VAL(nid, chs, 0, HDA_OUTPUT));
3011         if (err < 0)
3012                 return err;
3013         return 0;
3014 }
3015
3016 #define create_controls(codec, pfx, nid, chs) \
3017         create_controls_idx(codec, pfx, 0, nid, chs)
3018
3019 static int add_spec_dacs(struct sigmatel_spec *spec, hda_nid_t nid)
3020 {
3021         if (spec->multiout.num_dacs > 4) {
3022                 printk(KERN_WARNING "stac92xx: No space for DAC 0x%x\n", nid);
3023                 return 1;
3024         } else {
3025                 spec->multiout.dac_nids[spec->multiout.num_dacs] = nid;
3026                 spec->multiout.num_dacs++;
3027         }
3028         return 0;
3029 }
3030
3031 static int add_spec_extra_dacs(struct sigmatel_spec *spec, hda_nid_t nid)
3032 {
3033         int i;
3034         for (i = 0; i < ARRAY_SIZE(spec->multiout.extra_out_nid); i++) {
3035                 if (!spec->multiout.extra_out_nid[i]) {
3036                         spec->multiout.extra_out_nid[i] = nid;
3037                         return 0;
3038                 }
3039         }
3040         printk(KERN_WARNING "stac92xx: No space for extra DAC 0x%x\n", nid);
3041         return 1;
3042 }
3043
3044 /* Create output controls
3045  * The mixer elements are named depending on the given type (AUTO_PIN_XXX_OUT)
3046  */
3047 static int create_multi_out_ctls(struct hda_codec *codec, int num_outs,
3048                                  const hda_nid_t *pins,
3049                                  const hda_nid_t *dac_nids,
3050                                  int type)
3051 {
3052         struct sigmatel_spec *spec = codec->spec;
3053         static const char *chname[4] = {
3054                 "Front", "Surround", NULL /*CLFE*/, "Side"
3055         };
3056         hda_nid_t nid;
3057         int i, err;
3058         unsigned int wid_caps;
3059
3060         for (i = 0; i < num_outs && i < ARRAY_SIZE(chname); i++) {
3061                 if (type == AUTO_PIN_HP_OUT && !spec->hp_detect) {
3062                         wid_caps = get_wcaps(codec, pins[i]);
3063                         if (wid_caps & AC_WCAP_UNSOL_CAP)
3064                                 spec->hp_detect = 1;
3065                 }
3066                 nid = dac_nids[i];
3067                 if (!nid)
3068                         continue;
3069                 if (type != AUTO_PIN_HP_OUT && i == 2) {
3070                         /* Center/LFE */
3071                         err = create_controls(codec, "Center", nid, 1);
3072                         if (err < 0)
3073                                 return err;
3074                         err = create_controls(codec, "LFE", nid, 2);
3075                         if (err < 0)
3076                                 return err;
3077
3078                         wid_caps = get_wcaps(codec, nid);
3079
3080                         if (wid_caps & AC_WCAP_LR_SWAP) {
3081                                 err = stac92xx_add_control(spec,
3082                                         STAC_CTL_WIDGET_CLFE_SWITCH,
3083                                         "Swap Center/LFE Playback Switch", nid);
3084
3085                                 if (err < 0)
3086                                         return err;
3087                         }
3088
3089                 } else {
3090                         const char *name;
3091                         int idx;
3092                         switch (type) {
3093                         case AUTO_PIN_HP_OUT:
3094                                 name = "Headphone";
3095                                 idx = i;
3096                                 break;
3097                         case AUTO_PIN_SPEAKER_OUT:
3098                                 name = "Speaker";
3099                                 idx = i;
3100                                 break;
3101                         default:
3102                                 name = chname[i];
3103                                 idx = 0;
3104                                 break;
3105                         }
3106                         err = create_controls_idx(codec, name, idx, nid, 3);
3107                         if (err < 0)
3108                                 return err;
3109                 }
3110         }
3111         return 0;
3112 }
3113
3114 static int stac92xx_add_capvol_ctls(struct hda_codec *codec, unsigned long vol,
3115                                     unsigned long sw, int idx)
3116 {
3117         int err;
3118         err = stac92xx_add_control_idx(codec->spec, STAC_CTL_WIDGET_VOL, idx,
3119                                        "Capture Volume", vol);
3120         if (err < 0)
3121                 return err;
3122         err = stac92xx_add_control_idx(codec->spec, STAC_CTL_WIDGET_MUTE, idx,
3123                                        "Capture Switch", sw);
3124         if (err < 0)
3125                 return err;
3126         return 0;
3127 }
3128
3129 /* add playback controls from the parsed DAC table */
3130 static int stac92xx_auto_create_multi_out_ctls(struct hda_codec *codec,
3131                                                const struct auto_pin_cfg *cfg)
3132 {
3133         struct sigmatel_spec *spec = codec->spec;
3134         hda_nid_t nid;
3135         int err;
3136         int idx;
3137
3138         err = create_multi_out_ctls(codec, cfg->line_outs, cfg->line_out_pins,
3139                                     spec->multiout.dac_nids,
3140                                     cfg->line_out_type);
3141         if (err < 0)
3142                 return err;
3143
3144         if (cfg->hp_outs > 1 && cfg->line_out_type == AUTO_PIN_LINE_OUT) {
3145                 err = stac92xx_add_control(spec,
3146                         STAC_CTL_WIDGET_HP_SWITCH,
3147                         "Headphone as Line Out Switch",
3148                         cfg->hp_pins[cfg->hp_outs - 1]);
3149                 if (err < 0)
3150                         return err;
3151         }
3152
3153         for (idx = AUTO_PIN_MIC; idx <= AUTO_PIN_FRONT_LINE; idx++) {
3154                 nid = cfg->input_pins[idx];
3155                 if (nid) {
3156                         err = stac92xx_add_jack_mode_control(codec, nid, idx);
3157                         if (err < 0)
3158                                 return err;
3159                 }
3160         }
3161
3162         return 0;
3163 }
3164
3165 /* add playback controls for Speaker and HP outputs */
3166 static int stac92xx_auto_create_hp_ctls(struct hda_codec *codec,
3167                                         struct auto_pin_cfg *cfg)
3168 {
3169         struct sigmatel_spec *spec = codec->spec;
3170         int err;
3171
3172         err = create_multi_out_ctls(codec, cfg->hp_outs, cfg->hp_pins,
3173                                     spec->hp_dacs, AUTO_PIN_HP_OUT);
3174         if (err < 0)
3175                 return err;
3176
3177         err = create_multi_out_ctls(codec, cfg->speaker_outs, cfg->speaker_pins,
3178                                     spec->speaker_dacs, AUTO_PIN_SPEAKER_OUT);
3179         if (err < 0)
3180                 return err;
3181
3182         return 0;
3183 }
3184
3185 /* labels for mono mux outputs */
3186 static const char *stac92xx_mono_labels[4] = {
3187         "DAC0", "DAC1", "Mixer", "DAC2"
3188 };
3189
3190 /* create mono mux for mono out on capable codecs */
3191 static int stac92xx_auto_create_mono_output_ctls(struct hda_codec *codec)
3192 {
3193         struct sigmatel_spec *spec = codec->spec;
3194         struct hda_input_mux *mono_mux = &spec->private_mono_mux;
3195         int i, num_cons;
3196         hda_nid_t con_lst[ARRAY_SIZE(stac92xx_mono_labels)];
3197
3198         num_cons = snd_hda_get_connections(codec,
3199                                 spec->mono_nid,
3200                                 con_lst,
3201                                 HDA_MAX_NUM_INPUTS);
3202         if (num_cons <= 0 || num_cons > ARRAY_SIZE(stac92xx_mono_labels))
3203                 return -EINVAL;
3204
3205         for (i = 0; i < num_cons; i++) {
3206                 mono_mux->items[mono_mux->num_items].label =
3207                                         stac92xx_mono_labels[i];
3208                 mono_mux->items[mono_mux->num_items].index = i;
3209                 mono_mux->num_items++;
3210         }
3211
3212         return stac92xx_add_control(spec, STAC_CTL_WIDGET_MONO_MUX,
3213                                 "Mono Mux", spec->mono_nid);
3214 }
3215
3216 /* create PC beep volume controls */
3217 static int stac92xx_auto_create_beep_ctls(struct hda_codec *codec,
3218                                                 hda_nid_t nid)
3219 {
3220         struct sigmatel_spec *spec = codec->spec;
3221         u32 caps = query_amp_caps(codec, nid, HDA_OUTPUT);
3222         int err;
3223
3224         /* check for mute support for the the amp */
3225         if ((caps & AC_AMPCAP_MUTE) >> AC_AMPCAP_MUTE_SHIFT) {
3226                 err = stac92xx_add_control(spec, STAC_CTL_WIDGET_MUTE,
3227                         "PC Beep Playback Switch",
3228                         HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT));
3229                         if (err < 0)
3230                                 return err;
3231         }
3232
3233         /* check to see if there is volume support for the amp */
3234         if ((caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT) {
3235                 err = stac92xx_add_control(spec, STAC_CTL_WIDGET_VOL,
3236                         "PC Beep Playback Volume",
3237                         HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT));
3238                         if (err < 0)
3239                                 return err;
3240         }
3241         return 0;
3242 }
3243
3244 #ifdef CONFIG_SND_HDA_INPUT_BEEP
3245 #define stac92xx_dig_beep_switch_info snd_ctl_boolean_mono_info
3246
3247 static int stac92xx_dig_beep_switch_get(struct snd_kcontrol *kcontrol,
3248                                         struct snd_ctl_elem_value *ucontrol)
3249 {
3250         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3251         ucontrol->value.integer.value[0] = codec->beep->enabled;
3252         return 0;
3253 }
3254
3255 static int stac92xx_dig_beep_switch_put(struct snd_kcontrol *kcontrol,
3256                                         struct snd_ctl_elem_value *ucontrol)
3257 {
3258         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3259         int enabled = !!ucontrol->value.integer.value[0];
3260         if (codec->beep->enabled != enabled) {
3261                 codec->beep->enabled = enabled;
3262                 return 1;
3263         }
3264         return 0;
3265 }
3266
3267 static struct snd_kcontrol_new stac92xx_dig_beep_ctrl = {
3268         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3269         .info = stac92xx_dig_beep_switch_info,
3270         .get = stac92xx_dig_beep_switch_get,
3271         .put = stac92xx_dig_beep_switch_put,
3272 };
3273
3274 static int stac92xx_beep_switch_ctl(struct hda_codec *codec)
3275 {
3276         return stac92xx_add_control_temp(codec->spec, &stac92xx_dig_beep_ctrl,
3277                                          0, "PC Beep Playback Switch", 0);
3278 }
3279 #endif
3280
3281 static int stac92xx_auto_create_mux_input_ctls(struct hda_codec *codec)
3282 {
3283         struct sigmatel_spec *spec = codec->spec;
3284         int i, j, err = 0;
3285
3286         for (i = 0; i < spec->num_muxes; i++) {
3287                 hda_nid_t nid;
3288                 unsigned int wcaps;
3289                 unsigned long val;
3290
3291                 nid = spec->mux_nids[i];
3292                 wcaps = get_wcaps(codec, nid);
3293                 if (!(wcaps & AC_WCAP_OUT_AMP))
3294                         continue;
3295
3296                 /* check whether already the same control was created as
3297                  * normal Capture Volume.
3298                  */
3299                 val = HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT);
3300                 for (j = 0; j < spec->num_caps; j++) {
3301                         if (spec->capvols[j] == val)
3302                                 break;
3303                 }
3304                 if (j < spec->num_caps)
3305                         continue;
3306
3307                 err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_VOL, i,
3308                                                "Mux Capture Volume", val);
3309                 if (err < 0)
3310                         return err;
3311         }
3312         return 0;
3313 };
3314
3315 static const char *stac92xx_spdif_labels[3] = {
3316         "Digital Playback", "Analog Mux 1", "Analog Mux 2",
3317 };
3318
3319 static int stac92xx_auto_create_spdif_mux_ctls(struct hda_codec *codec)
3320 {
3321         struct sigmatel_spec *spec = codec->spec;
3322         struct hda_input_mux *spdif_mux = &spec->private_smux;
3323         const char **labels = spec->spdif_labels;
3324         int i, num_cons;
3325         hda_nid_t con_lst[HDA_MAX_NUM_INPUTS];
3326
3327         num_cons = snd_hda_get_connections(codec,
3328                                 spec->smux_nids[0],
3329                                 con_lst,
3330                                 HDA_MAX_NUM_INPUTS);
3331         if (num_cons <= 0)
3332                 return -EINVAL;
3333
3334         if (!labels)
3335                 labels = stac92xx_spdif_labels;
3336
3337         for (i = 0; i < num_cons; i++) {
3338                 spdif_mux->items[spdif_mux->num_items].label = labels[i];
3339                 spdif_mux->items[spdif_mux->num_items].index = i;
3340                 spdif_mux->num_items++;
3341         }
3342
3343         return 0;
3344 }
3345
3346 /* labels for dmic mux inputs */
3347 static const char *stac92xx_dmic_labels[5] = {
3348         "Analog Inputs", "Digital Mic 1", "Digital Mic 2",
3349         "Digital Mic 3", "Digital Mic 4"
3350 };
3351
3352 static int get_connection_index(struct hda_codec *codec, hda_nid_t mux,
3353                                 hda_nid_t nid)
3354 {
3355         hda_nid_t conn[HDA_MAX_NUM_INPUTS];
3356         int i, nums;
3357
3358         nums = snd_hda_get_connections(codec, mux, conn, ARRAY_SIZE(conn));
3359         for (i = 0; i < nums; i++)
3360                 if (conn[i] == nid)
3361                         return i;
3362         return -1;
3363 }
3364
3365 /* create a volume assigned to the given pin (only if supported) */
3366 /* return 1 if the volume control is created */
3367 static int create_elem_capture_vol(struct hda_codec *codec, hda_nid_t nid,
3368                                    const char *label, int direction)
3369 {
3370         unsigned int caps, nums;
3371         char name[32];
3372         int err;
3373
3374         if (direction == HDA_OUTPUT)
3375                 caps = AC_WCAP_OUT_AMP;
3376         else
3377                 caps = AC_WCAP_IN_AMP;
3378         if (!(get_wcaps(codec, nid) & caps))
3379                 return 0;
3380         caps = query_amp_caps(codec, nid, direction);
3381         nums = (caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT;
3382         if (!nums)
3383                 return 0;
3384         snprintf(name, sizeof(name), "%s Capture Volume", label);
3385         err = stac92xx_add_control(codec->spec, STAC_CTL_WIDGET_VOL, name,
3386                                     HDA_COMPOSE_AMP_VAL(nid, 3, 0, direction));
3387         if (err < 0)
3388                 return err;
3389         return 1;
3390 }
3391
3392 /* create playback/capture controls for input pins on dmic capable codecs */
3393 static int stac92xx_auto_create_dmic_input_ctls(struct hda_codec *codec,
3394                                                 const struct auto_pin_cfg *cfg)
3395 {
3396         struct sigmatel_spec *spec = codec->spec;
3397         struct hda_input_mux *imux = &spec->private_imux;
3398         struct hda_input_mux *dimux = &spec->private_dimux;
3399         int err, i, active_mics;
3400         unsigned int def_conf;
3401
3402         dimux->items[dimux->num_items].label = stac92xx_dmic_labels[0];
3403         dimux->items[dimux->num_items].index = 0;
3404         dimux->num_items++;
3405
3406         active_mics = 0;
3407         for (i = 0; i < spec->num_dmics; i++) {
3408                 /* check the validity: sometimes it's a dead vendor-spec node */
3409                 if (get_wcaps_type(get_wcaps(codec, spec->dmic_nids[i]))
3410                     != AC_WID_PIN)
3411                         continue;
3412                 def_conf = snd_hda_codec_get_pincfg(codec, spec->dmic_nids[i]);
3413                 if (get_defcfg_connect(def_conf) != AC_JACK_PORT_NONE)
3414                         active_mics++;
3415         }
3416
3417         for (i = 0; i < spec->num_dmics; i++) {
3418                 hda_nid_t nid;
3419                 int index;
3420                 const char *label;
3421
3422                 nid = spec->dmic_nids[i];
3423                 if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
3424                         continue;
3425                 def_conf = snd_hda_codec_get_pincfg(codec, nid);
3426                 if (get_defcfg_connect(def_conf) == AC_JACK_PORT_NONE)
3427                         continue;
3428
3429                 index = get_connection_index(codec, spec->dmux_nids[0], nid);
3430                 if (index < 0)
3431                         continue;
3432
3433                 if (active_mics == 1)
3434                         label = "Digital Mic";
3435                 else
3436                         label = stac92xx_dmic_labels[dimux->num_items];
3437
3438                 err = create_elem_capture_vol(codec, nid, label, HDA_INPUT);
3439                 if (err < 0)
3440                         return err;
3441                 if (!err) {
3442                         err = create_elem_capture_vol(codec, nid, label,
3443                                                       HDA_OUTPUT);
3444                         if (err < 0)
3445                                 return err;
3446                 }
3447
3448                 dimux->items[dimux->num_items].label = label;
3449                 dimux->items[dimux->num_items].index = index;
3450                 dimux->num_items++;
3451                 if (snd_hda_get_bool_hint(codec, "separate_dmux") != 1) {
3452                         imux->items[imux->num_items].label = label;
3453                         imux->items[imux->num_items].index = index;
3454                         imux->num_items++;
3455                 }
3456         }
3457
3458         return 0;
3459 }
3460
3461 static int check_mic_pin(struct hda_codec *codec, hda_nid_t nid,
3462                          hda_nid_t *fixed, hda_nid_t *ext)
3463 {
3464         unsigned int cfg;
3465
3466         if (!nid)
3467                 return 0;
3468         cfg = snd_hda_codec_get_pincfg(codec, nid);
3469         switch (get_defcfg_connect(cfg)) {
3470         case AC_JACK_PORT_FIXED:
3471                 if (*fixed)
3472                         return 1; /* already occupied */
3473                 *fixed = nid;
3474                 break;
3475         case AC_JACK_PORT_COMPLEX:
3476                 if (*ext)
3477                         return 1; /* already occupied */
3478                 *ext = nid;
3479                 break;
3480         }
3481         return 0;
3482 }
3483
3484 static int set_mic_route(struct hda_codec *codec,
3485                          struct sigmatel_mic_route *mic,
3486                          hda_nid_t pin)
3487 {
3488         struct sigmatel_spec *spec = codec->spec;
3489         struct auto_pin_cfg *cfg = &spec->autocfg;
3490         int i;
3491
3492         mic->pin = pin;
3493         for (i = AUTO_PIN_MIC; i <= AUTO_PIN_FRONT_MIC; i++)
3494                 if (pin == cfg->input_pins[i])
3495                         break;
3496         if (i <= AUTO_PIN_FRONT_MIC) {
3497                 /* analog pin */
3498                 i = get_connection_index(codec, spec->mux_nids[0], pin);
3499                 if (i < 0)
3500                         return -1;
3501                 mic->mux_idx = i;
3502                 mic->dmux_idx = -1;
3503                 if (spec->dmux_nids)
3504                         mic->dmux_idx = get_connection_index(codec,
3505                                                              spec->dmux_nids[0],
3506                                                              spec->mux_nids[0]);
3507         }  else if (spec->dmux_nids) {
3508                 /* digital pin */
3509                 i = get_connection_index(codec, spec->dmux_nids[0], pin);
3510                 if (i < 0)
3511                         return -1;
3512                 mic->dmux_idx = i;
3513                 mic->mux_idx = -1;
3514                 if (spec->mux_nids)
3515                         mic->mux_idx = get_connection_index(codec,
3516                                                             spec->mux_nids[0],
3517                                                             spec->dmux_nids[0]);
3518         }
3519         return 0;
3520 }
3521
3522 /* return non-zero if the device is for automatic mic switch */
3523 static int stac_check_auto_mic(struct hda_codec *codec)
3524 {
3525         struct sigmatel_spec *spec = codec->spec;
3526         struct auto_pin_cfg *cfg = &spec->autocfg;
3527         hda_nid_t fixed, ext;
3528         int i;
3529
3530         for (i = AUTO_PIN_LINE; i < AUTO_PIN_LAST; i++) {
3531                 if (cfg->input_pins[i])
3532                         return 0; /* must be exclusively mics */
3533         }
3534         fixed = ext = 0;
3535         for (i = AUTO_PIN_MIC; i <= AUTO_PIN_FRONT_MIC; i++)
3536                 if (check_mic_pin(codec, cfg->input_pins[i], &fixed, &ext))
3537                         return 0;
3538         for (i = 0; i < spec->num_dmics; i++)
3539                 if (check_mic_pin(codec, spec->dmic_nids[i], &fixed, &ext))
3540                         return 0;
3541         if (!fixed || !ext)
3542                 return 0;
3543         if (!(get_wcaps(codec, ext) & AC_WCAP_UNSOL_CAP))
3544                 return 0; /* no unsol support */
3545         if (set_mic_route(codec, &spec->ext_mic, ext) ||
3546             set_mic_route(codec, &spec->int_mic, fixed))
3547                 return 0; /* something is wrong */
3548         return 1;
3549 }
3550
3551 /* create playback/capture controls for input pins */
3552 static int stac92xx_auto_create_analog_input_ctls(struct hda_codec *codec, const struct auto_pin_cfg *cfg)
3553 {
3554         struct sigmatel_spec *spec = codec->spec;
3555         struct hda_input_mux *imux = &spec->private_imux;
3556         int i, j;
3557
3558         for (i = 0; i < AUTO_PIN_LAST; i++) {
3559                 hda_nid_t nid = cfg->input_pins[i];
3560                 int index, err;
3561
3562                 if (!nid)
3563                         continue;
3564                 index = -1;
3565                 for (j = 0; j < spec->num_muxes; j++) {
3566                         index = get_connection_index(codec, spec->mux_nids[j],
3567                                                      nid);
3568                         if (index >= 0)
3569                                 break;
3570                 }
3571                 if (index < 0)
3572                         continue;
3573
3574                 err = create_elem_capture_vol(codec, nid,
3575                                               auto_pin_cfg_labels[i],
3576                                               HDA_INPUT);
3577                 if (err < 0)
3578                         return err;
3579
3580                 imux->items[imux->num_items].label = auto_pin_cfg_labels[i];
3581                 imux->items[imux->num_items].index = index;
3582                 imux->num_items++;
3583         }
3584         spec->num_analog_muxes = imux->num_items;
3585
3586         if (imux->num_items) {
3587                 /*
3588                  * Set the current input for the muxes.
3589                  * The STAC9221 has two input muxes with identical source
3590                  * NID lists.  Hopefully this won't get confused.
3591                  */
3592                 for (i = 0; i < spec->num_muxes; i++) {
3593                         snd_hda_codec_write_cache(codec, spec->mux_nids[i], 0,
3594                                                   AC_VERB_SET_CONNECT_SEL,
3595                                                   imux->items[0].index);
3596                 }
3597         }
3598
3599         return 0;
3600 }
3601
3602 static void stac92xx_auto_init_multi_out(struct hda_codec *codec)
3603 {
3604         struct sigmatel_spec *spec = codec->spec;
3605         int i;
3606
3607         for (i = 0; i < spec->autocfg.line_outs; i++) {
3608                 hda_nid_t nid = spec->autocfg.line_out_pins[i];
3609                 stac92xx_auto_set_pinctl(codec, nid, AC_PINCTL_OUT_EN);
3610         }
3611 }
3612
3613 static void stac92xx_auto_init_hp_out(struct hda_codec *codec)
3614 {
3615         struct sigmatel_spec *spec = codec->spec;
3616         int i;
3617
3618         for (i = 0; i < spec->autocfg.hp_outs; i++) {
3619                 hda_nid_t pin;
3620                 pin = spec->autocfg.hp_pins[i];
3621                 if (pin) /* connect to front */
3622                         stac92xx_auto_set_pinctl(codec, pin, AC_PINCTL_OUT_EN | AC_PINCTL_HP_EN);
3623         }
3624         for (i = 0; i < spec->autocfg.speaker_outs; i++) {
3625                 hda_nid_t pin;
3626                 pin = spec->autocfg.speaker_pins[i];
3627                 if (pin) /* connect to front */
3628                         stac92xx_auto_set_pinctl(codec, pin, AC_PINCTL_OUT_EN);
3629         }
3630 }
3631
3632 static int stac92xx_parse_auto_config(struct hda_codec *codec, hda_nid_t dig_out, hda_nid_t dig_in)
3633 {
3634         struct sigmatel_spec *spec = codec->spec;
3635         int hp_swap = 0;
3636         int i, err;
3637
3638         if ((err = snd_hda_parse_pin_def_config(codec,
3639                                                 &spec->autocfg,
3640                                                 spec->dmic_nids)) < 0)
3641                 return err;
3642         if (! spec->autocfg.line_outs)
3643                 return 0; /* can't find valid pin config */
3644
3645         /* If we have no real line-out pin and multiple hp-outs, HPs should
3646          * be set up as multi-channel outputs.
3647          */
3648         if (spec->autocfg.line_out_type == AUTO_PIN_SPEAKER_OUT &&
3649             spec->autocfg.hp_outs > 1) {
3650                 /* Copy hp_outs to line_outs, backup line_outs in
3651                  * speaker_outs so that the following routines can handle
3652                  * HP pins as primary outputs.
3653                  */
3654                 snd_printdd("stac92xx: Enabling multi-HPs workaround\n");
3655                 memcpy(spec->autocfg.speaker_pins, spec->autocfg.line_out_pins,
3656                        sizeof(spec->autocfg.line_out_pins));
3657                 spec->autocfg.speaker_outs = spec->autocfg.line_outs;
3658                 memcpy(spec->autocfg.line_out_pins, spec->autocfg.hp_pins,
3659                        sizeof(spec->autocfg.hp_pins));
3660                 spec->autocfg.line_outs = spec->autocfg.hp_outs;
3661                 spec->autocfg.line_out_type = AUTO_PIN_HP_OUT;
3662                 spec->autocfg.hp_outs = 0;
3663                 hp_swap = 1;
3664         }
3665         if (spec->autocfg.mono_out_pin) {
3666                 int dir = get_wcaps(codec, spec->autocfg.mono_out_pin) &
3667                         (AC_WCAP_OUT_AMP | AC_WCAP_IN_AMP);
3668                 u32 caps = query_amp_caps(codec,
3669                                 spec->autocfg.mono_out_pin, dir);
3670                 hda_nid_t conn_list[1];
3671
3672                 /* get the mixer node and then the mono mux if it exists */
3673                 if (snd_hda_get_connections(codec,
3674                                 spec->autocfg.mono_out_pin, conn_list, 1) &&
3675                                 snd_hda_get_connections(codec, conn_list[0],
3676                                 conn_list, 1) > 0) {
3677
3678                                 int wcaps = get_wcaps(codec, conn_list[0]);
3679                                 int wid_type = get_wcaps_type(wcaps);
3680                                 /* LR swap check, some stac925x have a mux that
3681                                  * changes the DACs output path instead of the
3682                                  * mono-mux path.
3683                                  */
3684                                 if (wid_type == AC_WID_AUD_SEL &&
3685                                                 !(wcaps & AC_WCAP_LR_SWAP))
3686                                         spec->mono_nid = conn_list[0];
3687                 }
3688                 if (dir) {
3689                         hda_nid_t nid = spec->autocfg.mono_out_pin;
3690
3691                         /* most mono outs have a least a mute/unmute switch */
3692                         dir = (dir & AC_WCAP_OUT_AMP) ? HDA_OUTPUT : HDA_INPUT;
3693                         err = stac92xx_add_control(spec, STAC_CTL_WIDGET_MUTE,
3694                                 "Mono Playback Switch",
3695                                 HDA_COMPOSE_AMP_VAL(nid, 1, 0, dir));
3696                         if (err < 0)
3697                                 return err;
3698                         /* check for volume support for the amp */
3699                         if ((caps & AC_AMPCAP_NUM_STEPS)
3700                                         >> AC_AMPCAP_NUM_STEPS_SHIFT) {
3701                                 err = stac92xx_add_control(spec,
3702                                         STAC_CTL_WIDGET_VOL,
3703                                         "Mono Playback Volume",
3704                                 HDA_COMPOSE_AMP_VAL(nid, 1, 0, dir));
3705                                 if (err < 0)
3706                                         return err;
3707                         }
3708                 }
3709
3710                 stac92xx_auto_set_pinctl(codec, spec->autocfg.mono_out_pin,
3711                                          AC_PINCTL_OUT_EN);
3712         }
3713
3714         if (!spec->multiout.num_dacs) {
3715                 err = stac92xx_auto_fill_dac_nids(codec);
3716                 if (err < 0)
3717                         return err;
3718                 err = stac92xx_auto_create_multi_out_ctls(codec,
3719                                                           &spec->autocfg);
3720                 if (err < 0)
3721                         return err;
3722         }
3723
3724         /* setup analog beep controls */
3725         if (spec->anabeep_nid > 0) {
3726                 err = stac92xx_auto_create_beep_ctls(codec,
3727                         spec->anabeep_nid);
3728                 if (err < 0)
3729                         return err;
3730         }
3731
3732         /* setup digital beep controls and input device */
3733 #ifdef CONFIG_SND_HDA_INPUT_BEEP
3734         if (spec->digbeep_nid > 0) {
3735                 hda_nid_t nid = spec->digbeep_nid;
3736                 unsigned int caps;
3737
3738                 err = stac92xx_auto_create_beep_ctls(codec, nid);
3739                 if (err < 0)
3740                         return err;
3741                 err = snd_hda_attach_beep_device(codec, nid);
3742                 if (err < 0)
3743                         return err;
3744                 /* IDT/STAC codecs have linear beep tone parameter */
3745                 codec->beep->linear_tone = 1;
3746                 /* if no beep switch is available, make its own one */
3747                 caps = query_amp_caps(codec, nid, HDA_OUTPUT);
3748                 if (codec->beep &&
3749                     !((caps & AC_AMPCAP_MUTE) >> AC_AMPCAP_MUTE_SHIFT)) {
3750                         err = stac92xx_beep_switch_ctl(codec);
3751                         if (err < 0)
3752                                 return err;
3753                 }
3754         }
3755 #endif
3756
3757         err = stac92xx_auto_create_hp_ctls(codec, &spec->autocfg);
3758         if (err < 0)
3759                 return err;
3760
3761         /* All output parsing done, now restore the swapped hp pins */
3762         if (hp_swap) {
3763                 memcpy(spec->autocfg.hp_pins, spec->autocfg.line_out_pins,
3764                        sizeof(spec->autocfg.hp_pins));
3765                 spec->autocfg.hp_outs = spec->autocfg.line_outs;
3766                 spec->autocfg.line_out_type = AUTO_PIN_HP_OUT;
3767                 spec->autocfg.line_outs = 0;
3768         }
3769
3770         if (stac_check_auto_mic(codec)) {
3771                 spec->auto_mic = 1;
3772                 /* only one capture for auto-mic */
3773                 spec->num_adcs = 1;
3774                 spec->num_caps = 1;
3775                 spec->num_muxes = 1;
3776         }
3777
3778         for (i = 0; i < spec->num_caps; i++) {
3779                 err = stac92xx_add_capvol_ctls(codec, spec->capvols[i],
3780                                                spec->capsws[i], i);
3781                 if (err < 0)
3782                         return err;
3783         }
3784
3785         err = stac92xx_auto_create_analog_input_ctls(codec, &spec->autocfg);
3786         if (err < 0)
3787                 return err;
3788
3789         if (spec->mono_nid > 0) {
3790                 err = stac92xx_auto_create_mono_output_ctls(codec);
3791                 if (err < 0)
3792                         return err;
3793         }
3794         if (spec->num_dmics > 0 && !spec->dinput_mux)
3795