[ALSA] semaphore -> mutex (Archs, misc buses)
[linux-2.6.git] / sound / usb / usbmixer.c
1 /*
2  *   (Tentative) USB Audio Driver for ALSA
3  *
4  *   Mixer control part
5  *
6  *   Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>
7  *
8  *   Many codes borrowed from audio.c by
9  *          Alan Cox (alan@lxorguk.ukuu.org.uk)
10  *          Thomas Sailer (sailer@ife.ee.ethz.ch)
11  *
12  *
13  *   This program is free software; you can redistribute it and/or modify
14  *   it under the terms of the GNU General Public License as published by
15  *   the Free Software Foundation; either version 2 of the License, or
16  *   (at your option) any later version.
17  *
18  *   This program is distributed in the hope that it will be useful,
19  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
20  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  *   GNU General Public License for more details.
22  *
23  *   You should have received a copy of the GNU General Public License
24  *   along with this program; if not, write to the Free Software
25  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
26  *
27  */
28
29 #include <sound/driver.h>
30 #include <linux/bitops.h>
31 #include <linux/init.h>
32 #include <linux/list.h>
33 #include <linux/slab.h>
34 #include <linux/string.h>
35 #include <linux/usb.h>
36 #include <sound/core.h>
37 #include <sound/control.h>
38 #include <sound/hwdep.h>
39 #include <sound/info.h>
40
41 #include "usbaudio.h"
42
43 /*
44  */
45
46 /* ignore error from controls - for debugging */
47 /* #define IGNORE_CTL_ERROR */
48
49 struct usb_mixer_interface {
50         struct snd_usb_audio *chip;
51         unsigned int ctrlif;
52         struct list_head list;
53         unsigned int ignore_ctl_error;
54         struct urb *urb;
55         struct usb_mixer_elem_info **id_elems; /* array[256], indexed by unit id */
56
57         /* Sound Blaster remote control stuff */
58         enum {
59                 RC_NONE,
60                 RC_EXTIGY,
61                 RC_AUDIGY2NX,
62         } rc_type;
63         unsigned long rc_hwdep_open;
64         u32 rc_code;
65         wait_queue_head_t rc_waitq;
66         struct urb *rc_urb;
67         struct usb_ctrlrequest *rc_setup_packet;
68         u8 rc_buffer[6];
69
70         u8 audigy2nx_leds[3];
71 };
72
73
74 struct usb_audio_term {
75         int id;
76         int type;
77         int channels;
78         unsigned int chconfig;
79         int name;
80 };
81
82 struct usbmix_name_map;
83
84 struct mixer_build {
85         struct snd_usb_audio *chip;
86         struct usb_mixer_interface *mixer;
87         unsigned char *buffer;
88         unsigned int buflen;
89         DECLARE_BITMAP(unitbitmap, 256);
90         struct usb_audio_term oterm;
91         const struct usbmix_name_map *map;
92         const struct usbmix_selector_map *selector_map;
93 };
94
95 struct usb_mixer_elem_info {
96         struct usb_mixer_interface *mixer;
97         struct usb_mixer_elem_info *next_id_elem; /* list of controls with same id */
98         struct snd_ctl_elem_id *elem_id;
99         unsigned int id;
100         unsigned int control;   /* CS or ICN (high byte) */
101         unsigned int cmask; /* channel mask bitmap: 0 = master */
102         int channels;
103         int val_type;
104         int min, max, res;
105         u8 initialized;
106 };
107
108
109 enum {
110         USB_FEATURE_NONE = 0,
111         USB_FEATURE_MUTE = 1,
112         USB_FEATURE_VOLUME,
113         USB_FEATURE_BASS,
114         USB_FEATURE_MID,
115         USB_FEATURE_TREBLE,
116         USB_FEATURE_GEQ,
117         USB_FEATURE_AGC,
118         USB_FEATURE_DELAY,
119         USB_FEATURE_BASSBOOST,
120         USB_FEATURE_LOUDNESS
121 };
122
123 enum {
124         USB_MIXER_BOOLEAN,
125         USB_MIXER_INV_BOOLEAN,
126         USB_MIXER_S8,
127         USB_MIXER_U8,
128         USB_MIXER_S16,
129         USB_MIXER_U16,
130 };
131
132 enum {
133         USB_PROC_UPDOWN = 1,
134         USB_PROC_UPDOWN_SWITCH = 1,
135         USB_PROC_UPDOWN_MODE_SEL = 2,
136
137         USB_PROC_PROLOGIC = 2,
138         USB_PROC_PROLOGIC_SWITCH = 1,
139         USB_PROC_PROLOGIC_MODE_SEL = 2,
140
141         USB_PROC_3DENH = 3,
142         USB_PROC_3DENH_SWITCH = 1,
143         USB_PROC_3DENH_SPACE = 2,
144
145         USB_PROC_REVERB = 4,
146         USB_PROC_REVERB_SWITCH = 1,
147         USB_PROC_REVERB_LEVEL = 2,
148         USB_PROC_REVERB_TIME = 3,
149         USB_PROC_REVERB_DELAY = 4,
150
151         USB_PROC_CHORUS = 5,
152         USB_PROC_CHORUS_SWITCH = 1,
153         USB_PROC_CHORUS_LEVEL = 2,
154         USB_PROC_CHORUS_RATE = 3,
155         USB_PROC_CHORUS_DEPTH = 4,
156
157         USB_PROC_DCR = 6,
158         USB_PROC_DCR_SWITCH = 1,
159         USB_PROC_DCR_RATIO = 2,
160         USB_PROC_DCR_MAX_AMP = 3,
161         USB_PROC_DCR_THRESHOLD = 4,
162         USB_PROC_DCR_ATTACK = 5,
163         USB_PROC_DCR_RELEASE = 6,
164 };
165
166 #define MAX_CHANNELS    10      /* max logical channels */
167
168
169 /*
170  * manual mapping of mixer names
171  * if the mixer topology is too complicated and the parsed names are
172  * ambiguous, add the entries in usbmixer_maps.c.
173  */
174 #include "usbmixer_maps.c"
175
176 /* get the mapped name if the unit matches */
177 static int check_mapped_name(struct mixer_build *state, int unitid, int control, char *buf, int buflen)
178 {
179         const struct usbmix_name_map *p;
180
181         if (! state->map)
182                 return 0;
183
184         for (p = state->map; p->id; p++) {
185                 if (p->id == unitid && p->name &&
186                     (! control || ! p->control || control == p->control)) {
187                         buflen--;
188                         return strlcpy(buf, p->name, buflen);
189                 }
190         }
191         return 0;
192 }
193
194 /* check whether the control should be ignored */
195 static int check_ignored_ctl(struct mixer_build *state, int unitid, int control)
196 {
197         const struct usbmix_name_map *p;
198
199         if (! state->map)
200                 return 0;
201         for (p = state->map; p->id; p++) {
202                 if (p->id == unitid && ! p->name &&
203                     (! control || ! p->control || control == p->control)) {
204                         // printk("ignored control %d:%d\n", unitid, control);
205                         return 1;
206                 }
207         }
208         return 0;
209 }
210
211 /* get the mapped selector source name */
212 static int check_mapped_selector_name(struct mixer_build *state, int unitid,
213                                       int index, char *buf, int buflen)
214 {
215         const struct usbmix_selector_map *p;
216
217         if (! state->selector_map)
218                 return 0;
219         for (p = state->selector_map; p->id; p++) {
220                 if (p->id == unitid && index < p->count)
221                         return strlcpy(buf, p->names[index], buflen);
222         }
223         return 0;
224 }
225
226 /*
227  * find an audio control unit with the given unit id
228  */
229 static void *find_audio_control_unit(struct mixer_build *state, unsigned char unit)
230 {
231         unsigned char *p;
232
233         p = NULL;
234         while ((p = snd_usb_find_desc(state->buffer, state->buflen, p,
235                                       USB_DT_CS_INTERFACE)) != NULL) {
236                 if (p[0] >= 4 && p[2] >= INPUT_TERMINAL && p[2] <= EXTENSION_UNIT && p[3] == unit)
237                         return p;
238         }
239         return NULL;
240 }
241
242
243 /*
244  * copy a string with the given id
245  */
246 static int snd_usb_copy_string_desc(struct mixer_build *state, int index, char *buf, int maxlen)
247 {
248         int len = usb_string(state->chip->dev, index, buf, maxlen - 1);
249         buf[len] = 0;
250         return len;
251 }
252
253 /*
254  * convert from the byte/word on usb descriptor to the zero-based integer
255  */
256 static int convert_signed_value(struct usb_mixer_elem_info *cval, int val)
257 {
258         switch (cval->val_type) {
259         case USB_MIXER_BOOLEAN:
260                 return !!val;
261         case USB_MIXER_INV_BOOLEAN:
262                 return !val;
263         case USB_MIXER_U8:
264                 val &= 0xff;
265                 break;
266         case USB_MIXER_S8:
267                 val &= 0xff;
268                 if (val >= 0x80)
269                         val -= 0x100;
270                 break;
271         case USB_MIXER_U16:
272                 val &= 0xffff;
273                 break;
274         case USB_MIXER_S16:
275                 val &= 0xffff;
276                 if (val >= 0x8000)
277                         val -= 0x10000;
278                 break;
279         }
280         return val;
281 }
282
283 /*
284  * convert from the zero-based int to the byte/word for usb descriptor
285  */
286 static int convert_bytes_value(struct usb_mixer_elem_info *cval, int val)
287 {
288         switch (cval->val_type) {
289         case USB_MIXER_BOOLEAN:
290                 return !!val;
291         case USB_MIXER_INV_BOOLEAN:
292                 return !val;
293         case USB_MIXER_S8:
294         case USB_MIXER_U8:
295                 return val & 0xff;
296         case USB_MIXER_S16:
297         case USB_MIXER_U16:
298                 return val & 0xffff;
299         }
300         return 0; /* not reached */
301 }
302
303 static int get_relative_value(struct usb_mixer_elem_info *cval, int val)
304 {
305         if (! cval->res)
306                 cval->res = 1;
307         if (val < cval->min)
308                 return 0;
309         else if (val > cval->max)
310                 return (cval->max - cval->min) / cval->res;
311         else
312                 return (val - cval->min) / cval->res;
313 }
314
315 static int get_abs_value(struct usb_mixer_elem_info *cval, int val)
316 {
317         if (val < 0)
318                 return cval->min;
319         if (! cval->res)
320                 cval->res = 1;
321         val *= cval->res;
322         val += cval->min;
323         if (val > cval->max)
324                 return cval->max;
325         return val;
326 }
327
328
329 /*
330  * retrieve a mixer value
331  */
332
333 static int get_ctl_value(struct usb_mixer_elem_info *cval, int request, int validx, int *value_ret)
334 {
335         unsigned char buf[2];
336         int val_len = cval->val_type >= USB_MIXER_S16 ? 2 : 1;
337         int timeout = 10;
338
339         while (timeout-- > 0) {
340                 if (snd_usb_ctl_msg(cval->mixer->chip->dev,
341                                     usb_rcvctrlpipe(cval->mixer->chip->dev, 0),
342                                     request,
343                                     USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN,
344                                     validx, cval->mixer->ctrlif | (cval->id << 8),
345                                     buf, val_len, 100) >= 0) {
346                         *value_ret = convert_signed_value(cval, snd_usb_combine_bytes(buf, val_len));
347                         return 0;
348                 }
349         }
350         snd_printdd(KERN_ERR "cannot get ctl value: req = %#x, wValue = %#x, wIndex = %#x, type = %d\n",
351                     request, validx, cval->mixer->ctrlif | (cval->id << 8), cval->val_type);
352         return -EINVAL;
353 }
354
355 static int get_cur_ctl_value(struct usb_mixer_elem_info *cval, int validx, int *value)
356 {
357         return get_ctl_value(cval, GET_CUR, validx, value);
358 }
359
360 /* channel = 0: master, 1 = first channel */
361 static inline int get_cur_mix_value(struct usb_mixer_elem_info *cval, int channel, int *value)
362 {
363         return get_ctl_value(cval, GET_CUR, (cval->control << 8) | channel, value);
364 }
365
366 /*
367  * set a mixer value
368  */
369
370 static int set_ctl_value(struct usb_mixer_elem_info *cval, int request, int validx, int value_set)
371 {
372         unsigned char buf[2];
373         int val_len = cval->val_type >= USB_MIXER_S16 ? 2 : 1;
374         int timeout = 10;
375
376         value_set = convert_bytes_value(cval, value_set);
377         buf[0] = value_set & 0xff;
378         buf[1] = (value_set >> 8) & 0xff;
379         while (timeout -- > 0)
380                 if (snd_usb_ctl_msg(cval->mixer->chip->dev,
381                                     usb_sndctrlpipe(cval->mixer->chip->dev, 0),
382                                     request,
383                                     USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_OUT,
384                                     validx, cval->mixer->ctrlif | (cval->id << 8),
385                                     buf, val_len, 100) >= 0)
386                         return 0;
387         snd_printdd(KERN_ERR "cannot set ctl value: req = %#x, wValue = %#x, wIndex = %#x, type = %d, data = %#x/%#x\n",
388                     request, validx, cval->mixer->ctrlif | (cval->id << 8), cval->val_type, buf[0], buf[1]);
389         return -EINVAL;
390 }
391
392 static int set_cur_ctl_value(struct usb_mixer_elem_info *cval, int validx, int value)
393 {
394         return set_ctl_value(cval, SET_CUR, validx, value);
395 }
396
397 static inline int set_cur_mix_value(struct usb_mixer_elem_info *cval, int channel, int value)
398 {
399         return set_ctl_value(cval, SET_CUR, (cval->control << 8) | channel, value);
400 }
401
402
403 /*
404  * parser routines begin here...
405  */
406
407 static int parse_audio_unit(struct mixer_build *state, int unitid);
408
409
410 /*
411  * check if the input/output channel routing is enabled on the given bitmap.
412  * used for mixer unit parser
413  */
414 static int check_matrix_bitmap(unsigned char *bmap, int ich, int och, int num_outs)
415 {
416         int idx = ich * num_outs + och;
417         return bmap[idx >> 3] & (0x80 >> (idx & 7));
418 }
419
420
421 /*
422  * add an alsa control element
423  * search and increment the index until an empty slot is found.
424  *
425  * if failed, give up and free the control instance.
426  */
427
428 static int add_control_to_empty(struct mixer_build *state, struct snd_kcontrol *kctl)
429 {
430         struct usb_mixer_elem_info *cval = kctl->private_data;
431         int err;
432
433         while (snd_ctl_find_id(state->chip->card, &kctl->id))
434                 kctl->id.index++;
435         if ((err = snd_ctl_add(state->chip->card, kctl)) < 0) {
436                 snd_printd(KERN_ERR "cannot add control (err = %d)\n", err);
437                 snd_ctl_free_one(kctl);
438                 return err;
439         }
440         cval->elem_id = &kctl->id;
441         cval->next_id_elem = state->mixer->id_elems[cval->id];
442         state->mixer->id_elems[cval->id] = cval;
443         return 0;
444 }
445
446
447 /*
448  * get a terminal name string
449  */
450
451 static struct iterm_name_combo {
452         int type;
453         char *name;
454 } iterm_names[] = {
455         { 0x0300, "Output" },
456         { 0x0301, "Speaker" },
457         { 0x0302, "Headphone" },
458         { 0x0303, "HMD Audio" },
459         { 0x0304, "Desktop Speaker" },
460         { 0x0305, "Room Speaker" },
461         { 0x0306, "Com Speaker" },
462         { 0x0307, "LFE" },
463         { 0x0600, "External In" },
464         { 0x0601, "Analog In" },
465         { 0x0602, "Digital In" },
466         { 0x0603, "Line" },
467         { 0x0604, "Legacy In" },
468         { 0x0605, "IEC958 In" },
469         { 0x0606, "1394 DA Stream" },
470         { 0x0607, "1394 DV Stream" },
471         { 0x0700, "Embedded" },
472         { 0x0701, "Noise Source" },
473         { 0x0702, "Equalization Noise" },
474         { 0x0703, "CD" },
475         { 0x0704, "DAT" },
476         { 0x0705, "DCC" },
477         { 0x0706, "MiniDisk" },
478         { 0x0707, "Analog Tape" },
479         { 0x0708, "Phonograph" },
480         { 0x0709, "VCR Audio" },
481         { 0x070a, "Video Disk Audio" },
482         { 0x070b, "DVD Audio" },
483         { 0x070c, "TV Tuner Audio" },
484         { 0x070d, "Satellite Rec Audio" },
485         { 0x070e, "Cable Tuner Audio" },
486         { 0x070f, "DSS Audio" },
487         { 0x0710, "Radio Receiver" },
488         { 0x0711, "Radio Transmitter" },
489         { 0x0712, "Multi-Track Recorder" },
490         { 0x0713, "Synthesizer" },
491         { 0 },
492 };
493
494 static int get_term_name(struct mixer_build *state, struct usb_audio_term *iterm,
495                          unsigned char *name, int maxlen, int term_only)
496 {
497         struct iterm_name_combo *names;
498
499         if (iterm->name)
500                 return snd_usb_copy_string_desc(state, iterm->name, name, maxlen);
501
502         /* virtual type - not a real terminal */
503         if (iterm->type >> 16) {
504                 if (term_only)
505                         return 0;
506                 switch (iterm->type >> 16) {
507                 case SELECTOR_UNIT:
508                         strcpy(name, "Selector"); return 8;
509                 case PROCESSING_UNIT:
510                         strcpy(name, "Process Unit"); return 12;
511                 case EXTENSION_UNIT:
512                         strcpy(name, "Ext Unit"); return 8;
513                 case MIXER_UNIT:
514                         strcpy(name, "Mixer"); return 5;
515                 default:
516                         return sprintf(name, "Unit %d", iterm->id);
517                 }
518         }
519
520         switch (iterm->type & 0xff00) {
521         case 0x0100:
522                 strcpy(name, "PCM"); return 3;
523         case 0x0200:
524                 strcpy(name, "Mic"); return 3;
525         case 0x0400:
526                 strcpy(name, "Headset"); return 7;
527         case 0x0500:
528                 strcpy(name, "Phone"); return 5;
529         }
530
531         for (names = iterm_names; names->type; names++)
532                 if (names->type == iterm->type) {
533                         strcpy(name, names->name);
534                         return strlen(names->name);
535                 }
536         return 0;
537 }
538
539
540 /*
541  * parse the source unit recursively until it reaches to a terminal
542  * or a branched unit.
543  */
544 static int check_input_term(struct mixer_build *state, int id, struct usb_audio_term *term)
545 {
546         unsigned char *p1;
547
548         memset(term, 0, sizeof(*term));
549         while ((p1 = find_audio_control_unit(state, id)) != NULL) {
550                 term->id = id;
551                 switch (p1[2]) {
552                 case INPUT_TERMINAL:
553                         term->type = combine_word(p1 + 4);
554                         term->channels = p1[7];
555                         term->chconfig = combine_word(p1 + 8);
556                         term->name = p1[11];
557                         return 0;
558                 case FEATURE_UNIT:
559                         id = p1[4];
560                         break; /* continue to parse */
561                 case MIXER_UNIT:
562                         term->type = p1[2] << 16; /* virtual type */
563                         term->channels = p1[5 + p1[4]];
564                         term->chconfig = combine_word(p1 + 6 + p1[4]);
565                         term->name = p1[p1[0] - 1];
566                         return 0;
567                 case SELECTOR_UNIT:
568                         /* call recursively to retrieve the channel info */
569                         if (check_input_term(state, p1[5], term) < 0)
570                                 return -ENODEV;
571                         term->type = p1[2] << 16; /* virtual type */
572                         term->id = id;
573                         term->name = p1[9 + p1[0] - 1];
574                         return 0;
575                 case PROCESSING_UNIT:
576                 case EXTENSION_UNIT:
577                         if (p1[6] == 1) {
578                                 id = p1[7];
579                                 break; /* continue to parse */
580                         }
581                         term->type = p1[2] << 16; /* virtual type */
582                         term->channels = p1[7 + p1[6]];
583                         term->chconfig = combine_word(p1 + 8 + p1[6]);
584                         term->name = p1[12 + p1[6] + p1[11 + p1[6]]];
585                         return 0;
586                 default:
587                         return -ENODEV;
588                 }
589         }
590         return -ENODEV;
591 }
592
593
594 /*
595  * Feature Unit
596  */
597
598 /* feature unit control information */
599 struct usb_feature_control_info {
600         const char *name;
601         unsigned int type;      /* control type (mute, volume, etc.) */
602 };
603
604 static struct usb_feature_control_info audio_feature_info[] = {
605         { "Mute",               USB_MIXER_INV_BOOLEAN },
606         { "Volume",             USB_MIXER_S16 },
607         { "Tone Control - Bass",        USB_MIXER_S8 },
608         { "Tone Control - Mid",         USB_MIXER_S8 },
609         { "Tone Control - Treble",      USB_MIXER_S8 },
610         { "Graphic Equalizer",          USB_MIXER_S8 }, /* FIXME: not implemeted yet */
611         { "Auto Gain Control",  USB_MIXER_BOOLEAN },
612         { "Delay Control",      USB_MIXER_U16 },
613         { "Bass Boost",         USB_MIXER_BOOLEAN },
614         { "Loudness",           USB_MIXER_BOOLEAN },
615 };
616
617
618 /* private_free callback */
619 static void usb_mixer_elem_free(struct snd_kcontrol *kctl)
620 {
621         kfree(kctl->private_data);
622         kctl->private_data = NULL;
623 }
624
625
626 /*
627  * interface to ALSA control for feature/mixer units
628  */
629
630 /*
631  * retrieve the minimum and maximum values for the specified control
632  */
633 static int get_min_max(struct usb_mixer_elem_info *cval, int default_min)
634 {
635         /* for failsafe */
636         cval->min = default_min;
637         cval->max = cval->min + 1;
638         cval->res = 1;
639
640         if (cval->val_type == USB_MIXER_BOOLEAN ||
641             cval->val_type == USB_MIXER_INV_BOOLEAN) {
642                 cval->initialized = 1;
643         } else {
644                 int minchn = 0;
645                 if (cval->cmask) {
646                         int i;
647                         for (i = 0; i < MAX_CHANNELS; i++)
648                                 if (cval->cmask & (1 << i)) {
649                                         minchn = i + 1;
650                                         break;
651                                 }
652                 }
653                 if (get_ctl_value(cval, GET_MAX, (cval->control << 8) | minchn, &cval->max) < 0 ||
654                     get_ctl_value(cval, GET_MIN, (cval->control << 8) | minchn, &cval->min) < 0) {
655                         snd_printd(KERN_ERR "%d:%d: cannot get min/max values for control %d (id %d)\n",
656                                    cval->id, cval->mixer->ctrlif, cval->control, cval->id);
657                         return -EINVAL;
658                 }
659                 if (get_ctl_value(cval, GET_RES, (cval->control << 8) | minchn, &cval->res) < 0) {
660                         cval->res = 1;
661                 } else {
662                         int last_valid_res = cval->res;
663
664                         while (cval->res > 1) {
665                                 if (set_ctl_value(cval, SET_RES, (cval->control << 8) | minchn, cval->res / 2) < 0)
666                                         break;
667                                 cval->res /= 2;
668                         }
669                         if (get_ctl_value(cval, GET_RES, (cval->control << 8) | minchn, &cval->res) < 0)
670                                 cval->res = last_valid_res;
671                 }
672                 if (cval->res == 0)
673                         cval->res = 1;
674                 cval->initialized = 1;
675         }
676         return 0;
677 }
678
679
680 /* get a feature/mixer unit info */
681 static int mixer_ctl_feature_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
682 {
683         struct usb_mixer_elem_info *cval = kcontrol->private_data;
684
685         if (cval->val_type == USB_MIXER_BOOLEAN ||
686             cval->val_type == USB_MIXER_INV_BOOLEAN)
687                 uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
688         else
689                 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
690         uinfo->count = cval->channels;
691         if (cval->val_type == USB_MIXER_BOOLEAN ||
692             cval->val_type == USB_MIXER_INV_BOOLEAN) {
693                 uinfo->value.integer.min = 0;
694                 uinfo->value.integer.max = 1;
695         } else {
696                 if (! cval->initialized)
697                         get_min_max(cval,  0);
698                 uinfo->value.integer.min = 0;
699                 uinfo->value.integer.max = (cval->max - cval->min) / cval->res;
700         }
701         return 0;
702 }
703
704 /* get the current value from feature/mixer unit */
705 static int mixer_ctl_feature_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
706 {
707         struct usb_mixer_elem_info *cval = kcontrol->private_data;
708         int c, cnt, val, err;
709
710         if (cval->cmask) {
711                 cnt = 0;
712                 for (c = 0; c < MAX_CHANNELS; c++) {
713                         if (cval->cmask & (1 << c)) {
714                                 err = get_cur_mix_value(cval, c + 1, &val);
715                                 if (err < 0) {
716                                         if (cval->mixer->ignore_ctl_error) {
717                                                 ucontrol->value.integer.value[0] = cval->min;
718                                                 return 0;
719                                         }
720                                         snd_printd(KERN_ERR "cannot get current value for control %d ch %d: err = %d\n", cval->control, c + 1, err);
721                                         return err;
722                                 }
723                                 val = get_relative_value(cval, val);
724                                 ucontrol->value.integer.value[cnt] = val;
725                                 cnt++;
726                         }
727                 }
728         } else {
729                 /* master channel */
730                 err = get_cur_mix_value(cval, 0, &val);
731                 if (err < 0) {
732                         if (cval->mixer->ignore_ctl_error) {
733                                 ucontrol->value.integer.value[0] = cval->min;
734                                 return 0;
735                         }
736                         snd_printd(KERN_ERR "cannot get current value for control %d master ch: err = %d\n", cval->control, err);
737                         return err;
738                 }
739                 val = get_relative_value(cval, val);
740                 ucontrol->value.integer.value[0] = val;
741         }
742         return 0;
743 }
744
745 /* put the current value to feature/mixer unit */
746 static int mixer_ctl_feature_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
747 {
748         struct usb_mixer_elem_info *cval = kcontrol->private_data;
749         int c, cnt, val, oval, err;
750         int changed = 0;
751
752         if (cval->cmask) {
753                 cnt = 0;
754                 for (c = 0; c < MAX_CHANNELS; c++) {
755                         if (cval->cmask & (1 << c)) {
756                                 err = get_cur_mix_value(cval, c + 1, &oval);
757                                 if (err < 0) {
758                                         if (cval->mixer->ignore_ctl_error)
759                                                 return 0;
760                                         return err;
761                                 }
762                                 val = ucontrol->value.integer.value[cnt];
763                                 val = get_abs_value(cval, val);
764                                 if (oval != val) {
765                                         set_cur_mix_value(cval, c + 1, val);
766                                         changed = 1;
767                                 }
768                                 get_cur_mix_value(cval, c + 1, &val);
769                                 cnt++;
770                         }
771                 }
772         } else {
773                 /* master channel */
774                 err = get_cur_mix_value(cval, 0, &oval);
775                 if (err < 0 && cval->mixer->ignore_ctl_error)
776                         return 0;
777                 if (err < 0)
778                         return err;
779                 val = ucontrol->value.integer.value[0];
780                 val = get_abs_value(cval, val);
781                 if (val != oval) {
782                         set_cur_mix_value(cval, 0, val);
783                         changed = 1;
784                 }
785         }
786         return changed;
787 }
788
789 static struct snd_kcontrol_new usb_feature_unit_ctl = {
790         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
791         .name = "", /* will be filled later manually */
792         .info = mixer_ctl_feature_info,
793         .get = mixer_ctl_feature_get,
794         .put = mixer_ctl_feature_put,
795 };
796
797
798 /*
799  * build a feature control
800  */
801
802 static void build_feature_ctl(struct mixer_build *state, unsigned char *desc,
803                               unsigned int ctl_mask, int control,
804                               struct usb_audio_term *iterm, int unitid)
805 {
806         unsigned int len = 0;
807         int mapped_name = 0;
808         int nameid = desc[desc[0] - 1];
809         struct snd_kcontrol *kctl;
810         struct usb_mixer_elem_info *cval;
811
812         control++; /* change from zero-based to 1-based value */
813
814         if (control == USB_FEATURE_GEQ) {
815                 /* FIXME: not supported yet */
816                 return;
817         }
818
819         if (check_ignored_ctl(state, unitid, control))
820                 return;
821
822         cval = kzalloc(sizeof(*cval), GFP_KERNEL);
823         if (! cval) {
824                 snd_printk(KERN_ERR "cannot malloc kcontrol\n");
825                 return;
826         }
827         cval->mixer = state->mixer;
828         cval->id = unitid;
829         cval->control = control;
830         cval->cmask = ctl_mask;
831         cval->val_type = audio_feature_info[control-1].type;
832         if (ctl_mask == 0)
833                 cval->channels = 1;     /* master channel */
834         else {
835                 int i, c = 0;
836                 for (i = 0; i < 16; i++)
837                         if (ctl_mask & (1 << i))
838                                 c++;
839                 cval->channels = c;
840         }
841
842         /* get min/max values */
843         get_min_max(cval, 0);
844
845         kctl = snd_ctl_new1(&usb_feature_unit_ctl, cval);
846         if (! kctl) {
847                 snd_printk(KERN_ERR "cannot malloc kcontrol\n");
848                 kfree(cval);
849                 return;
850         }
851         kctl->private_free = usb_mixer_elem_free;
852
853         len = check_mapped_name(state, unitid, control, kctl->id.name, sizeof(kctl->id.name));
854         mapped_name = len != 0;
855         if (! len && nameid)
856                 len = snd_usb_copy_string_desc(state, nameid, kctl->id.name, sizeof(kctl->id.name));
857
858         switch (control) {
859         case USB_FEATURE_MUTE:
860         case USB_FEATURE_VOLUME:
861                 /* determine the control name.  the rule is:
862                  * - if a name id is given in descriptor, use it.
863                  * - if the connected input can be determined, then use the name
864                  *   of terminal type.
865                  * - if the connected output can be determined, use it.
866                  * - otherwise, anonymous name.
867                  */
868                 if (! len) {
869                         len = get_term_name(state, iterm, kctl->id.name, sizeof(kctl->id.name), 1);
870                         if (! len)
871                                 len = get_term_name(state, &state->oterm, kctl->id.name, sizeof(kctl->id.name), 1);
872                         if (! len)
873                                 len = snprintf(kctl->id.name, sizeof(kctl->id.name),
874                                                "Feature %d", unitid);
875                 }
876                 /* determine the stream direction:
877                  * if the connected output is USB stream, then it's likely a
878                  * capture stream.  otherwise it should be playback (hopefully :)
879                  */
880                 if (! mapped_name && ! (state->oterm.type >> 16)) {
881                         if ((state->oterm.type & 0xff00) == 0x0100) {
882                                 len = strlcat(kctl->id.name, " Capture", sizeof(kctl->id.name));
883                         } else {
884                                 len = strlcat(kctl->id.name + len, " Playback", sizeof(kctl->id.name));
885                         }
886                 }
887                 strlcat(kctl->id.name + len, control == USB_FEATURE_MUTE ? " Switch" : " Volume",
888                         sizeof(kctl->id.name));
889                 break;
890
891         default:
892                 if (! len)
893                         strlcpy(kctl->id.name, audio_feature_info[control-1].name,
894                                 sizeof(kctl->id.name));
895                 break;
896         }
897
898         /* quirk for UDA1321/N101 */
899         /* note that detection between firmware 2.1.1.7 (N101) and later 2.1.1.21 */
900         /* is not very clear from datasheets */
901         /* I hope that the min value is -15360 for newer firmware --jk */
902         switch (state->chip->usb_id) {
903         case USB_ID(0x0471, 0x0101):
904         case USB_ID(0x0471, 0x0104):
905         case USB_ID(0x0471, 0x0105):
906         case USB_ID(0x0672, 0x1041):
907                 if (!strcmp(kctl->id.name, "PCM Playback Volume") &&
908                     cval->min == -15616) {
909                         snd_printk(KERN_INFO "using volume control quirk for the UDA1321/N101 chip\n");
910                         cval->max = -256;
911                 }
912         }
913
914         snd_printdd(KERN_INFO "[%d] FU [%s] ch = %d, val = %d/%d/%d\n",
915                     cval->id, kctl->id.name, cval->channels, cval->min, cval->max, cval->res);
916         add_control_to_empty(state, kctl);
917 }
918
919
920
921 /*
922  * parse a feature unit
923  *
924  * most of controlls are defined here.
925  */
926 static int parse_audio_feature_unit(struct mixer_build *state, int unitid, unsigned char *ftr)
927 {
928         int channels, i, j;
929         struct usb_audio_term iterm;
930         unsigned int master_bits, first_ch_bits;
931         int err, csize;
932
933         if (ftr[0] < 7 || ! (csize = ftr[5]) || ftr[0] < 7 + csize) {
934                 snd_printk(KERN_ERR "usbaudio: unit %u: invalid FEATURE_UNIT descriptor\n", unitid);
935                 return -EINVAL;
936         }
937
938         /* parse the source unit */
939         if ((err = parse_audio_unit(state, ftr[4])) < 0)
940                 return err;
941
942         /* determine the input source type and name */
943         if (check_input_term(state, ftr[4], &iterm) < 0)
944                 return -EINVAL;
945
946         channels = (ftr[0] - 7) / csize - 1;
947
948         master_bits = snd_usb_combine_bytes(ftr + 6, csize);
949         if (channels > 0)
950                 first_ch_bits = snd_usb_combine_bytes(ftr + 6 + csize, csize);
951         else
952                 first_ch_bits = 0;
953         /* check all control types */
954         for (i = 0; i < 10; i++) {
955                 unsigned int ch_bits = 0;
956                 for (j = 0; j < channels; j++) {
957                         unsigned int mask = snd_usb_combine_bytes(ftr + 6 + csize * (j+1), csize);
958                         if (mask & (1 << i))
959                                 ch_bits |= (1 << j);
960                 }
961                 if (ch_bits & 1) /* the first channel must be set (for ease of programming) */
962                         build_feature_ctl(state, ftr, ch_bits, i, &iterm, unitid);
963                 if (master_bits & (1 << i))
964                         build_feature_ctl(state, ftr, 0, i, &iterm, unitid);
965         }
966
967         return 0;
968 }
969
970
971 /*
972  * Mixer Unit
973  */
974
975 /*
976  * build a mixer unit control
977  *
978  * the callbacks are identical with feature unit.
979  * input channel number (zero based) is given in control field instead.
980  */
981
982 static void build_mixer_unit_ctl(struct mixer_build *state, unsigned char *desc,
983                                  int in_pin, int in_ch, int unitid,
984                                  struct usb_audio_term *iterm)
985 {
986         struct usb_mixer_elem_info *cval;
987         unsigned int input_pins = desc[4];
988         unsigned int num_outs = desc[5 + input_pins];
989         unsigned int i, len;
990         struct snd_kcontrol *kctl;
991
992         if (check_ignored_ctl(state, unitid, 0))
993                 return;
994
995         cval = kzalloc(sizeof(*cval), GFP_KERNEL);
996         if (! cval)
997                 return;
998
999         cval->mixer = state->mixer;
1000         cval->id = unitid;
1001         cval->control = in_ch + 1; /* based on 1 */
1002         cval->val_type = USB_MIXER_S16;
1003         for (i = 0; i < num_outs; i++) {
1004                 if (check_matrix_bitmap(desc + 9 + input_pins, in_ch, i, num_outs)) {
1005                         cval->cmask |= (1 << i);
1006                         cval->channels++;
1007                 }
1008         }
1009
1010         /* get min/max values */
1011         get_min_max(cval, 0);
1012
1013         kctl = snd_ctl_new1(&usb_feature_unit_ctl, cval);
1014         if (! kctl) {
1015                 snd_printk(KERN_ERR "cannot malloc kcontrol\n");
1016                 kfree(cval);
1017                 return;
1018         }
1019         kctl->private_free = usb_mixer_elem_free;
1020
1021         len = check_mapped_name(state, unitid, 0, kctl->id.name, sizeof(kctl->id.name));
1022         if (! len)
1023                 len = get_term_name(state, iterm, kctl->id.name, sizeof(kctl->id.name), 0);
1024         if (! len)
1025                 len = sprintf(kctl->id.name, "Mixer Source %d", in_ch + 1);
1026         strlcat(kctl->id.name + len, " Volume", sizeof(kctl->id.name));
1027
1028         snd_printdd(KERN_INFO "[%d] MU [%s] ch = %d, val = %d/%d\n",
1029                     cval->id, kctl->id.name, cval->channels, cval->min, cval->max);
1030         add_control_to_empty(state, kctl);
1031 }
1032
1033
1034 /*
1035  * parse a mixer unit
1036  */
1037 static int parse_audio_mixer_unit(struct mixer_build *state, int unitid, unsigned char *desc)
1038 {
1039         struct usb_audio_term iterm;
1040         int input_pins, num_ins, num_outs;
1041         int pin, ich, err;
1042
1043         if (desc[0] < 11 || ! (input_pins = desc[4]) || ! (num_outs = desc[5 + input_pins])) {
1044                 snd_printk(KERN_ERR "invalid MIXER UNIT descriptor %d\n", unitid);
1045                 return -EINVAL;
1046         }
1047         /* no bmControls field (e.g. Maya44) -> ignore */
1048         if (desc[0] <= 10 + input_pins) {
1049                 snd_printdd(KERN_INFO "MU %d has no bmControls field\n", unitid);
1050                 return 0;
1051         }
1052
1053         num_ins = 0;
1054         ich = 0;
1055         for (pin = 0; pin < input_pins; pin++) {
1056                 err = parse_audio_unit(state, desc[5 + pin]);
1057                 if (err < 0)
1058                         return err;
1059                 err = check_input_term(state, desc[5 + pin], &iterm);
1060                 if (err < 0)
1061                         return err;
1062                 num_ins += iterm.channels;
1063                 for (; ich < num_ins; ++ich) {
1064                         int och, ich_has_controls = 0;
1065
1066                         for (och = 0; och < num_outs; ++och) {
1067                                 if (check_matrix_bitmap(desc + 9 + input_pins,
1068                                                         ich, och, num_outs)) {
1069                                         ich_has_controls = 1;
1070                                         break;
1071                                 }
1072                         }
1073                         if (ich_has_controls)
1074                                 build_mixer_unit_ctl(state, desc, pin, ich,
1075                                                      unitid, &iterm);
1076                 }
1077         }
1078         return 0;
1079 }
1080
1081
1082 /*
1083  * Processing Unit / Extension Unit
1084  */
1085
1086 /* get callback for processing/extension unit */
1087 static int mixer_ctl_procunit_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1088 {
1089         struct usb_mixer_elem_info *cval = kcontrol->private_data;
1090         int err, val;
1091
1092         err = get_cur_ctl_value(cval, cval->control << 8, &val);
1093         if (err < 0 && cval->mixer->ignore_ctl_error) {
1094                 ucontrol->value.integer.value[0] = cval->min;
1095                 return 0;
1096         }
1097         if (err < 0)
1098                 return err;
1099         val = get_relative_value(cval, val);
1100         ucontrol->value.integer.value[0] = val;
1101         return 0;
1102 }
1103
1104 /* put callback for processing/extension unit */
1105 static int mixer_ctl_procunit_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1106 {
1107         struct usb_mixer_elem_info *cval = kcontrol->private_data;
1108         int val, oval, err;
1109
1110         err = get_cur_ctl_value(cval, cval->control << 8, &oval);
1111         if (err < 0) {
1112                 if (cval->mixer->ignore_ctl_error)
1113                         return 0;
1114                 return err;
1115         }
1116         val = ucontrol->value.integer.value[0];
1117         val = get_abs_value(cval, val);
1118         if (val != oval) {
1119                 set_cur_ctl_value(cval, cval->control << 8, val);
1120                 return 1;
1121         }
1122         return 0;
1123 }
1124
1125 /* alsa control interface for processing/extension unit */
1126 static struct snd_kcontrol_new mixer_procunit_ctl = {
1127         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1128         .name = "", /* will be filled later */
1129         .info = mixer_ctl_feature_info,
1130         .get = mixer_ctl_procunit_get,
1131         .put = mixer_ctl_procunit_put,
1132 };
1133
1134
1135 /*
1136  * predefined data for processing units
1137  */
1138 struct procunit_value_info {
1139         int control;
1140         char *suffix;
1141         int val_type;
1142         int min_value;
1143 };
1144
1145 struct procunit_info {
1146         int type;
1147         char *name;
1148         struct procunit_value_info *values;
1149 };
1150
1151 static struct procunit_value_info updown_proc_info[] = {
1152         { USB_PROC_UPDOWN_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1153         { USB_PROC_UPDOWN_MODE_SEL, "Mode Select", USB_MIXER_U8, 1 },
1154         { 0 }
1155 };
1156 static struct procunit_value_info prologic_proc_info[] = {
1157         { USB_PROC_PROLOGIC_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1158         { USB_PROC_PROLOGIC_MODE_SEL, "Mode Select", USB_MIXER_U8, 1 },
1159         { 0 }
1160 };
1161 static struct procunit_value_info threed_enh_proc_info[] = {
1162         { USB_PROC_3DENH_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1163         { USB_PROC_3DENH_SPACE, "Spaciousness", USB_MIXER_U8 },
1164         { 0 }
1165 };
1166 static struct procunit_value_info reverb_proc_info[] = {
1167         { USB_PROC_REVERB_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1168         { USB_PROC_REVERB_LEVEL, "Level", USB_MIXER_U8 },
1169         { USB_PROC_REVERB_TIME, "Time", USB_MIXER_U16 },
1170         { USB_PROC_REVERB_DELAY, "Delay", USB_MIXER_U8 },
1171         { 0 }
1172 };
1173 static struct procunit_value_info chorus_proc_info[] = {
1174         { USB_PROC_CHORUS_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1175         { USB_PROC_CHORUS_LEVEL, "Level", USB_MIXER_U8 },
1176         { USB_PROC_CHORUS_RATE, "Rate", USB_MIXER_U16 },
1177         { USB_PROC_CHORUS_DEPTH, "Depth", USB_MIXER_U16 },
1178         { 0 }
1179 };
1180 static struct procunit_value_info dcr_proc_info[] = {
1181         { USB_PROC_DCR_SWITCH, "Switch", USB_MIXER_BOOLEAN },
1182         { USB_PROC_DCR_RATIO, "Ratio", USB_MIXER_U16 },
1183         { USB_PROC_DCR_MAX_AMP, "Max Amp", USB_MIXER_S16 },
1184         { USB_PROC_DCR_THRESHOLD, "Threshold", USB_MIXER_S16 },
1185         { USB_PROC_DCR_ATTACK, "Attack Time", USB_MIXER_U16 },
1186         { USB_PROC_DCR_RELEASE, "Release Time", USB_MIXER_U16 },
1187         { 0 }
1188 };
1189
1190 static struct procunit_info procunits[] = {
1191         { USB_PROC_UPDOWN, "Up Down", updown_proc_info },
1192         { USB_PROC_PROLOGIC, "Dolby Prologic", prologic_proc_info },
1193         { USB_PROC_3DENH, "3D Stereo Extender", threed_enh_proc_info },
1194         { USB_PROC_REVERB, "Reverb", reverb_proc_info },
1195         { USB_PROC_CHORUS, "Chorus", chorus_proc_info },
1196         { USB_PROC_DCR, "DCR", dcr_proc_info },
1197         { 0 },
1198 };
1199
1200 /*
1201  * build a processing/extension unit
1202  */
1203 static int build_audio_procunit(struct mixer_build *state, int unitid, unsigned char *dsc, struct procunit_info *list, char *name)
1204 {
1205         int num_ins = dsc[6];
1206         struct usb_mixer_elem_info *cval;
1207         struct snd_kcontrol *kctl;
1208         int i, err, nameid, type, len;
1209         struct procunit_info *info;
1210         struct procunit_value_info *valinfo;
1211         static struct procunit_value_info default_value_info[] = {
1212                 { 0x01, "Switch", USB_MIXER_BOOLEAN },
1213                 { 0 }
1214         };
1215         static struct procunit_info default_info = {
1216                 0, NULL, default_value_info
1217         };
1218
1219         if (dsc[0] < 13 || dsc[0] < 13 + num_ins || dsc[0] < num_ins + dsc[11 + num_ins]) {
1220                 snd_printk(KERN_ERR "invalid %s descriptor (id %d)\n", name, unitid);
1221                 return -EINVAL;
1222         }
1223
1224         for (i = 0; i < num_ins; i++) {
1225                 if ((err = parse_audio_unit(state, dsc[7 + i])) < 0)
1226                         return err;
1227         }
1228
1229         type = combine_word(&dsc[4]);
1230         for (info = list; info && info->type; info++)
1231                 if (info->type == type)
1232                         break;
1233         if (! info || ! info->type)
1234                 info = &default_info;
1235
1236         for (valinfo = info->values; valinfo->control; valinfo++) {
1237                 /* FIXME: bitmap might be longer than 8bit */
1238                 if (! (dsc[12 + num_ins] & (1 << (valinfo->control - 1))))
1239                         continue;
1240                 if (check_ignored_ctl(state, unitid, valinfo->control))
1241                         continue;
1242                 cval = kzalloc(sizeof(*cval), GFP_KERNEL);
1243                 if (! cval) {
1244                         snd_printk(KERN_ERR "cannot malloc kcontrol\n");
1245                         return -ENOMEM;
1246                 }
1247                 cval->mixer = state->mixer;
1248                 cval->id = unitid;
1249                 cval->control = valinfo->control;
1250                 cval->val_type = valinfo->val_type;
1251                 cval->channels = 1;
1252
1253                 /* get min/max values */
1254                 if (type == USB_PROC_UPDOWN && cval->control == USB_PROC_UPDOWN_MODE_SEL) {
1255                         /* FIXME: hard-coded */
1256                         cval->min = 1;
1257                         cval->max = dsc[15];
1258                         cval->res = 1;
1259                         cval->initialized = 1;
1260                 } else
1261                         get_min_max(cval, valinfo->min_value);
1262
1263                 kctl = snd_ctl_new1(&mixer_procunit_ctl, cval);
1264                 if (! kctl) {
1265                         snd_printk(KERN_ERR "cannot malloc kcontrol\n");
1266                         kfree(cval);
1267                         return -ENOMEM;
1268                 }
1269                 kctl->private_free = usb_mixer_elem_free;
1270
1271                 if (check_mapped_name(state, unitid, cval->control, kctl->id.name, sizeof(kctl->id.name)))
1272                         ;
1273                 else if (info->name)
1274                         strlcpy(kctl->id.name, info->name, sizeof(kctl->id.name));
1275                 else {
1276                         nameid = dsc[12 + num_ins + dsc[11 + num_ins]];
1277                         len = 0;
1278                         if (nameid)
1279                                 len = snd_usb_copy_string_desc(state, nameid, kctl->id.name, sizeof(kctl->id.name));
1280                         if (! len)
1281                                 strlcpy(kctl->id.name, name, sizeof(kctl->id.name));
1282                 }
1283                 strlcat(kctl->id.name, " ", sizeof(kctl->id.name));
1284                 strlcat(kctl->id.name, valinfo->suffix, sizeof(kctl->id.name));
1285
1286                 snd_printdd(KERN_INFO "[%d] PU [%s] ch = %d, val = %d/%d\n",
1287                             cval->id, kctl->id.name, cval->channels, cval->min, cval->max);
1288                 if ((err = add_control_to_empty(state, kctl)) < 0)
1289                         return err;
1290         }
1291         return 0;
1292 }
1293
1294
1295 static int parse_audio_processing_unit(struct mixer_build *state, int unitid, unsigned char *desc)
1296 {
1297         return build_audio_procunit(state, unitid, desc, procunits, "Processing Unit");
1298 }
1299
1300 static int parse_audio_extension_unit(struct mixer_build *state, int unitid, unsigned char *desc)
1301 {
1302         return build_audio_procunit(state, unitid, desc, NULL, "Extension Unit");
1303 }
1304
1305
1306 /*
1307  * Selector Unit
1308  */
1309
1310 /* info callback for selector unit
1311  * use an enumerator type for routing
1312  */
1313 static int mixer_ctl_selector_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1314 {
1315         struct usb_mixer_elem_info *cval = kcontrol->private_data;
1316         char **itemlist = (char **)kcontrol->private_value;
1317
1318         snd_assert(itemlist, return -EINVAL);
1319         uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1320         uinfo->count = 1;
1321         uinfo->value.enumerated.items = cval->max;
1322         if ((int)uinfo->value.enumerated.item >= cval->max)
1323                 uinfo->value.enumerated.item = cval->max - 1;
1324         strcpy(uinfo->value.enumerated.name, itemlist[uinfo->value.enumerated.item]);
1325         return 0;
1326 }
1327
1328 /* get callback for selector unit */
1329 static int mixer_ctl_selector_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1330 {
1331         struct usb_mixer_elem_info *cval = kcontrol->private_data;
1332         int val, err;
1333
1334         err = get_cur_ctl_value(cval, 0, &val);
1335         if (err < 0) {
1336                 if (cval->mixer->ignore_ctl_error) {
1337                         ucontrol->value.enumerated.item[0] = 0;
1338                         return 0;
1339                 }
1340                 return err;
1341         }
1342         val = get_relative_value(cval, val);
1343         ucontrol->value.enumerated.item[0] = val;
1344         return 0;
1345 }
1346
1347 /* put callback for selector unit */
1348 static int mixer_ctl_selector_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1349 {
1350         struct usb_mixer_elem_info *cval = kcontrol->private_data;
1351         int val, oval, err;
1352
1353         err = get_cur_ctl_value(cval, 0, &oval);
1354         if (err < 0) {
1355                 if (cval->mixer->ignore_ctl_error)
1356                         return 0;
1357                 return err;
1358         }
1359         val = ucontrol->value.enumerated.item[0];
1360         val = get_abs_value(cval, val);
1361         if (val != oval) {
1362                 set_cur_ctl_value(cval, 0, val);
1363                 return 1;
1364         }
1365         return 0;
1366 }
1367
1368 /* alsa control interface for selector unit */
1369 static struct snd_kcontrol_new mixer_selectunit_ctl = {
1370         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1371         .name = "", /* will be filled later */
1372         .info = mixer_ctl_selector_info,
1373         .get = mixer_ctl_selector_get,
1374         .put = mixer_ctl_selector_put,
1375 };
1376
1377
1378 /* private free callback.
1379  * free both private_data and private_value
1380  */
1381 static void usb_mixer_selector_elem_free(struct snd_kcontrol *kctl)
1382 {
1383         int i, num_ins = 0;
1384
1385         if (kctl->private_data) {
1386                 struct usb_mixer_elem_info *cval = kctl->private_data;
1387                 num_ins = cval->max;
1388                 kfree(cval);
1389                 kctl->private_data = NULL;
1390         }
1391         if (kctl->private_value) {
1392                 char **itemlist = (char **)kctl->private_value;
1393                 for (i = 0; i < num_ins; i++)
1394                         kfree(itemlist[i]);
1395                 kfree(itemlist);
1396                 kctl->private_value = 0;
1397         }
1398 }
1399
1400 /*
1401  * parse a selector unit
1402  */
1403 static int parse_audio_selector_unit(struct mixer_build *state, int unitid, unsigned char *desc)
1404 {
1405         unsigned int num_ins = desc[4];
1406         unsigned int i, nameid, len;
1407         int err;
1408         struct usb_mixer_elem_info *cval;
1409         struct snd_kcontrol *kctl;
1410         char **namelist;
1411
1412         if (! num_ins || desc[0] < 6 + num_ins) {
1413                 snd_printk(KERN_ERR "invalid SELECTOR UNIT descriptor %d\n", unitid);
1414                 return -EINVAL;
1415         }
1416
1417         for (i = 0; i < num_ins; i++) {
1418                 if ((err = parse_audio_unit(state, desc[5 + i])) < 0)
1419                         return err;
1420         }
1421
1422         if (num_ins == 1) /* only one ? nonsense! */
1423                 return 0;
1424
1425         if (check_ignored_ctl(state, unitid, 0))
1426                 return 0;
1427
1428         cval = kzalloc(sizeof(*cval), GFP_KERNEL);
1429         if (! cval) {
1430                 snd_printk(KERN_ERR "cannot malloc kcontrol\n");
1431                 return -ENOMEM;
1432         }
1433         cval->mixer = state->mixer;
1434         cval->id = unitid;
1435         cval->val_type = USB_MIXER_U8;
1436         cval->channels = 1;
1437         cval->min = 1;
1438         cval->max = num_ins;
1439         cval->res = 1;
1440         cval->initialized = 1;
1441
1442         namelist = kmalloc(sizeof(char *) * num_ins, GFP_KERNEL);
1443         if (! namelist) {
1444                 snd_printk(KERN_ERR "cannot malloc\n");
1445                 kfree(cval);
1446                 return -ENOMEM;
1447         }
1448 #define MAX_ITEM_NAME_LEN       64
1449         for (i = 0; i < num_ins; i++) {
1450                 struct usb_audio_term iterm;
1451                 len = 0;
1452                 namelist[i] = kmalloc(MAX_ITEM_NAME_LEN, GFP_KERNEL);
1453                 if (! namelist[i]) {
1454                         snd_printk(KERN_ERR "cannot malloc\n");
1455                         while (--i > 0)
1456                                 kfree(namelist[i]);
1457                         kfree(namelist);
1458                         kfree(cval);
1459                         return -ENOMEM;
1460                 }
1461                 len = check_mapped_selector_name(state, unitid, i, namelist[i],
1462                                                  MAX_ITEM_NAME_LEN);
1463                 if (! len && check_input_term(state, desc[5 + i], &iterm) >= 0)
1464                         len = get_term_name(state, &iterm, namelist[i], MAX_ITEM_NAME_LEN, 0);
1465                 if (! len)
1466                         sprintf(namelist[i], "Input %d", i);
1467         }
1468
1469         kctl = snd_ctl_new1(&mixer_selectunit_ctl, cval);
1470         if (! kctl) {
1471                 snd_printk(KERN_ERR "cannot malloc kcontrol\n");
1472                 kfree(cval);
1473                 return -ENOMEM;
1474         }
1475         kctl->private_value = (unsigned long)namelist;
1476         kctl->private_free = usb_mixer_selector_elem_free;
1477
1478         nameid = desc[desc[0] - 1];
1479         len = check_mapped_name(state, unitid, 0, kctl->id.name, sizeof(kctl->id.name));
1480         if (len)
1481                 ;
1482         else if (nameid)
1483                 snd_usb_copy_string_desc(state, nameid, kctl->id.name, sizeof(kctl->id.name));
1484         else {
1485                 len = get_term_name(state, &state->oterm,
1486                                     kctl->id.name, sizeof(kctl->id.name), 0);
1487                 if (! len)
1488                         strlcpy(kctl->id.name, "USB", sizeof(kctl->id.name));
1489
1490                 if ((state->oterm.type & 0xff00) == 0x0100)
1491                         strlcat(kctl->id.name, " Capture Source", sizeof(kctl->id.name));
1492                 else
1493                         strlcat(kctl->id.name, " Playback Source", sizeof(kctl->id.name));
1494         }
1495
1496         snd_printdd(KERN_INFO "[%d] SU [%s] items = %d\n",
1497                     cval->id, kctl->id.name, num_ins);
1498         if ((err = add_control_to_empty(state, kctl)) < 0)
1499                 return err;
1500
1501         return 0;
1502 }
1503
1504
1505 /*
1506  * parse an audio unit recursively
1507  */
1508
1509 static int parse_audio_unit(struct mixer_build *state, int unitid)
1510 {
1511         unsigned char *p1;
1512
1513         if (test_and_set_bit(unitid, state->unitbitmap))
1514                 return 0; /* the unit already visited */
1515
1516         p1 = find_audio_control_unit(state, unitid);
1517         if (!p1) {
1518                 snd_printk(KERN_ERR "usbaudio: unit %d not found!\n", unitid);
1519                 return -EINVAL;
1520         }
1521
1522         switch (p1[2]) {
1523         case INPUT_TERMINAL:
1524                 return 0; /* NOP */
1525         case MIXER_UNIT:
1526                 return parse_audio_mixer_unit(state, unitid, p1);
1527         case SELECTOR_UNIT:
1528                 return parse_audio_selector_unit(state, unitid, p1);
1529         case FEATURE_UNIT:
1530                 return parse_audio_feature_unit(state, unitid, p1);
1531         case PROCESSING_UNIT:
1532                 return parse_audio_processing_unit(state, unitid, p1);
1533         case EXTENSION_UNIT:
1534                 return parse_audio_extension_unit(state, unitid, p1);
1535         default:
1536                 snd_printk(KERN_ERR "usbaudio: unit %u: unexpected type 0x%02x\n", unitid, p1[2]);
1537                 return -EINVAL;
1538         }
1539 }
1540
1541 static void snd_usb_mixer_free(struct usb_mixer_interface *mixer)
1542 {
1543         kfree(mixer->id_elems);
1544         if (mixer->urb) {
1545                 kfree(mixer->urb->transfer_buffer);
1546                 usb_free_urb(mixer->urb);
1547         }
1548         if (mixer->rc_urb)
1549                 usb_free_urb(mixer->rc_urb);
1550         kfree(mixer->rc_setup_packet);
1551         kfree(mixer);
1552 }
1553
1554 static int snd_usb_mixer_dev_free(struct snd_device *device)
1555 {
1556         struct usb_mixer_interface *mixer = device->device_data;
1557         snd_usb_mixer_free(mixer);
1558         return 0;
1559 }
1560
1561 /*
1562  * create mixer controls
1563  *
1564  * walk through all OUTPUT_TERMINAL descriptors to search for mixers
1565  */
1566 static int snd_usb_mixer_controls(struct usb_mixer_interface *mixer)
1567 {
1568         unsigned char *desc;
1569         struct mixer_build state;
1570         int err;
1571         const struct usbmix_ctl_map *map;
1572         struct usb_host_interface *hostif;
1573
1574         hostif = &usb_ifnum_to_if(mixer->chip->dev, mixer->ctrlif)->altsetting[0];
1575         memset(&state, 0, sizeof(state));
1576         state.chip = mixer->chip;
1577         state.mixer = mixer;
1578         state.buffer = hostif->extra;
1579         state.buflen = hostif->extralen;
1580
1581         /* check the mapping table */
1582         for (map = usbmix_ctl_maps; map->id; map++) {
1583                 if (map->id == state.chip->usb_id) {
1584                         state.map = map->map;
1585                         state.selector_map = map->selector_map;
1586                         mixer->ignore_ctl_error = map->ignore_ctl_error;
1587                         break;
1588                 }
1589         }
1590
1591         desc = NULL;
1592         while ((desc = snd_usb_find_csint_desc(hostif->extra, hostif->extralen, desc, OUTPUT_TERMINAL)) != NULL) {
1593                 if (desc[0] < 9)
1594                         continue; /* invalid descriptor? */
1595                 set_bit(desc[3], state.unitbitmap);  /* mark terminal ID as visited */
1596                 state.oterm.id = desc[3];
1597                 state.oterm.type = combine_word(&desc[4]);
1598                 state.oterm.name = desc[8];
1599                 err = parse_audio_unit(&state, desc[7]);
1600                 if (err < 0)
1601                         return err;
1602         }
1603         return 0;
1604 }
1605
1606 static void snd_usb_mixer_notify_id(struct usb_mixer_interface *mixer,
1607                                     int unitid)
1608 {
1609         struct usb_mixer_elem_info *info;
1610
1611         for (info = mixer->id_elems[unitid]; info; info = info->next_id_elem)
1612                 snd_ctl_notify(mixer->chip->card, SNDRV_CTL_EVENT_MASK_VALUE,
1613                                info->elem_id);
1614 }
1615
1616 static void snd_usb_mixer_memory_change(struct usb_mixer_interface *mixer,
1617                                         int unitid)
1618 {
1619         if (mixer->rc_type == RC_NONE)
1620                 return;
1621         /* unit ids specific to Extigy/Audigy 2 NX: */
1622         switch (unitid) {
1623         case 0: /* remote control */
1624                 mixer->rc_urb->dev = mixer->chip->dev;
1625                 usb_submit_urb(mixer->rc_urb, GFP_ATOMIC);
1626                 break;
1627         case 4: /* digital in jack */
1628         case 7: /* line in jacks */
1629         case 19: /* speaker out jacks */
1630         case 20: /* headphones out jack */
1631                 break;
1632         default:
1633                 snd_printd(KERN_DEBUG "memory change in unknown unit %d\n", unitid);
1634                 break;
1635         }
1636 }
1637
1638 static void snd_usb_mixer_status_complete(struct urb *urb, struct pt_regs *regs)
1639 {
1640         struct usb_mixer_interface *mixer = urb->context;
1641
1642         if (urb->status == 0) {
1643                 u8 *buf = urb->transfer_buffer;
1644                 int i;
1645
1646                 for (i = urb->actual_length; i >= 2; buf += 2, i -= 2) {
1647                         snd_printd(KERN_DEBUG "status interrupt: %02x %02x\n",
1648                                    buf[0], buf[1]);
1649                         /* ignore any notifications not from the control interface */
1650                         if ((buf[0] & 0x0f) != 0)
1651                                 continue;
1652                         if (!(buf[0] & 0x40))
1653                                 snd_usb_mixer_notify_id(mixer, buf[1]);
1654                         else
1655                                 snd_usb_mixer_memory_change(mixer, buf[1]);
1656                 }
1657         }
1658         if (urb->status != -ENOENT && urb->status != -ECONNRESET) {
1659                 urb->dev = mixer->chip->dev;
1660                 usb_submit_urb(urb, GFP_ATOMIC);
1661         }
1662 }
1663
1664 /* create the handler for the optional status interrupt endpoint */
1665 static int snd_usb_mixer_status_create(struct usb_mixer_interface *mixer)
1666 {
1667         struct usb_host_interface *hostif;
1668         struct usb_endpoint_descriptor *ep;
1669         void *transfer_buffer;
1670         int buffer_length;
1671         unsigned int epnum;
1672
1673         hostif = &usb_ifnum_to_if(mixer->chip->dev, mixer->ctrlif)->altsetting[0];
1674         /* we need one interrupt input endpoint */
1675         if (get_iface_desc(hostif)->bNumEndpoints < 1)
1676                 return 0;
1677         ep = get_endpoint(hostif, 0);
1678         if ((ep->bEndpointAddress & USB_ENDPOINT_DIR_MASK) != USB_DIR_IN ||
1679             (ep->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT)
1680                 return 0;
1681
1682         epnum = ep->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK;
1683         buffer_length = le16_to_cpu(ep->wMaxPacketSize);
1684         transfer_buffer = kmalloc(buffer_length, GFP_KERNEL);
1685         if (!transfer_buffer)
1686                 return -ENOMEM;
1687         mixer->urb = usb_alloc_urb(0, GFP_KERNEL);
1688         if (!mixer->urb) {
1689                 kfree(transfer_buffer);
1690                 return -ENOMEM;
1691         }
1692         usb_fill_int_urb(mixer->urb, mixer->chip->dev,
1693                          usb_rcvintpipe(mixer->chip->dev, epnum),
1694                          transfer_buffer, buffer_length,
1695                          snd_usb_mixer_status_complete, mixer, ep->bInterval);
1696         usb_submit_urb(mixer->urb, GFP_KERNEL);
1697         return 0;
1698 }
1699
1700 static void snd_usb_soundblaster_remote_complete(struct urb *urb,
1701                                                  struct pt_regs *regs)
1702 {
1703         struct usb_mixer_interface *mixer = urb->context;
1704         /*
1705          * format of remote control data:
1706          * Extigy:      xx 00
1707          * Audigy 2 NX: 06 80 xx 00 00 00
1708          */
1709         int offset = mixer->rc_type == RC_EXTIGY ? 0 : 2;
1710         u32 code;
1711
1712         if (urb->status < 0 || urb->actual_length <= offset)
1713                 return;
1714         code = mixer->rc_buffer[offset];
1715         /* the Mute button actually changes the mixer control */
1716         if (code == 13)
1717                 snd_usb_mixer_notify_id(mixer, 18);
1718         mixer->rc_code = code;
1719         wmb();
1720         wake_up(&mixer->rc_waitq);
1721 }
1722
1723 static int snd_usb_sbrc_hwdep_open(struct snd_hwdep *hw, struct file *file)
1724 {
1725         struct usb_mixer_interface *mixer = hw->private_data;
1726
1727         if (test_and_set_bit(0, &mixer->rc_hwdep_open))
1728                 return -EBUSY;
1729         return 0;
1730 }
1731
1732 static int snd_usb_sbrc_hwdep_release(struct snd_hwdep *hw, struct file *file)
1733 {
1734         struct usb_mixer_interface *mixer = hw->private_data;
1735
1736         clear_bit(0, &mixer->rc_hwdep_open);
1737         smp_mb__after_clear_bit();
1738         return 0;
1739 }
1740
1741 static long snd_usb_sbrc_hwdep_read(struct snd_hwdep *hw, char __user *buf,
1742                                      long count, loff_t *offset)
1743 {
1744         struct usb_mixer_interface *mixer = hw->private_data;
1745         int err;
1746         u32 rc_code;
1747
1748         if (count != 1 && count != 4)
1749                 return -EINVAL;
1750         err = wait_event_interruptible(mixer->rc_waitq,
1751                                        (rc_code = xchg(&mixer->rc_code, 0)) != 0);
1752         if (err == 0) {
1753                 if (count == 1)
1754                         err = put_user(rc_code, buf);
1755                 else
1756                         err = put_user(rc_code, (u32 __user *)buf);
1757         }
1758         return err < 0 ? err : count;
1759 }
1760
1761 static unsigned int snd_usb_sbrc_hwdep_poll(struct snd_hwdep *hw, struct file *file,
1762                                             poll_table *wait)
1763 {
1764         struct usb_mixer_interface *mixer = hw->private_data;
1765
1766         poll_wait(file, &mixer->rc_waitq, wait);
1767         return mixer->rc_code ? POLLIN | POLLRDNORM : 0;
1768 }
1769
1770 static int snd_usb_soundblaster_remote_init(struct usb_mixer_interface *mixer)
1771 {
1772         struct snd_hwdep *hwdep;
1773         int err, len;
1774
1775         switch (mixer->chip->usb_id) {
1776         case USB_ID(0x041e, 0x3000):
1777                 mixer->rc_type = RC_EXTIGY;
1778                 len = 2;
1779                 break;
1780         case USB_ID(0x041e, 0x3020):
1781                 mixer->rc_type = RC_AUDIGY2NX;
1782                 len = 6;
1783                 break;
1784         default:
1785                 return 0;
1786         }
1787
1788         init_waitqueue_head(&mixer->rc_waitq);
1789         err = snd_hwdep_new(mixer->chip->card, "SB remote control", 0, &hwdep);
1790         if (err < 0)
1791                 return err;
1792         snprintf(hwdep->name, sizeof(hwdep->name),
1793                  "%s remote control", mixer->chip->card->shortname);
1794         hwdep->iface = SNDRV_HWDEP_IFACE_SB_RC;
1795         hwdep->private_data = mixer;
1796         hwdep->ops.read = snd_usb_sbrc_hwdep_read;
1797         hwdep->ops.open = snd_usb_sbrc_hwdep_open;
1798         hwdep->ops.release = snd_usb_sbrc_hwdep_release;
1799         hwdep->ops.poll = snd_usb_sbrc_hwdep_poll;
1800
1801         mixer->rc_urb = usb_alloc_urb(0, GFP_KERNEL);
1802         if (!mixer->rc_urb)
1803                 return -ENOMEM;
1804         mixer->rc_setup_packet = kmalloc(sizeof(*mixer->rc_setup_packet), GFP_KERNEL);
1805         if (!mixer->rc_setup_packet) {
1806                 usb_free_urb(mixer->rc_urb);
1807                 mixer->rc_urb = NULL;
1808                 return -ENOMEM;
1809         }
1810         mixer->rc_setup_packet->bRequestType =
1811                 USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE;
1812         mixer->rc_setup_packet->bRequest = GET_MEM;
1813         mixer->rc_setup_packet->wValue = cpu_to_le16(0);
1814         mixer->rc_setup_packet->wIndex = cpu_to_le16(0);
1815         mixer->rc_setup_packet->wLength = cpu_to_le16(len);
1816         usb_fill_control_urb(mixer->rc_urb, mixer->chip->dev,
1817                              usb_rcvctrlpipe(mixer->chip->dev, 0),
1818                              (u8*)mixer->rc_setup_packet, mixer->rc_buffer, len,
1819                              snd_usb_soundblaster_remote_complete, mixer);
1820         return 0;
1821 }
1822
1823 static int snd_audigy2nx_led_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1824 {
1825         uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1826         uinfo->count = 1;
1827         uinfo->value.integer.min = 0;
1828         uinfo->value.integer.max = 1;
1829         return 0;
1830 }
1831
1832 static int snd_audigy2nx_led_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1833 {
1834         struct usb_mixer_interface *mixer = snd_kcontrol_chip(kcontrol);
1835         int index = kcontrol->private_value;
1836
1837         ucontrol->value.integer.value[0] = mixer->audigy2nx_leds[index];
1838         return 0;
1839 }
1840
1841 static int snd_audigy2nx_led_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1842 {
1843         struct usb_mixer_interface *mixer = snd_kcontrol_chip(kcontrol);
1844         int index = kcontrol->private_value;
1845         int value = ucontrol->value.integer.value[0];
1846         int err, changed;
1847
1848         if (value > 1)
1849                 return -EINVAL;
1850         changed = value != mixer->audigy2nx_leds[index];
1851         err = snd_usb_ctl_msg(mixer->chip->dev,
1852                               usb_sndctrlpipe(mixer->chip->dev, 0), 0x24,
1853                               USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER,
1854                               value, index + 2, NULL, 0, 100);
1855         if (err < 0)
1856                 return err;
1857         mixer->audigy2nx_leds[index] = value;
1858         return changed;
1859 }
1860
1861 static struct snd_kcontrol_new snd_audigy2nx_controls[] = {
1862         {
1863                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1864                 .name = "CMSS LED Switch",
1865                 .info = snd_audigy2nx_led_info,
1866                 .get = snd_audigy2nx_led_get,
1867                 .put = snd_audigy2nx_led_put,
1868                 .private_value = 0,
1869         },
1870         {
1871                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1872                 .name = "Power LED Switch",
1873                 .info = snd_audigy2nx_led_info,
1874                 .get = snd_audigy2nx_led_get,
1875                 .put = snd_audigy2nx_led_put,
1876                 .private_value = 1,
1877         },
1878         {
1879                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1880                 .name = "Dolby Digital LED Switch",
1881                 .info = snd_audigy2nx_led_info,
1882                 .get = snd_audigy2nx_led_get,
1883                 .put = snd_audigy2nx_led_put,
1884                 .private_value = 2,
1885         },
1886 };
1887
1888 static int snd_audigy2nx_controls_create(struct usb_mixer_interface *mixer)
1889 {
1890         int i, err;
1891
1892         for (i = 0; i < ARRAY_SIZE(snd_audigy2nx_controls); ++i) {
1893                 err = snd_ctl_add(mixer->chip->card,
1894                                   snd_ctl_new1(&snd_audigy2nx_controls[i], mixer));
1895                 if (err < 0)
1896                         return err;
1897         }
1898         mixer->audigy2nx_leds[1] = 1; /* Power LED is on by default */
1899         return 0;
1900 }
1901
1902 static void snd_audigy2nx_proc_read(struct snd_info_entry *entry,
1903                                     struct snd_info_buffer *buffer)
1904 {
1905         static const struct {
1906                 int unitid;
1907                 const char *name;
1908         } jacks[] = {
1909                 {4,  "dig in "},
1910                 {7,  "line in"},
1911                 {19, "spk out"},
1912                 {20, "hph out"},
1913         };
1914         struct usb_mixer_interface *mixer = entry->private_data;
1915         int i, err;
1916         u8 buf[3];
1917
1918         snd_iprintf(buffer, "%s jacks\n\n", mixer->chip->card->shortname);
1919         for (i = 0; i < ARRAY_SIZE(jacks); ++i) {
1920                 snd_iprintf(buffer, "%s: ", jacks[i].name);
1921                 err = snd_usb_ctl_msg(mixer->chip->dev,
1922                                       usb_rcvctrlpipe(mixer->chip->dev, 0),
1923                                       GET_MEM, USB_DIR_IN | USB_TYPE_CLASS |
1924                                       USB_RECIP_INTERFACE, 0,
1925                                       jacks[i].unitid << 8, buf, 3, 100);
1926                 if (err == 3 && buf[0] == 3)
1927                         snd_iprintf(buffer, "%02x %02x\n", buf[1], buf[2]);
1928                 else
1929                         snd_iprintf(buffer, "?\n");
1930         }
1931 }
1932
1933 int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif)
1934 {
1935         static struct snd_device_ops dev_ops = {
1936                 .dev_free = snd_usb_mixer_dev_free
1937         };
1938         struct usb_mixer_interface *mixer;
1939         int err;
1940
1941         strcpy(chip->card->mixername, "USB Mixer");
1942
1943         mixer = kzalloc(sizeof(*mixer), GFP_KERNEL);
1944         if (!mixer)
1945                 return -ENOMEM;
1946         mixer->chip = chip;
1947         mixer->ctrlif = ctrlif;
1948 #ifdef IGNORE_CTL_ERROR
1949         mixer->ignore_ctl_error = 1;
1950 #endif
1951         mixer->id_elems = kcalloc(256, sizeof(*mixer->id_elems), GFP_KERNEL);
1952         if (!mixer->id_elems) {
1953                 kfree(mixer);
1954                 return -ENOMEM;
1955         }
1956
1957         if ((err = snd_usb_mixer_controls(mixer)) < 0 ||
1958             (err = snd_usb_mixer_status_create(mixer)) < 0)
1959                 goto _error;
1960
1961         if ((err = snd_usb_soundblaster_remote_init(mixer)) < 0)
1962                 goto _error;
1963
1964         if (mixer->chip->usb_id == USB_ID(0x041e, 0x3020)) {
1965                 struct snd_info_entry *entry;
1966
1967                 if ((err = snd_audigy2nx_controls_create(mixer)) < 0)
1968                         goto _error;
1969                 if (!snd_card_proc_new(chip->card, "audigy2nx", &entry))
1970                         snd_info_set_text_ops(entry, mixer, 1024,
1971                                               snd_audigy2nx_proc_read);
1972         }
1973
1974         err = snd_device_new(chip->card, SNDRV_DEV_LOWLEVEL, mixer, &dev_ops);
1975         if (err < 0)
1976                 goto _error;
1977         list_add(&mixer->list, &chip->mixer_list);
1978         return 0;
1979
1980 _error:
1981         snd_usb_mixer_free(mixer);
1982         return err;
1983 }
1984
1985 void snd_usb_mixer_disconnect(struct list_head *p)
1986 {
1987         struct usb_mixer_interface *mixer;
1988         
1989         mixer = list_entry(p, struct usb_mixer_interface, list);
1990         if (mixer->urb)
1991                 usb_kill_urb(mixer->urb);
1992         if (mixer->rc_urb)
1993                 usb_kill_urb(mixer->rc_urb);
1994 }