blob: 9038b2e7df732d453993a180071a98ea3b2ff79f [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 */
Amitoj Kaur Chawlae5c53272016-06-17 20:12:15 +0530110static struct usbmix_dB_map mp3plus_dB_1 = {.min = -4781, .max = 0};
111 /* just guess */
112static struct usbmix_dB_map mp3plus_dB_2 = {.min = -1781, .max = 618};
113 /* just guess */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100114
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200115static struct usbmix_name_map mp3plus_map[] = {
116 /* 1: IT pcm */
117 /* 2: IT mic */
118 /* 3: IT line */
119 /* 4: IT digital in */
120 /* 5: OT digital out */
121 /* 6: OT speaker */
122 /* 7: OT pcm capture */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100123 { 8, "Capture Source" }, /* FU, default PCM Capture Source */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200124 /* (Mic, Input 1 = Line input, Input 2 = Optical input) */
125 { 9, "Master Playback" }, /* FU, default Speaker 1 */
126 /* { 10, "Mic Capture", 1 }, */ /* FU, Mic Capture */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100127 { 10, /* "Mic Capture", */ NULL, 2, .dB = &mp3plus_dB_2 },
128 /* FU, Mic Capture */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200129 { 10, "Mic Boost", 7 }, /* FU, default Auto Gain Input */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100130 { 11, "Line Capture", .dB = &mp3plus_dB_2 },
131 /* FU, default PCM Capture */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200132 { 12, "Digital In Playback" }, /* FU, default PCM 1 */
Jaroslav Kyselac3a3e042010-02-11 17:50:44 +0100133 { 13, /* "Mic Playback", */ .dB = &mp3plus_dB_1 },
134 /* FU, default Mic Playback */
135 { 14, "Line Playback", .dB = &mp3plus_dB_1 }, /* FU, default Speaker */
Takashi Iwai54ab87e2005-04-01 13:14:14 +0200136 /* 15: MU */
137 { 0 } /* terminator */
138};
139
Clemens Ladisch863ad942005-04-22 08:52:03 +0200140/* Topology of SB Audigy 2 NX
141
142 +----------------------------->EU[27]--+
143 | v
144 | +----------------------------------->SU[29]---->FU[22]-->Dig_OUT[24]
145 | | ^
146USB_IN[1]-+------------+ +->EU[17]->+->FU[11]-+
147 | v | v |
148Dig_IN[4]---+->FU[6]-->MU[16]->FU[18]-+->EU[21]->SU[31]----->FU[30]->Hph_OUT[20]
149 | ^ | |
150Lin_IN[7]-+--->FU[8]---+ +->EU[23]->FU[28]------------->Spk_OUT[19]
151 | | v
152 +--->FU[12]------------------------------------->SU[14]--->USB_OUT[15]
153 | ^
154 +->FU[13]--------------------------------------+
155*/
156static struct usbmix_name_map audigy2nx_map[] = {
157 /* 1: IT pcm playback */
158 /* 4: IT digital in */
159 { 6, "Digital In Playback" }, /* FU */
160 /* 7: IT line in */
161 { 8, "Line Playback" }, /* FU */
162 { 11, "What-U-Hear Capture" }, /* FU */
163 { 12, "Line Capture" }, /* FU */
164 { 13, "Digital In Capture" }, /* FU */
165 { 14, "Capture Source" }, /* SU */
166 /* 15: OT pcm capture */
167 /* 16: MU w/o controls */
168 { 17, NULL }, /* DISABLED: EU (for what?) */
169 { 18, "Master Playback" }, /* FU */
170 /* 19: OT speaker */
171 /* 20: OT headphone */
172 { 21, NULL }, /* DISABLED: EU (for what?) */
173 { 22, "Digital Out Playback" }, /* FU */
174 { 23, NULL }, /* DISABLED: EU (for what?) */
175 /* 24: OT digital out */
176 { 27, NULL }, /* DISABLED: EU (for what?) */
177 { 28, "Speaker Playback" }, /* FU */
178 { 29, "Digital Out Source" }, /* SU */
179 { 30, "Headphone Playback" }, /* FU */
180 { 31, "Headphone Source" }, /* SU */
181 { 0 } /* terminator */
182};
183
Damien Zammitd497a822014-11-12 01:09:54 +1100184static struct usbmix_name_map mbox1_map[] = {
185 { 1, "Clock" },
186 { 0 } /* terminator */
187};
188
Eldad Zack39e95152013-01-13 23:02:04 +0100189static struct usbmix_selector_map c400_selectors[] = {
190 {
191 .id = 0x80,
192 .count = 2,
193 .names = (const char*[]) {"Internal", "SPDIF"}
194 },
195 { 0 } /* terminator */
196};
197
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200198static struct usbmix_selector_map audigy2nx_selectors[] = {
199 {
200 .id = 14, /* Capture Source */
201 .count = 3,
202 .names = (const char*[]) {"Line", "Digital In", "What-U-Hear"}
203 },
204 {
205 .id = 29, /* Digital Out Source */
206 .count = 3,
207 .names = (const char*[]) {"Front", "PCM", "Digital In"}
208 },
209 {
210 .id = 31, /* Headphone Source */
211 .count = 2,
212 .names = (const char*[]) {"Front", "Side"}
213 },
214 { 0 } /* terminator */
215};
216
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100217/* Creative SoundBlaster Live! 24-bit External */
218static struct usbmix_name_map live24ext_map[] = {
219 /* 2: PCM Playback Volume */
220 { 5, "Mic Capture" }, /* FU, default PCM Capture Volume */
221 { 0 } /* terminator */
222};
223
Linus Torvalds1da177e2005-04-16 15:20:36 -0700224/* LineX FM Transmitter entry - needed to bypass controls bug */
225static struct usbmix_name_map linex_map[] = {
226 /* 1: IT pcm */
227 /* 2: OT Speaker */
228 { 3, "Master" }, /* FU: master volume - left / right / mute */
229 { 0 } /* terminator */
230};
231
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100232static struct usbmix_name_map maya44_map[] = {
233 /* 1: IT line */
234 { 2, "Line Playback" }, /* FU */
235 /* 3: IT line */
236 { 4, "Line Playback" }, /* FU */
237 /* 5: IT pcm playback */
238 /* 6: MU */
239 { 7, "Master Playback" }, /* FU */
240 /* 8: OT speaker */
241 /* 9: IT line */
242 { 10, "Line Capture" }, /* FU */
243 /* 11: MU */
244 /* 12: OT pcm capture */
245 { }
246};
247
Linus Torvalds1da177e2005-04-16 15:20:36 -0700248/* Section "justlink_map" below added by James Courtier-Dutton <James@superbug.demon.co.uk>
249 * sourced from Maplin Electronics (http://www.maplin.co.uk), part number A56AK
250 * Part has 2 connectors that act as a single output. (TOSLINK Optical for digital out, and 3.5mm Jack for Analogue out.)
251 * The USB Mixer publishes a Microphone and extra Volume controls for it, but none exist on the device,
252 * so this map removes all unwanted sliders from alsamixer
253 */
254
255static struct usbmix_name_map justlink_map[] = {
256 /* 1: IT pcm playback */
257 /* 2: Not present */
258 { 3, NULL}, /* IT mic (No mic input on device) */
259 /* 4: Not present */
260 /* 5: OT speacker */
261 /* 6: OT pcm capture */
262 { 7, "Master Playback" }, /* Mute/volume for speaker */
263 { 8, NULL }, /* Capture Switch (No capture inputs on device) */
264 { 9, NULL }, /* Capture Mute/volume (No capture inputs on device */
265 /* 0xa: Not present */
266 /* 0xb: MU (w/o controls) */
267 { 0xc, NULL }, /* Mic feedback Mute/volume (No capture inputs on device) */
268 { 0 } /* terminator */
269};
270
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200271/* TerraTec Aureon 5.1 MkII USB */
272static struct usbmix_name_map aureon_51_2_map[] = {
273 /* 1: IT USB */
274 /* 2: IT Mic */
275 /* 3: IT Line */
276 /* 4: IT SPDIF */
277 /* 5: OT SPDIF */
278 /* 6: OT Speaker */
279 /* 7: OT USB */
280 { 8, "Capture Source" }, /* SU */
281 { 9, "Master Playback" }, /* FU */
282 { 10, "Mic Capture" }, /* FU */
283 { 11, "Line Capture" }, /* FU */
284 { 12, "IEC958 In Capture" }, /* FU */
285 { 13, "Mic Playback" }, /* FU */
286 { 14, "Line Playback" }, /* FU */
287 /* 15: MU */
288 {} /* terminator */
289};
290
Andreas Bergmeier86932902009-01-18 18:48:03 +0100291static struct usbmix_name_map scratch_live_map[] = {
292 /* 1: IT Line 1 (USB streaming) */
293 /* 2: OT Line 1 (Speaker) */
294 /* 3: IT Line 1 (Line connector) */
295 { 4, "Line 1 In" }, /* FU */
296 /* 5: OT Line 1 (USB streaming) */
297 /* 6: IT Line 2 (USB streaming) */
298 /* 7: OT Line 2 (Speaker) */
299 /* 8: IT Line 2 (Line connector) */
300 { 9, "Line 2 In" }, /* FU */
301 /* 10: OT Line 2 (USB streaming) */
302 /* 11: IT Mic (Line connector) */
303 /* 12: OT Mic (USB streaming) */
304 { 0 } /* terminator */
305};
306
Mark Hills7536c302012-04-14 17:19:24 +0100307static struct usbmix_name_map ebox44_map[] = {
308 { 4, NULL }, /* FU */
309 { 6, NULL }, /* MU */
310 { 7, NULL }, /* FU */
311 { 10, NULL }, /* FU */
312 { 11, NULL }, /* MU */
313 { 0 }
314};
315
Alexey Fishere0feefc2009-12-01 13:40:53 +0100316/* "Gamesurround Muse Pocket LT" looks same like "Sound Blaster MP3+"
317 * most importand difference is SU[8], it should be set to "Capture Source"
318 * to make alsamixer and PA working properly.
319 * FIXME: or mp3plus_map should use "Capture Source" too,
320 * so this maps can be merget
321 */
322static struct usbmix_name_map hercules_usb51_map[] = {
323 { 8, "Capture Source" }, /* SU, default "PCM Capture Source" */
324 { 9, "Master Playback" }, /* FU, default "Speaker Playback" */
325 { 10, "Mic Boost", 7 }, /* FU, default "Auto Gain Input" */
326 { 11, "Line Capture" }, /* FU, default "PCM Capture" */
327 { 13, "Mic Bypass Playback" }, /* FU, default "Mic Playback" */
328 { 14, "Line Bypass Playback" }, /* FU, default "Line Playback" */
329 { 0 } /* terminator */
330};
331
Takashi Iwai19570d72013-12-19 14:32:53 +0100332/* Plantronics Gamecom 780 has a broken volume control, better to disable it */
333static struct usbmix_name_map gamecom780_map[] = {
334 { 9, NULL }, /* FU, speaker out */
335 {}
336};
337
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100338/* some (all?) SCMS USB3318 devices are affected by a firmware lock up
339 * when anything attempts to access FU 10 (control)
340 */
341static const struct usbmix_name_map scms_usb3318_map[] = {
342 { 10, NULL },
Clemens Ladisch624aef42014-02-16 17:11:10 +0100343 { 0 }
344};
345
Yao-Wen Mao2d1cb7f2015-07-29 15:13:54 +0800346/* Bose companion 5, the dB conversion factor is 16 instead of 256 */
347static struct usbmix_dB_map bose_companion5_dB = {-5006, -6};
348static struct usbmix_name_map bose_companion5_map[] = {
349 { 3, NULL, .dB = &bose_companion5_dB },
350 { 0 } /* terminator */
351};
352
Linus Torvalds1da177e2005-04-16 15:20:36 -0700353/*
Kailang Yangadcdd0d2016-04-12 10:55:03 +0800354 * Dell usb dock with ALC4020 codec had a firmware problem where it got
355 * screwed up when zero volume is passed; just skip it as a workaround
356 */
357static const struct usbmix_name_map dell_alc4020_map[] = {
358 { 16, NULL },
359 { 19, NULL },
360 { 0 }
361};
362
363/*
Linus Torvalds1da177e2005-04-16 15:20:36 -0700364 * Control map entries
365 */
366
367static struct usbmix_ctl_map usbmix_ctl_maps[] = {
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200368 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200369 .id = USB_ID(0x041e, 0x3000),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200370 .map = extigy_map,
371 .ignore_ctl_error = 1,
372 },
373 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200374 .id = USB_ID(0x041e, 0x3010),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200375 .map = mp3plus_map,
376 },
377 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200378 .id = USB_ID(0x041e, 0x3020),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200379 .map = audigy2nx_map,
380 .selector_map = audigy2nx_selectors,
381 },
Timofei Bondarenko69b1f1e2007-10-30 15:28:14 +0100382 {
383 .id = USB_ID(0x041e, 0x3040),
384 .map = live24ext_map,
385 },
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200386 {
Andrea Borgia31959542009-01-07 22:58:50 +0100387 .id = USB_ID(0x041e, 0x3048),
388 .map = audigy2nx_map,
389 .selector_map = audigy2nx_selectors,
390 },
Oleksij Rempelb64a1ba2012-06-19 22:21:19 +0200391 { /* Logitech, Inc. QuickCam Pro for Notebooks */
392 .id = USB_ID(0x046d, 0x0991),
393 .ignore_ctl_error = 1,
394 },
Oleksij Rempel05b9afd52012-06-19 22:21:18 +0200395 { /* Logitech, Inc. QuickCam E 3500 */
396 .id = USB_ID(0x046d, 0x09a4),
397 .ignore_ctl_error = 1,
398 },
Takashi Iwai19570d72013-12-19 14:32:53 +0100399 { /* Plantronics GameCom 780 */
400 .id = USB_ID(0x047f, 0xc010),
401 .map = gamecom780_map,
402 },
Andrea Borgia31959542009-01-07 22:58:50 +0100403 {
Clemens Ladisch9c9565f2005-10-05 13:02:38 +0200404 /* Hercules DJ Console (Windows Edition) */
405 .id = USB_ID(0x06f8, 0xb000),
406 .ignore_ctl_error = 1,
407 },
408 {
409 /* Hercules DJ Console (Macintosh Edition) */
Clemens Ladisch460dc982005-09-16 16:56:01 +0200410 .id = USB_ID(0x06f8, 0xd002),
411 .ignore_ctl_error = 1,
412 },
413 {
Alexey Fishere0feefc2009-12-01 13:40:53 +0100414 /* Hercules Gamesurround Muse Pocket LT
415 * (USB 5.1 Channel Audio Adapter)
416 */
417 .id = USB_ID(0x06f8, 0xc000),
418 .map = hercules_usb51_map,
419 },
420 {
Eldad Zack39e95152013-01-13 23:02:04 +0100421 .id = USB_ID(0x0763, 0x2030),
422 .selector_map = c400_selectors,
423 },
424 {
Matt Gruskine9a25e02013-02-09 12:56:35 -0500425 .id = USB_ID(0x0763, 0x2031),
426 .selector_map = c400_selectors,
427 },
428 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200429 .id = USB_ID(0x08bb, 0x2702),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200430 .map = linex_map,
431 .ignore_ctl_error = 1,
432 },
433 {
Clemens Ladischc7a93b82006-03-16 08:25:56 +0100434 .id = USB_ID(0x0a92, 0x0091),
435 .map = maya44_map,
436 },
437 {
Clemens Ladisch27d10f52005-05-02 08:51:26 +0200438 .id = USB_ID(0x0c45, 0x1158),
Clemens Ladisch8e062ec2005-04-22 15:49:52 +0200439 .map = justlink_map,
440 },
Clemens Ladischfef8a0c2006-09-22 11:00:51 +0200441 {
442 .id = USB_ID(0x0ccd, 0x0028),
443 .map = aureon_51_2_map,
444 },
Andreas Bergmeier86932902009-01-18 18:48:03 +0100445 {
Kailang Yangadcdd0d2016-04-12 10:55:03 +0800446 .id = USB_ID(0x0bda, 0x4014),
447 .map = dell_alc4020_map,
448 },
449 {
Damien Zammitd497a822014-11-12 01:09:54 +1100450 .id = USB_ID(0x0dba, 0x1000),
451 .map = mbox1_map,
452 },
453 {
Andreas Bergmeier86932902009-01-18 18:48:03 +0100454 .id = USB_ID(0x13e5, 0x0001),
455 .map = scratch_live_map,
456 .ignore_ctl_error = 1,
457 },
Mark Hills7536c302012-04-14 17:19:24 +0100458 {
459 .id = USB_ID(0x200c, 0x1018),
460 .map = ebox44_map,
461 },
Clemens Ladisch624aef42014-02-16 17:11:10 +0100462 {
Clemens Ladisch044bddb2015-06-03 11:36:42 +0200463 /* MAYA44 USB+ */
464 .id = USB_ID(0x2573, 0x0008),
465 .map = maya44_map,
466 },
467 {
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100468 /* KEF X300A */
Clemens Ladisch624aef42014-02-16 17:11:10 +0100469 .id = USB_ID(0x27ac, 0x1000),
Jiri Jaburekd70a1b92014-12-18 02:03:19 +0100470 .map = scms_usb3318_map,
471 },
472 {
473 /* Arcam rPAC */
474 .id = USB_ID(0x25c4, 0x0003),
475 .map = scms_usb3318_map,
Clemens Ladisch624aef42014-02-16 17:11:10 +0100476 },
Yao-Wen Mao2d1cb7f2015-07-29 15:13:54 +0800477 {
478 /* Bose Companion 5 */
479 .id = USB_ID(0x05a7, 0x1020),
480 .map = bose_companion5_map,
481 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700482 { 0 } /* terminator */
483};
484