blob: 0e2ed3d05c451c32a53032b735bc95c7868df143 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * Additional mixer mapping
3 *
4 * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 *
20 */
21
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +010022struct usbmix_dB_map {
23 u32 min;
24 u32 max;
25};
Linus Torvalds1da177e2005-04-16 15:20:36 -070026
27struct usbmix_name_map {
28 int id;
29 const char *name;
30 int control;
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +010031 struct usbmix_dB_map *dB;
Linus Torvalds1da177e2005-04-16 15:20:36 -070032};
33
Clemens Ladisch8e062ec2005-04-22 15:49:52 +020034struct usbmix_selector_map {
35 int id;
36 int count;
37 const char **names;
38};
39
Linus Torvalds1da177e2005-04-16 15:20:36 -070040struct usbmix_ctl_map {
Clemens Ladisch27d10f52005-05-02 08:51:26 +020041 u32 id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070042 const struct usbmix_name_map *map;
Clemens Ladisch8e062ec2005-04-22 15:49:52 +020043 const struct usbmix_selector_map *selector_map;
Linus Torvalds1da177e2005-04-16 15:20:36 -070044 int ignore_ctl_error;
45};
46
47/*
48 * USB control mappers for SB Exitigy
49 */
50
51/*
52 * Topology of SB Extigy (see on the wide screen :)
53
54USB_IN[1] --->FU[2]------------------------------+->MU[16]-->PU[17]-+->FU[18]--+->EU[27]--+->EU[21]-->FU[22]--+->FU[23] > Dig_OUT[24]
55 ^ | | | |
56USB_IN[3] -+->SU[5]-->FU[6]--+->MU[14] ->PU[15]->+ | | | +->FU[25] > Dig_OUT[26]
57 ^ ^ | | | |
58Dig_IN[4] -+ | | | | +->FU[28]---------------------> Spk_OUT[19]
59 | | | |
60Lin-IN[7] -+-->FU[8]---------+ | | +----------------------------------------> Hph_OUT[20]
61 | | |
62Mic-IN[9] --+->FU[10]----------------------------+ |
63 || |
64 || +----------------------------------------------------+
65 VV V
66 ++--+->SU[11]-->FU[12] --------------------------------------------------------------------------------------> USB_OUT[13]
67*/
68
69static struct usbmix_name_map extigy_map[] = {
70 /* 1: IT pcm */
71 { 2, "PCM Playback" }, /* FU */
72 /* 3: IT pcm */
73 /* 4: IT digital in */
74 { 5, NULL }, /* DISABLED: this seems to be bogus on some firmware */
75 { 6, "Digital In" }, /* FU */
76 /* 7: IT line */
77 { 8, "Line Playback" }, /* FU */
78 /* 9: IT mic */
79 { 10, "Mic Playback" }, /* FU */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +010080 { 11, "Capture Source" }, /* SU */
Linus Torvalds1da177e2005-04-16 15:20:36 -070081 { 12, "Capture" }, /* FU */
82 /* 13: OT pcm capture */
83 /* 14: MU (w/o controls) */
84 /* 15: PU (3D enh) */
85 /* 16: MU (w/o controls) */
86 { 17, NULL, 1 }, /* DISABLED: PU-switch (any effect?) */
87 { 17, "Channel Routing", 2 }, /* PU: mode select */
Daniel Mack65f25da2010-05-31 13:35:41 +020088 { 18, "Tone Control - Bass", UAC_FU_BASS }, /* FU */
89 { 18, "Tone Control - Treble", UAC_FU_TREBLE }, /* FU */
Linus Torvalds1da177e2005-04-16 15:20:36 -070090 { 18, "Master Playback" }, /* FU; others */
91 /* 19: OT speaker */
92 /* 20: OT headphone */
93 { 21, NULL }, /* DISABLED: EU (for what?) */
94 { 22, "Digital Out Playback" }, /* FU */
95 { 23, "Digital Out1 Playback" }, /* FU */ /* FIXME: corresponds to 24 */
96 /* 24: OT digital out */
97 { 25, "IEC958 Optical Playback" }, /* FU */
98 { 26, "IEC958 Optical Playback" }, /* OT */
99 { 27, NULL }, /* DISABLED: EU (for what?) */
100 /* 28: FU speaker (mute) */
101 { 29, NULL }, /* Digital Input Playback Source? */
102 { 0 } /* terminator */
103};
104
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200105/* Sound Blaster MP3+ controls mapping
106 * The default mixer channels have totally misleading names,
107 * e.g. no Master and fake PCM volume
108 * Pavel Mihaylov <bin@bash.info>
109 */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100110static struct usbmix_dB_map mp3plus_dB_1 = {-4781, 0}; /* just guess */
111static struct usbmix_dB_map mp3plus_dB_2 = {-1781, 618}; /* just guess */
112
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200113static struct usbmix_name_map mp3plus_map[] = {
114 /* 1: IT pcm */
115 /* 2: IT mic */
116 /* 3: IT line */
117 /* 4: IT digital in */
118 /* 5: OT digital out */
119 /* 6: OT speaker */
120 /* 7: OT pcm capture */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100121 { 8, "Capture Source" }, /* FU, default PCM Capture Source */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200122 /* (Mic, Input 1 = Line input, Input 2 = Optical input) */
123 { 9, "Master Playback" }, /* FU, default Speaker 1 */
124 /* { 10, "Mic Capture", 1 }, */ /* FU, Mic Capture */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100125 { 10, /* "Mic Capture", */ NULL, 2, .dB = &mp3plus_dB_2 },
126 /* FU, Mic Capture */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200127 { 10, "Mic Boost", 7 }, /* FU, default Auto Gain Input */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100128 { 11, "Line Capture", .dB = &mp3plus_dB_2 },
129 /* FU, default PCM Capture */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200130 { 12, "Digital In Playback" }, /* FU, default PCM 1 */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100131 { 13, /* "Mic Playback", */ .dB = &mp3plus_dB_1 },
132 /* FU, default Mic Playback */
133 { 14, "Line Playback", .dB = &mp3plus_dB_1 }, /* FU, default Speaker */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200134 /* 15: MU */
135 { 0 } /* terminator */
136};
137
Clemens Ladisch863ad942005-04-22 08:52:03 +0200138/* Topology of SB Audigy 2 NX
139
140 +----------------------------->EU[27]--+
141 | v
142 | +----------------------------------->SU[29]---->FU[22]-->Dig_OUT[24]
143 | | ^
144USB_IN[1]-+------------+ +->EU[17]->+->FU[11]-+
145 | v | v |
146Dig_IN[4]---+->FU[6]-->MU[16]->FU[18]-+->EU[21]->SU[31]----->FU[30]->Hph_OUT[20]
147 | ^ | |
148Lin_IN[7]-+--->FU[8]---+ +->EU[23]->FU[28]------------->Spk_OUT[19]
149 | | v
150 +--->FU[12]------------------------------------->SU[14]--->USB_OUT[15]
151 | ^
152 +->FU[13]--------------------------------------+
153*/
154static struct usbmix_name_map audigy2nx_map[] = {
155 /* 1: IT pcm playback */
156 /* 4: IT digital in */
157 { 6, "Digital In Playback" }, /* FU */
158 /* 7: IT line in */
159 { 8, "Line Playback" }, /* FU */
160 { 11, "What-U-Hear Capture" }, /* FU */
161 { 12, "Line Capture" }, /* FU */
162 { 13, "Digital In Capture" }, /* FU */
163 { 14, "Capture Source" }, /* SU */
164 /* 15: OT pcm capture */
165 /* 16: MU w/o controls */
166 { 17, NULL }, /* DISABLED: EU (for what?) */
167 { 18, "Master Playback" }, /* FU */
168 /* 19: OT speaker */
169 /* 20: OT headphone */
170 { 21, NULL }, /* DISABLED: EU (for what?) */
171 { 22, "Digital Out Playback" }, /* FU */
172 { 23, NULL }, /* DISABLED: EU (for what?) */
173 /* 24: OT digital out */
174 { 27, NULL }, /* DISABLED: EU (for what?) */
175 { 28, "Speaker Playback" }, /* FU */
176 { 29, "Digital Out Source" }, /* SU */
177 { 30, "Headphone Playback" }, /* FU */
178 { 31, "Headphone Source" }, /* SU */
179 { 0 } /* terminator */
180};
181
Eldad Zack39e95152013-01-13 23:02:04 +0100182static struct usbmix_selector_map c400_selectors[] = {
183 {
184 .id = 0x80,
185 .count = 2,
186 .names = (const char*[]) {"Internal", "SPDIF"}
187 },
188 { 0 } /* terminator */
189};
190
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200191static struct usbmix_selector_map audigy2nx_selectors[] = {
192 {
193 .id = 14, /* Capture Source */
194 .count = 3,
195 .names = (const char*[]) {"Line", "Digital In", "What-U-Hear"}
196 },
197 {
198 .id = 29, /* Digital Out Source */
199 .count = 3,
200 .names = (const char*[]) {"Front", "PCM", "Digital In"}
201 },
202 {
203 .id = 31, /* Headphone Source */
204 .count = 2,
205 .names = (const char*[]) {"Front", "Side"}
206 },
207 { 0 } /* terminator */
208};
209
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100210/* Creative SoundBlaster Live! 24-bit External */
211static struct usbmix_name_map live24ext_map[] = {
212 /* 2: PCM Playback Volume */
213 { 5, "Mic Capture" }, /* FU, default PCM Capture Volume */
214 { 0 } /* terminator */
215};
216
Linus Torvalds1da177e2005-04-16 15:20:36 -0700217/* LineX FM Transmitter entry - needed to bypass controls bug */
218static struct usbmix_name_map linex_map[] = {
219 /* 1: IT pcm */
220 /* 2: OT Speaker */
221 { 3, "Master" }, /* FU: master volume - left / right / mute */
222 { 0 } /* terminator */
223};
224
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100225static struct usbmix_name_map maya44_map[] = {
226 /* 1: IT line */
227 { 2, "Line Playback" }, /* FU */
228 /* 3: IT line */
229 { 4, "Line Playback" }, /* FU */
230 /* 5: IT pcm playback */
231 /* 6: MU */
232 { 7, "Master Playback" }, /* FU */
233 /* 8: OT speaker */
234 /* 9: IT line */
235 { 10, "Line Capture" }, /* FU */
236 /* 11: MU */
237 /* 12: OT pcm capture */
238 { }
239};
240
Linus Torvalds1da177e2005-04-16 15:20:36 -0700241/* Section "justlink_map" below added by James Courtier-Dutton <James@superbug.demon.co.uk>
242 * sourced from Maplin Electronics (http://www.maplin.co.uk), part number A56AK
243 * Part has 2 connectors that act as a single output. (TOSLINK Optical for digital out, and 3.5mm Jack for Analogue out.)
244 * The USB Mixer publishes a Microphone and extra Volume controls for it, but none exist on the device,
245 * so this map removes all unwanted sliders from alsamixer
246 */
247
248static struct usbmix_name_map justlink_map[] = {
249 /* 1: IT pcm playback */
250 /* 2: Not present */
251 { 3, NULL}, /* IT mic (No mic input on device) */
252 /* 4: Not present */
253 /* 5: OT speacker */
254 /* 6: OT pcm capture */
255 { 7, "Master Playback" }, /* Mute/volume for speaker */
256 { 8, NULL }, /* Capture Switch (No capture inputs on device) */
257 { 9, NULL }, /* Capture Mute/volume (No capture inputs on device */
258 /* 0xa: Not present */
259 /* 0xb: MU (w/o controls) */
260 { 0xc, NULL }, /* Mic feedback Mute/volume (No capture inputs on device) */
261 { 0 } /* terminator */
262};
263
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200264/* TerraTec Aureon 5.1 MkII USB */
265static struct usbmix_name_map aureon_51_2_map[] = {
266 /* 1: IT USB */
267 /* 2: IT Mic */
268 /* 3: IT Line */
269 /* 4: IT SPDIF */
270 /* 5: OT SPDIF */
271 /* 6: OT Speaker */
272 /* 7: OT USB */
273 { 8, "Capture Source" }, /* SU */
274 { 9, "Master Playback" }, /* FU */
275 { 10, "Mic Capture" }, /* FU */
276 { 11, "Line Capture" }, /* FU */
277 { 12, "IEC958 In Capture" }, /* FU */
278 { 13, "Mic Playback" }, /* FU */
279 { 14, "Line Playback" }, /* FU */
280 /* 15: MU */
281 {} /* terminator */
282};
283
Andreas Bergmeier86932902009-01-18 18:48:03 +0100284static struct usbmix_name_map scratch_live_map[] = {
285 /* 1: IT Line 1 (USB streaming) */
286 /* 2: OT Line 1 (Speaker) */
287 /* 3: IT Line 1 (Line connector) */
288 { 4, "Line 1 In" }, /* FU */
289 /* 5: OT Line 1 (USB streaming) */
290 /* 6: IT Line 2 (USB streaming) */
291 /* 7: OT Line 2 (Speaker) */
292 /* 8: IT Line 2 (Line connector) */
293 { 9, "Line 2 In" }, /* FU */
294 /* 10: OT Line 2 (USB streaming) */
295 /* 11: IT Mic (Line connector) */
296 /* 12: OT Mic (USB streaming) */
297 { 0 } /* terminator */
298};
299
Mark Hills7536c302012-04-14 17:19:24 +0100300static struct usbmix_name_map ebox44_map[] = {
301 { 4, NULL }, /* FU */
302 { 6, NULL }, /* MU */
303 { 7, NULL }, /* FU */
304 { 10, NULL }, /* FU */
305 { 11, NULL }, /* MU */
306 { 0 }
307};
308
Alexey Fishere0feefc2009-12-01 13:40:53 +0100309/* "Gamesurround Muse Pocket LT" looks same like "Sound Blaster MP3+"
310 * most importand difference is SU[8], it should be set to "Capture Source"
311 * to make alsamixer and PA working properly.
312 * FIXME: or mp3plus_map should use "Capture Source" too,
313 * so this maps can be merget
314 */
315static struct usbmix_name_map hercules_usb51_map[] = {
316 { 8, "Capture Source" }, /* SU, default "PCM Capture Source" */
317 { 9, "Master Playback" }, /* FU, default "Speaker Playback" */
318 { 10, "Mic Boost", 7 }, /* FU, default "Auto Gain Input" */
319 { 11, "Line Capture" }, /* FU, default "PCM Capture" */
320 { 13, "Mic Bypass Playback" }, /* FU, default "Mic Playback" */
321 { 14, "Line Bypass Playback" }, /* FU, default "Line Playback" */
322 { 0 } /* terminator */
323};
324
Linus Torvalds1da177e2005-04-16 15:20:36 -0700325/*
326 * Control map entries
327 */
328
329static struct usbmix_ctl_map usbmix_ctl_maps[] = {
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200330 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200331 .id = USB_ID(0x041e, 0x3000),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200332 .map = extigy_map,
333 .ignore_ctl_error = 1,
334 },
335 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200336 .id = USB_ID(0x041e, 0x3010),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200337 .map = mp3plus_map,
338 },
339 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200340 .id = USB_ID(0x041e, 0x3020),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200341 .map = audigy2nx_map,
342 .selector_map = audigy2nx_selectors,
343 },
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100344 {
345 .id = USB_ID(0x041e, 0x3040),
346 .map = live24ext_map,
347 },
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200348 {
Andrea Borgia31959542009-01-07 22:58:50 +0100349 .id = USB_ID(0x041e, 0x3048),
350 .map = audigy2nx_map,
351 .selector_map = audigy2nx_selectors,
352 },
Oleksij Rempelb64a1ba2012-06-19 22:21:19 +0200353 { /* Logitech, Inc. QuickCam Pro for Notebooks */
354 .id = USB_ID(0x046d, 0x0991),
355 .ignore_ctl_error = 1,
356 },
Oleksij Rempel05b9afd52012-06-19 22:21:18 +0200357 { /* Logitech, Inc. QuickCam E 3500 */
358 .id = USB_ID(0x046d, 0x09a4),
359 .ignore_ctl_error = 1,
360 },
Andrea Borgia31959542009-01-07 22:58:50 +0100361 {
Clemens Ladisch9c9565f2005-10-05 13:02:38 +0200362 /* Hercules DJ Console (Windows Edition) */
363 .id = USB_ID(0x06f8, 0xb000),
364 .ignore_ctl_error = 1,
365 },
366 {
367 /* Hercules DJ Console (Macintosh Edition) */
Clemens Ladisch460dc982005-09-16 16:56:01 +0200368 .id = USB_ID(0x06f8, 0xd002),
369 .ignore_ctl_error = 1,
370 },
371 {
Alexey Fishere0feefc2009-12-01 13:40:53 +0100372 /* Hercules Gamesurround Muse Pocket LT
373 * (USB 5.1 Channel Audio Adapter)
374 */
375 .id = USB_ID(0x06f8, 0xc000),
376 .map = hercules_usb51_map,
377 },
378 {
Eldad Zack39e95152013-01-13 23:02:04 +0100379 .id = USB_ID(0x0763, 0x2030),
380 .selector_map = c400_selectors,
381 },
382 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200383 .id = USB_ID(0x08bb, 0x2702),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200384 .map = linex_map,
385 .ignore_ctl_error = 1,
386 },
387 {
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100388 .id = USB_ID(0x0a92, 0x0091),
389 .map = maya44_map,
390 },
391 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200392 .id = USB_ID(0x0c45, 0x1158),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200393 .map = justlink_map,
394 },
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200395 {
396 .id = USB_ID(0x0ccd, 0x0028),
397 .map = aureon_51_2_map,
398 },
Andreas Bergmeier86932902009-01-18 18:48:03 +0100399 {
400 .id = USB_ID(0x13e5, 0x0001),
401 .map = scratch_live_map,
402 .ignore_ctl_error = 1,
403 },
Mark Hills7536c302012-04-14 17:19:24 +0100404 {
405 .id = USB_ID(0x200c, 0x1018),
406 .map = ebox44_map,
407 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700408 { 0 } /* terminator */
409};
410