blob: b703cb3cda1993402d60efc03e9e7d840cb68f72 [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
Damien Zammitd497a822014-11-12 01:09:54 +1100182static struct usbmix_name_map mbox1_map[] = {
183 { 1, "Clock" },
184 { 0 } /* terminator */
185};
186
Eldad Zack39e95152013-01-13 23:02:04 +0100187static struct usbmix_selector_map c400_selectors[] = {
188 {
189 .id = 0x80,
190 .count = 2,
191 .names = (const char*[]) {"Internal", "SPDIF"}
192 },
193 { 0 } /* terminator */
194};
195
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200196static struct usbmix_selector_map audigy2nx_selectors[] = {
197 {
198 .id = 14, /* Capture Source */
199 .count = 3,
200 .names = (const char*[]) {"Line", "Digital In", "What-U-Hear"}
201 },
202 {
203 .id = 29, /* Digital Out Source */
204 .count = 3,
205 .names = (const char*[]) {"Front", "PCM", "Digital In"}
206 },
207 {
208 .id = 31, /* Headphone Source */
209 .count = 2,
210 .names = (const char*[]) {"Front", "Side"}
211 },
212 { 0 } /* terminator */
213};
214
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100215/* Creative SoundBlaster Live! 24-bit External */
216static struct usbmix_name_map live24ext_map[] = {
217 /* 2: PCM Playback Volume */
218 { 5, "Mic Capture" }, /* FU, default PCM Capture Volume */
219 { 0 } /* terminator */
220};
221
Linus Torvalds1da177e2005-04-16 15:20:36 -0700222/* LineX FM Transmitter entry - needed to bypass controls bug */
223static struct usbmix_name_map linex_map[] = {
224 /* 1: IT pcm */
225 /* 2: OT Speaker */
226 { 3, "Master" }, /* FU: master volume - left / right / mute */
227 { 0 } /* terminator */
228};
229
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100230static struct usbmix_name_map maya44_map[] = {
231 /* 1: IT line */
232 { 2, "Line Playback" }, /* FU */
233 /* 3: IT line */
234 { 4, "Line Playback" }, /* FU */
235 /* 5: IT pcm playback */
236 /* 6: MU */
237 { 7, "Master Playback" }, /* FU */
238 /* 8: OT speaker */
239 /* 9: IT line */
240 { 10, "Line Capture" }, /* FU */
241 /* 11: MU */
242 /* 12: OT pcm capture */
243 { }
244};
245
Linus Torvalds1da177e2005-04-16 15:20:36 -0700246/* Section "justlink_map" below added by James Courtier-Dutton <James@superbug.demon.co.uk>
247 * sourced from Maplin Electronics (http://www.maplin.co.uk), part number A56AK
248 * Part has 2 connectors that act as a single output. (TOSLINK Optical for digital out, and 3.5mm Jack for Analogue out.)
249 * The USB Mixer publishes a Microphone and extra Volume controls for it, but none exist on the device,
250 * so this map removes all unwanted sliders from alsamixer
251 */
252
253static struct usbmix_name_map justlink_map[] = {
254 /* 1: IT pcm playback */
255 /* 2: Not present */
256 { 3, NULL}, /* IT mic (No mic input on device) */
257 /* 4: Not present */
258 /* 5: OT speacker */
259 /* 6: OT pcm capture */
260 { 7, "Master Playback" }, /* Mute/volume for speaker */
261 { 8, NULL }, /* Capture Switch (No capture inputs on device) */
262 { 9, NULL }, /* Capture Mute/volume (No capture inputs on device */
263 /* 0xa: Not present */
264 /* 0xb: MU (w/o controls) */
265 { 0xc, NULL }, /* Mic feedback Mute/volume (No capture inputs on device) */
266 { 0 } /* terminator */
267};
268
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200269/* TerraTec Aureon 5.1 MkII USB */
270static struct usbmix_name_map aureon_51_2_map[] = {
271 /* 1: IT USB */
272 /* 2: IT Mic */
273 /* 3: IT Line */
274 /* 4: IT SPDIF */
275 /* 5: OT SPDIF */
276 /* 6: OT Speaker */
277 /* 7: OT USB */
278 { 8, "Capture Source" }, /* SU */
279 { 9, "Master Playback" }, /* FU */
280 { 10, "Mic Capture" }, /* FU */
281 { 11, "Line Capture" }, /* FU */
282 { 12, "IEC958 In Capture" }, /* FU */
283 { 13, "Mic Playback" }, /* FU */
284 { 14, "Line Playback" }, /* FU */
285 /* 15: MU */
286 {} /* terminator */
287};
288
Andreas Bergmeier86932902009-01-18 18:48:03 +0100289static struct usbmix_name_map scratch_live_map[] = {
290 /* 1: IT Line 1 (USB streaming) */
291 /* 2: OT Line 1 (Speaker) */
292 /* 3: IT Line 1 (Line connector) */
293 { 4, "Line 1 In" }, /* FU */
294 /* 5: OT Line 1 (USB streaming) */
295 /* 6: IT Line 2 (USB streaming) */
296 /* 7: OT Line 2 (Speaker) */
297 /* 8: IT Line 2 (Line connector) */
298 { 9, "Line 2 In" }, /* FU */
299 /* 10: OT Line 2 (USB streaming) */
300 /* 11: IT Mic (Line connector) */
301 /* 12: OT Mic (USB streaming) */
302 { 0 } /* terminator */
303};
304
Mark Hills7536c302012-04-14 17:19:24 +0100305static struct usbmix_name_map ebox44_map[] = {
306 { 4, NULL }, /* FU */
307 { 6, NULL }, /* MU */
308 { 7, NULL }, /* FU */
309 { 10, NULL }, /* FU */
310 { 11, NULL }, /* MU */
311 { 0 }
312};
313
Alexey Fishere0feefc2009-12-01 13:40:53 +0100314/* "Gamesurround Muse Pocket LT" looks same like "Sound Blaster MP3+"
315 * most importand difference is SU[8], it should be set to "Capture Source"
316 * to make alsamixer and PA working properly.
317 * FIXME: or mp3plus_map should use "Capture Source" too,
318 * so this maps can be merget
319 */
320static struct usbmix_name_map hercules_usb51_map[] = {
321 { 8, "Capture Source" }, /* SU, default "PCM Capture Source" */
322 { 9, "Master Playback" }, /* FU, default "Speaker Playback" */
323 { 10, "Mic Boost", 7 }, /* FU, default "Auto Gain Input" */
324 { 11, "Line Capture" }, /* FU, default "PCM Capture" */
325 { 13, "Mic Bypass Playback" }, /* FU, default "Mic Playback" */
326 { 14, "Line Bypass Playback" }, /* FU, default "Line Playback" */
327 { 0 } /* terminator */
328};
329
Takashi Iwai19570d72013-12-19 14:32:53 +0100330/* Plantronics Gamecom 780 has a broken volume control, better to disable it */
331static struct usbmix_name_map gamecom780_map[] = {
332 { 9, NULL }, /* FU, speaker out */
333 {}
334};
335
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100336/* some (all?) SCMS USB3318 devices are affected by a firmware lock up
337 * when anything attempts to access FU 10 (control)
338 */
339static const struct usbmix_name_map scms_usb3318_map[] = {
340 { 10, NULL },
Clemens Ladisch624aef42014-02-16 17:11:10 +0100341 { 0 }
342};
343
Linus Torvalds1da177e2005-04-16 15:20:36 -0700344/*
345 * Control map entries
346 */
347
348static struct usbmix_ctl_map usbmix_ctl_maps[] = {
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200349 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200350 .id = USB_ID(0x041e, 0x3000),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200351 .map = extigy_map,
352 .ignore_ctl_error = 1,
353 },
354 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200355 .id = USB_ID(0x041e, 0x3010),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200356 .map = mp3plus_map,
357 },
358 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200359 .id = USB_ID(0x041e, 0x3020),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200360 .map = audigy2nx_map,
361 .selector_map = audigy2nx_selectors,
362 },
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100363 {
364 .id = USB_ID(0x041e, 0x3040),
365 .map = live24ext_map,
366 },
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200367 {
Andrea Borgia31959542009-01-07 22:58:50 +0100368 .id = USB_ID(0x041e, 0x3048),
369 .map = audigy2nx_map,
370 .selector_map = audigy2nx_selectors,
371 },
Oleksij Rempelb64a1ba2012-06-19 22:21:19 +0200372 { /* Logitech, Inc. QuickCam Pro for Notebooks */
373 .id = USB_ID(0x046d, 0x0991),
374 .ignore_ctl_error = 1,
375 },
Oleksij Rempel05b9afd52012-06-19 22:21:18 +0200376 { /* Logitech, Inc. QuickCam E 3500 */
377 .id = USB_ID(0x046d, 0x09a4),
378 .ignore_ctl_error = 1,
379 },
Takashi Iwai19570d72013-12-19 14:32:53 +0100380 { /* Plantronics GameCom 780 */
381 .id = USB_ID(0x047f, 0xc010),
382 .map = gamecom780_map,
383 },
Andrea Borgia31959542009-01-07 22:58:50 +0100384 {
Clemens Ladisch9c9565f2005-10-05 13:02:38 +0200385 /* Hercules DJ Console (Windows Edition) */
386 .id = USB_ID(0x06f8, 0xb000),
387 .ignore_ctl_error = 1,
388 },
389 {
390 /* Hercules DJ Console (Macintosh Edition) */
Clemens Ladisch460dc982005-09-16 16:56:01 +0200391 .id = USB_ID(0x06f8, 0xd002),
392 .ignore_ctl_error = 1,
393 },
394 {
Alexey Fishere0feefc2009-12-01 13:40:53 +0100395 /* Hercules Gamesurround Muse Pocket LT
396 * (USB 5.1 Channel Audio Adapter)
397 */
398 .id = USB_ID(0x06f8, 0xc000),
399 .map = hercules_usb51_map,
400 },
401 {
Eldad Zack39e95152013-01-13 23:02:04 +0100402 .id = USB_ID(0x0763, 0x2030),
403 .selector_map = c400_selectors,
404 },
405 {
Matt Gruskine9a25e02013-02-09 12:56:35 -0500406 .id = USB_ID(0x0763, 0x2031),
407 .selector_map = c400_selectors,
408 },
409 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200410 .id = USB_ID(0x08bb, 0x2702),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200411 .map = linex_map,
412 .ignore_ctl_error = 1,
413 },
414 {
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100415 .id = USB_ID(0x0a92, 0x0091),
416 .map = maya44_map,
417 },
418 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200419 .id = USB_ID(0x0c45, 0x1158),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200420 .map = justlink_map,
421 },
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200422 {
423 .id = USB_ID(0x0ccd, 0x0028),
424 .map = aureon_51_2_map,
425 },
Andreas Bergmeier86932902009-01-18 18:48:03 +0100426 {
Damien Zammitd497a822014-11-12 01:09:54 +1100427 .id = USB_ID(0x0dba, 0x1000),
428 .map = mbox1_map,
429 },
430 {
Andreas Bergmeier86932902009-01-18 18:48:03 +0100431 .id = USB_ID(0x13e5, 0x0001),
432 .map = scratch_live_map,
433 .ignore_ctl_error = 1,
434 },
Mark Hills7536c302012-04-14 17:19:24 +0100435 {
436 .id = USB_ID(0x200c, 0x1018),
437 .map = ebox44_map,
438 },
Clemens Ladisch624aef42014-02-16 17:11:10 +0100439 {
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100440 /* KEF X300A */
Clemens Ladisch624aef42014-02-16 17:11:10 +0100441 .id = USB_ID(0x27ac, 0x1000),
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100442 .map = scms_usb3318_map,
443 },
444 {
445 /* Arcam rPAC */
446 .id = USB_ID(0x25c4, 0x0003),
447 .map = scms_usb3318_map,
Clemens Ladisch624aef42014-02-16 17:11:10 +0100448 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700449 { 0 } /* terminator */
450};
451