Linux Audio

Check our new training course

Loading...
v6.13.7
   1/* SPDX-License-Identifier: GPL-2.0-or-later */
   2/*
   3 * ALSA USB Audio Driver
   4 *
   5 * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>,
   6 *                       Clemens Ladisch <clemens@ladisch.de>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
   7 */
   8
   9/*
  10 * The contents of this file are part of the driver's id_table.
  11 *
  12 * In a perfect world, this file would be empty.
  13 */
  14
  15/*
  16 * Use this for devices where other interfaces are standard compliant,
  17 * to prevent the quirk being applied to those interfaces. (To work with
  18 * hotplugging, bDeviceClass must be set to USB_CLASS_PER_INTERFACE.)
  19 */
  20#define USB_DEVICE_VENDOR_SPEC(vend, prod) \
  21	.match_flags = USB_DEVICE_ID_MATCH_VENDOR | \
  22		       USB_DEVICE_ID_MATCH_PRODUCT | \
  23		       USB_DEVICE_ID_MATCH_INT_CLASS, \
  24	.idVendor = vend, \
  25	.idProduct = prod, \
  26	.bInterfaceClass = USB_CLASS_VENDOR_SPEC
  27
  28/* A standard entry matching with vid/pid and the audio class/subclass */
  29#define USB_AUDIO_DEVICE(vend, prod) \
  30	.match_flags = USB_DEVICE_ID_MATCH_DEVICE | \
  31		       USB_DEVICE_ID_MATCH_INT_CLASS | \
  32		       USB_DEVICE_ID_MATCH_INT_SUBCLASS, \
  33	.idVendor = vend, \
  34	.idProduct = prod, \
  35	.bInterfaceClass = USB_CLASS_AUDIO, \
  36	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
  37
  38/* Quirk .driver_info, followed by the definition of the quirk entry;
  39 * put like QUIRK_DRIVER_INFO { ... } in each entry of the quirk table
  40 */
  41#define QUIRK_DRIVER_INFO \
  42	.driver_info = (unsigned long)&(const struct snd_usb_audio_quirk)
  43
  44/*
  45 * Macros for quirk data entries
  46 */
  47
  48/* Quirk data entry for ignoring the interface */
  49#define QUIRK_DATA_IGNORE(_ifno) \
  50	.ifnum = (_ifno), .type = QUIRK_IGNORE_INTERFACE
  51/* Quirk data entry for a standard audio interface */
  52#define QUIRK_DATA_STANDARD_AUDIO(_ifno) \
  53	.ifnum = (_ifno), .type = QUIRK_AUDIO_STANDARD_INTERFACE
  54/* Quirk data entry for a standard MIDI interface */
  55#define QUIRK_DATA_STANDARD_MIDI(_ifno) \
  56	.ifnum = (_ifno), .type = QUIRK_MIDI_STANDARD_INTERFACE
  57/* Quirk data entry for a standard mixer interface */
  58#define QUIRK_DATA_STANDARD_MIXER(_ifno) \
  59	.ifnum = (_ifno), .type = QUIRK_AUDIO_STANDARD_MIXER
  60
  61/* Quirk data entry for Yamaha MIDI */
  62#define QUIRK_DATA_MIDI_YAMAHA(_ifno) \
  63	.ifnum = (_ifno), .type = QUIRK_MIDI_YAMAHA
  64/* Quirk data entry for Edirol UAxx */
  65#define QUIRK_DATA_EDIROL_UAXX(_ifno) \
  66	.ifnum = (_ifno), .type = QUIRK_AUDIO_EDIROL_UAXX
  67/* Quirk data entry for raw bytes interface */
  68#define QUIRK_DATA_RAW_BYTES(_ifno) \
  69	.ifnum = (_ifno), .type = QUIRK_MIDI_RAW_BYTES
  70
  71/* Quirk composite array terminator */
  72#define QUIRK_COMPOSITE_END	{ .ifnum = -1 }
  73
  74/* Quirk data entry for composite quirks;
  75 * followed by the quirk array that is terminated with QUIRK_COMPOSITE_END
  76 * e.g. QUIRK_DATA_COMPOSITE { { quirk1 }, { quirk2 },..., QUIRK_COMPOSITE_END }
  77 */
  78#define QUIRK_DATA_COMPOSITE \
  79	.ifnum = QUIRK_ANY_INTERFACE, \
  80	.type = QUIRK_COMPOSITE, \
  81	.data = &(const struct snd_usb_audio_quirk[])
  82
  83/* Quirk data entry for a fixed audio endpoint;
  84 * followed by audioformat definition
  85 * e.g. QUIRK_DATA_AUDIOFORMAT(n) { .formats = xxx, ... }
  86 */
  87#define QUIRK_DATA_AUDIOFORMAT(_ifno)	    \
  88	.ifnum = (_ifno),		    \
  89	.type = QUIRK_AUDIO_FIXED_ENDPOINT, \
  90	.data = &(const struct audioformat)
  91
  92/* Quirk data entry for a fixed MIDI endpoint;
  93 * followed by snd_usb_midi_endpoint_info definition
  94 * e.g. QUIRK_DATA_MIDI_FIXED_ENDPOINT(n) { .out_cables = x, .in_cables = y }
  95 */
  96#define QUIRK_DATA_MIDI_FIXED_ENDPOINT(_ifno) \
  97	.ifnum = (_ifno),		      \
  98	.type = QUIRK_MIDI_FIXED_ENDPOINT,    \
  99	.data = &(const struct snd_usb_midi_endpoint_info)
 100/* Quirk data entry for a MIDIMAN MIDI endpoint */
 101#define QUIRK_DATA_MIDI_MIDIMAN(_ifno) \
 102	.ifnum = (_ifno),	       \
 103	.type = QUIRK_MIDI_MIDIMAN,    \
 104	.data = &(const struct snd_usb_midi_endpoint_info)
 105/* Quirk data entry for a EMAGIC MIDI endpoint */
 106#define QUIRK_DATA_MIDI_EMAGIC(_ifno) \
 107	.ifnum = (_ifno),	      \
 108	.type = QUIRK_MIDI_EMAGIC,    \
 109	.data = &(const struct snd_usb_midi_endpoint_info)
 110
 111/*
 112 * Here we go... the quirk table definition begins:
 113 */
 114
 115/* FTDI devices */
 116{
 117	USB_DEVICE(0x0403, 0xb8d8),
 118	QUIRK_DRIVER_INFO {
 119		/* .vendor_name = "STARR LABS", */
 120		/* .product_name = "Starr Labs MIDI USB device", */
 121		.ifnum = 0,
 122		.type = QUIRK_MIDI_FTDI
 123	}
 124},
 125
 126{
 127	/* Creative BT-D1 */
 128	USB_DEVICE(0x041e, 0x0005),
 129	QUIRK_DRIVER_INFO {
 130		QUIRK_DATA_AUDIOFORMAT(1) {
 
 
 131			.formats = SNDRV_PCM_FMTBIT_S16_LE,
 132			.channels = 2,
 133			.iface = 1,
 134			.altsetting = 1,
 135			.altset_idx = 1,
 136			.endpoint = 0x03,
 137			.ep_attr = USB_ENDPOINT_XFER_ISOC,
 138			.attributes = 0,
 139			.rates = SNDRV_PCM_RATE_CONTINUOUS,
 140			.rate_min = 48000,
 141			.rate_max = 48000,
 142		}
 143	}
 144},
 145
 146/* E-Mu 0202 USB */
 147{ USB_DEVICE_VENDOR_SPEC(0x041e, 0x3f02) },
 148/* E-Mu 0404 USB */
 149{ USB_DEVICE_VENDOR_SPEC(0x041e, 0x3f04) },
 150/* E-Mu Tracker Pre */
 151{ USB_DEVICE_VENDOR_SPEC(0x041e, 0x3f0a) },
 152/* E-Mu 0204 USB */
 153{ USB_DEVICE_VENDOR_SPEC(0x041e, 0x3f19) },
 154/* Ktmicro Usb_audio device */
 155{ USB_DEVICE_VENDOR_SPEC(0x31b2, 0x0011) },
 156
 157/*
 158 * Creative Technology, Ltd Live! Cam Sync HD [VF0770]
 159 * The device advertises 8 formats, but only a rate of 48kHz is honored by the
 160 * hardware and 24 bits give chopped audio, so only report the one working
 161 * combination.
 162 */
 163{
 164	USB_AUDIO_DEVICE(0x041e, 0x4095),
 165	QUIRK_DRIVER_INFO {
 166		QUIRK_DATA_COMPOSITE {
 167			{ QUIRK_DATA_STANDARD_MIXER(2) },
 168			{
 169				QUIRK_DATA_AUDIOFORMAT(3) {
 170					.formats = SNDRV_PCM_FMTBIT_S16_LE,
 171					.channels = 2,
 172					.fmt_bits = 16,
 173					.iface = 3,
 174					.altsetting = 4,
 175					.altset_idx = 4,
 176					.endpoint = 0x82,
 177					.ep_attr = 0x05,
 178					.rates = SNDRV_PCM_RATE_48000,
 179					.rate_min = 48000,
 180					.rate_max = 48000,
 181					.nr_rates = 1,
 182					.rate_table = (unsigned int[]) { 48000 },
 183				},
 184			},
 185			QUIRK_COMPOSITE_END
 186		},
 187	},
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 188},
 189
 190/*
 191 * HP Wireless Audio
 192 * When not ignored, causes instability issues for some users, forcing them to
 193 * skip the entire module.
 194 */
 195{
 196	USB_DEVICE(0x0424, 0xb832),
 197	QUIRK_DRIVER_INFO {
 198		.vendor_name = "Standard Microsystems Corp.",
 199		.product_name = "HP Wireless Audio",
 200		QUIRK_DATA_COMPOSITE {
 
 
 201			/* Mixer */
 202			{ QUIRK_DATA_IGNORE(0) },
 
 
 
 203			/* Playback */
 204			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 205			/* Capture */
 206			{ QUIRK_DATA_IGNORE(2) },
 
 
 
 207			/* HID Device, .ifnum = 3 */
 208			QUIRK_COMPOSITE_END
 
 
 209		}
 210	}
 211},
 212
 213/*
 214 * Logitech QuickCam: bDeviceClass is vendor-specific, so generic interface
 215 * class matches do not take effect without an explicit ID match.
 216 */
 217{ USB_AUDIO_DEVICE(0x046d, 0x0850) },
 218{ USB_AUDIO_DEVICE(0x046d, 0x08ae) },
 219{ USB_AUDIO_DEVICE(0x046d, 0x08c6) },
 220{ USB_AUDIO_DEVICE(0x046d, 0x08f0) },
 221{ USB_AUDIO_DEVICE(0x046d, 0x08f5) },
 222{ USB_AUDIO_DEVICE(0x046d, 0x08f6) },
 223{ USB_AUDIO_DEVICE(0x046d, 0x0990) },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 224
 225/*
 226 * Yamaha devices
 227 */
 228
 229#define YAMAHA_DEVICE(id, name) { \
 230	USB_DEVICE(0x0499, id), \
 231	QUIRK_DRIVER_INFO { \
 232		.vendor_name = "Yamaha", \
 233		.product_name = name, \
 234		QUIRK_DATA_MIDI_YAMAHA(QUIRK_ANY_INTERFACE) \
 
 235	} \
 236}
 237#define YAMAHA_INTERFACE(id, intf, name) { \
 238	USB_DEVICE_VENDOR_SPEC(0x0499, id), \
 239	QUIRK_DRIVER_INFO { \
 240		.vendor_name = "Yamaha", \
 241		.product_name = name, \
 242		QUIRK_DATA_MIDI_YAMAHA(intf) \
 
 243	} \
 244}
 245YAMAHA_DEVICE(0x1000, "UX256"),
 246YAMAHA_DEVICE(0x1001, "MU1000"),
 247YAMAHA_DEVICE(0x1002, "MU2000"),
 248YAMAHA_DEVICE(0x1003, "MU500"),
 249YAMAHA_INTERFACE(0x1004, 3, "UW500"),
 250YAMAHA_DEVICE(0x1005, "MOTIF6"),
 251YAMAHA_DEVICE(0x1006, "MOTIF7"),
 252YAMAHA_DEVICE(0x1007, "MOTIF8"),
 253YAMAHA_DEVICE(0x1008, "UX96"),
 254YAMAHA_DEVICE(0x1009, "UX16"),
 255YAMAHA_INTERFACE(0x100a, 3, "EOS BX"),
 256YAMAHA_DEVICE(0x100c, "UC-MX"),
 257YAMAHA_DEVICE(0x100d, "UC-KX"),
 258YAMAHA_DEVICE(0x100e, "S08"),
 259YAMAHA_DEVICE(0x100f, "CLP-150"),
 260YAMAHA_DEVICE(0x1010, "CLP-170"),
 261YAMAHA_DEVICE(0x1011, "P-250"),
 262YAMAHA_DEVICE(0x1012, "TYROS"),
 263YAMAHA_DEVICE(0x1013, "PF-500"),
 264YAMAHA_DEVICE(0x1014, "S90"),
 265YAMAHA_DEVICE(0x1015, "MOTIF-R"),
 266YAMAHA_DEVICE(0x1016, "MDP-5"),
 267YAMAHA_DEVICE(0x1017, "CVP-204"),
 268YAMAHA_DEVICE(0x1018, "CVP-206"),
 269YAMAHA_DEVICE(0x1019, "CVP-208"),
 270YAMAHA_DEVICE(0x101a, "CVP-210"),
 271YAMAHA_DEVICE(0x101b, "PSR-1100"),
 272YAMAHA_DEVICE(0x101c, "PSR-2100"),
 273YAMAHA_DEVICE(0x101d, "CLP-175"),
 274YAMAHA_DEVICE(0x101e, "PSR-K1"),
 275YAMAHA_DEVICE(0x101f, "EZ-J24"),
 276YAMAHA_DEVICE(0x1020, "EZ-250i"),
 277YAMAHA_DEVICE(0x1021, "MOTIF ES 6"),
 278YAMAHA_DEVICE(0x1022, "MOTIF ES 7"),
 279YAMAHA_DEVICE(0x1023, "MOTIF ES 8"),
 280YAMAHA_DEVICE(0x1024, "CVP-301"),
 281YAMAHA_DEVICE(0x1025, "CVP-303"),
 282YAMAHA_DEVICE(0x1026, "CVP-305"),
 283YAMAHA_DEVICE(0x1027, "CVP-307"),
 284YAMAHA_DEVICE(0x1028, "CVP-309"),
 285YAMAHA_DEVICE(0x1029, "CVP-309GP"),
 286YAMAHA_DEVICE(0x102a, "PSR-1500"),
 287YAMAHA_DEVICE(0x102b, "PSR-3000"),
 288YAMAHA_DEVICE(0x102e, "ELS-01/01C"),
 289YAMAHA_DEVICE(0x1030, "PSR-295/293"),
 290YAMAHA_DEVICE(0x1031, "DGX-205/203"),
 291YAMAHA_DEVICE(0x1032, "DGX-305"),
 292YAMAHA_DEVICE(0x1033, "DGX-505"),
 293YAMAHA_DEVICE(0x1034, NULL),
 294YAMAHA_DEVICE(0x1035, NULL),
 295YAMAHA_DEVICE(0x1036, NULL),
 296YAMAHA_DEVICE(0x1037, NULL),
 297YAMAHA_DEVICE(0x1038, NULL),
 298YAMAHA_DEVICE(0x1039, NULL),
 299YAMAHA_DEVICE(0x103a, NULL),
 300YAMAHA_DEVICE(0x103b, NULL),
 301YAMAHA_DEVICE(0x103c, NULL),
 302YAMAHA_DEVICE(0x103d, NULL),
 303YAMAHA_DEVICE(0x103e, NULL),
 304YAMAHA_DEVICE(0x103f, NULL),
 305YAMAHA_DEVICE(0x1040, NULL),
 306YAMAHA_DEVICE(0x1041, NULL),
 307YAMAHA_DEVICE(0x1042, NULL),
 308YAMAHA_DEVICE(0x1043, NULL),
 309YAMAHA_DEVICE(0x1044, NULL),
 310YAMAHA_DEVICE(0x1045, NULL),
 311YAMAHA_INTERFACE(0x104e, 0, NULL),
 312YAMAHA_DEVICE(0x104f, NULL),
 313YAMAHA_DEVICE(0x1050, NULL),
 314YAMAHA_DEVICE(0x1051, NULL),
 315YAMAHA_DEVICE(0x1052, NULL),
 316YAMAHA_INTERFACE(0x1053, 0, NULL),
 317YAMAHA_INTERFACE(0x1054, 0, NULL),
 318YAMAHA_DEVICE(0x1055, NULL),
 319YAMAHA_DEVICE(0x1056, NULL),
 320YAMAHA_DEVICE(0x1057, NULL),
 321YAMAHA_DEVICE(0x1058, NULL),
 322YAMAHA_DEVICE(0x1059, NULL),
 323YAMAHA_DEVICE(0x105a, NULL),
 324YAMAHA_DEVICE(0x105b, NULL),
 325YAMAHA_DEVICE(0x105c, NULL),
 326YAMAHA_DEVICE(0x105d, NULL),
 327{
 328	USB_DEVICE(0x0499, 0x1503),
 329	QUIRK_DRIVER_INFO {
 330		/* .vendor_name = "Yamaha", */
 331		/* .product_name = "MOX6/MOX8", */
 332		QUIRK_DATA_COMPOSITE {
 333			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 334			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 335			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 336			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 337		}
 338	}
 339},
 340{
 341	USB_DEVICE(0x0499, 0x1507),
 342	QUIRK_DRIVER_INFO {
 343		/* .vendor_name = "Yamaha", */
 344		/* .product_name = "THR10", */
 345		QUIRK_DATA_COMPOSITE {
 346			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 347			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 348			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 349			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 350		}
 351	}
 352},
 353{
 354	USB_DEVICE(0x0499, 0x1509),
 355	QUIRK_DRIVER_INFO {
 356		/* .vendor_name = "Yamaha", */
 357		/* .product_name = "Steinberg UR22", */
 358		QUIRK_DATA_COMPOSITE {
 359			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 360			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 361			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 362			{ QUIRK_DATA_IGNORE(4) },
 363			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 364		}
 365	}
 366},
 367{
 368	USB_DEVICE(0x0499, 0x150a),
 369	QUIRK_DRIVER_INFO {
 370		/* .vendor_name = "Yamaha", */
 371		/* .product_name = "THR5A", */
 372		QUIRK_DATA_COMPOSITE {
 373			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 374			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 375			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 376			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 377		}
 378	}
 379},
 380{
 381	USB_DEVICE(0x0499, 0x150c),
 382	QUIRK_DRIVER_INFO {
 383		/* .vendor_name = "Yamaha", */
 384		/* .product_name = "THR10C", */
 385		QUIRK_DATA_COMPOSITE {
 386			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 387			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 388			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 389			QUIRK_COMPOSITE_END
 390		}
 391	}
 392},
 393{
 394	USB_DEVICE(0x0499, 0x1718),
 395	QUIRK_DRIVER_INFO {
 396		/* .vendor_name = "Yamaha", */
 397		/* .product_name = "P-125", */
 398		QUIRK_DATA_COMPOSITE {
 399			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 400			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 401			{ QUIRK_DATA_MIDI_YAMAHA(3) },
 402			QUIRK_COMPOSITE_END
 403		}
 404	}
 405},
 406YAMAHA_DEVICE(0x2000, "DGP-7"),
 407YAMAHA_DEVICE(0x2001, "DGP-5"),
 408YAMAHA_DEVICE(0x2002, NULL),
 409YAMAHA_DEVICE(0x2003, NULL),
 410YAMAHA_DEVICE(0x5000, "CS1D"),
 411YAMAHA_DEVICE(0x5001, "DSP1D"),
 412YAMAHA_DEVICE(0x5002, "DME32"),
 413YAMAHA_DEVICE(0x5003, "DM2000"),
 414YAMAHA_DEVICE(0x5004, "02R96"),
 415YAMAHA_DEVICE(0x5005, "ACU16-C"),
 416YAMAHA_DEVICE(0x5006, "NHB32-C"),
 417YAMAHA_DEVICE(0x5007, "DM1000"),
 418YAMAHA_DEVICE(0x5008, "01V96"),
 419YAMAHA_DEVICE(0x5009, "SPX2000"),
 420YAMAHA_DEVICE(0x500a, "PM5D"),
 421YAMAHA_DEVICE(0x500b, "DME64N"),
 422YAMAHA_DEVICE(0x500c, "DME24N"),
 423YAMAHA_DEVICE(0x500d, NULL),
 424YAMAHA_DEVICE(0x500e, NULL),
 425YAMAHA_DEVICE(0x500f, NULL),
 426YAMAHA_DEVICE(0x7000, "DTX"),
 427YAMAHA_DEVICE(0x7010, "UB99"),
 428#undef YAMAHA_DEVICE
 429#undef YAMAHA_INTERFACE
 430/* this catches most recent vendor-specific Yamaha devices */
 431{
 432	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
 433	               USB_DEVICE_ID_MATCH_INT_CLASS,
 434	.idVendor = 0x0499,
 435	.bInterfaceClass = USB_CLASS_VENDOR_SPEC,
 436	QUIRK_DRIVER_INFO {
 437		.ifnum = QUIRK_ANY_INTERFACE,
 438		.type = QUIRK_AUTODETECT
 439	}
 440},
 441
 442/*
 443 * Roland/RolandED/Edirol/BOSS devices
 444 */
 445{
 446	USB_DEVICE(0x0582, 0x0000),
 447	QUIRK_DRIVER_INFO {
 448		.vendor_name = "Roland",
 449		.product_name = "UA-100",
 450		QUIRK_DATA_COMPOSITE {
 
 
 451			{
 452				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
 453					.formats = SNDRV_PCM_FMTBIT_S16_LE,
 454					.channels = 4,
 455					.iface = 0,
 456					.altsetting = 1,
 457					.altset_idx = 1,
 458					.attributes = 0,
 459					.endpoint = 0x01,
 460					.ep_attr = 0x09,
 461					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 462					.rate_min = 44100,
 463					.rate_max = 44100,
 464				}
 465			},
 466			{
 467				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
 468					.formats = SNDRV_PCM_FMTBIT_S16_LE,
 469					.channels = 2,
 470					.iface = 1,
 471					.altsetting = 1,
 472					.altset_idx = 1,
 473					.attributes = UAC_EP_CS_ATTR_FILL_MAX,
 474					.endpoint = 0x81,
 475					.ep_attr = 0x05,
 476					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 477					.rate_min = 44100,
 478					.rate_max = 44100,
 479				}
 480			},
 481			{
 482				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 483					.out_cables = 0x0007,
 484					.in_cables  = 0x0007
 485				}
 486			},
 487			QUIRK_COMPOSITE_END
 
 
 488		}
 489	}
 490},
 491{
 492	USB_DEVICE(0x0582, 0x0002),
 493	QUIRK_DRIVER_INFO {
 494		.vendor_name = "EDIROL",
 495		.product_name = "UM-4",
 496		QUIRK_DATA_COMPOSITE {
 497			{ QUIRK_DATA_IGNORE(0) },
 498			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 499			{
 500				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 501					.out_cables = 0x000f,
 502					.in_cables  = 0x000f
 503				}
 504			},
 505			QUIRK_COMPOSITE_END
 
 
 506		}
 507	}
 508},
 509{
 510	USB_DEVICE(0x0582, 0x0003),
 511	QUIRK_DRIVER_INFO {
 512		.vendor_name = "Roland",
 513		.product_name = "SC-8850",
 514		QUIRK_DATA_COMPOSITE {
 515			{ QUIRK_DATA_IGNORE(0) },
 516			{ QUIRK_DATA_IGNORE(1) },
 517			{
 518				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 
 
 
 
 519					.out_cables = 0x003f,
 520					.in_cables  = 0x003f
 521				}
 522			},
 523			QUIRK_COMPOSITE_END
 
 
 524		}
 525	}
 526},
 527{
 528	USB_DEVICE(0x0582, 0x0004),
 529	QUIRK_DRIVER_INFO {
 530		.vendor_name = "Roland",
 531		.product_name = "U-8",
 532		QUIRK_DATA_COMPOSITE {
 533			{ QUIRK_DATA_IGNORE(0) },
 534			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 
 
 
 
 535			{
 536				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 537					.out_cables = 0x0005,
 538					.in_cables  = 0x0005
 539				}
 540			},
 541			QUIRK_COMPOSITE_END
 
 
 542		}
 543	}
 544},
 545{
 546	/* Has ID 0x0099 when not in "Advanced Driver" mode.
 547	 * The UM-2EX has only one input, but we cannot detect this. */
 548	USB_DEVICE(0x0582, 0x0005),
 549	QUIRK_DRIVER_INFO {
 550		.vendor_name = "EDIROL",
 551		.product_name = "UM-2",
 552		QUIRK_DATA_COMPOSITE {
 553			{ QUIRK_DATA_IGNORE(0) },
 554			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 
 
 
 
 555			{
 556				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 557					.out_cables = 0x0003,
 558					.in_cables  = 0x0003
 559				}
 560			},
 561			QUIRK_COMPOSITE_END
 
 
 562		}
 563	}
 564},
 565{
 566	USB_DEVICE(0x0582, 0x0007),
 567	QUIRK_DRIVER_INFO {
 568		.vendor_name = "Roland",
 569		.product_name = "SC-8820",
 570		QUIRK_DATA_COMPOSITE {
 571			{ QUIRK_DATA_IGNORE(0) },
 572			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 573			{
 574				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 575					.out_cables = 0x0013,
 576					.in_cables  = 0x0013
 577				}
 578			},
 579			QUIRK_COMPOSITE_END
 
 
 580		}
 581	}
 582},
 583{
 584	USB_DEVICE(0x0582, 0x0008),
 585	QUIRK_DRIVER_INFO {
 586		.vendor_name = "Roland",
 587		.product_name = "PC-300",
 588		QUIRK_DATA_COMPOSITE {
 589			{ QUIRK_DATA_IGNORE(0) },
 590			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 
 
 
 
 591			{
 592				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 593					.out_cables = 0x0001,
 594					.in_cables  = 0x0001
 595				}
 596			},
 597			QUIRK_COMPOSITE_END
 
 
 598		}
 599	}
 600},
 601{
 602	/* has ID 0x009d when not in "Advanced Driver" mode */
 603	USB_DEVICE(0x0582, 0x0009),
 604	QUIRK_DRIVER_INFO {
 605		.vendor_name = "EDIROL",
 606		.product_name = "UM-1",
 607		QUIRK_DATA_COMPOSITE {
 608			{ QUIRK_DATA_IGNORE(0) },
 609			{ QUIRK_DATA_IGNORE(1) },
 610			{
 611				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 
 
 
 
 612					.out_cables = 0x0001,
 613					.in_cables  = 0x0001
 614				}
 615			},
 616			QUIRK_COMPOSITE_END
 
 
 617		}
 618	}
 619},
 620{
 621	USB_DEVICE(0x0582, 0x000b),
 622	QUIRK_DRIVER_INFO {
 623		.vendor_name = "Roland",
 624		.product_name = "SK-500",
 625		QUIRK_DATA_COMPOSITE {
 626			{ QUIRK_DATA_IGNORE(0) },
 627			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 
 
 
 
 628			{
 629				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 630					.out_cables = 0x0013,
 631					.in_cables  = 0x0013
 632				}
 633			},
 634			QUIRK_COMPOSITE_END
 
 
 635		}
 636	}
 637},
 638{
 639	/* thanks to Emiliano Grilli <emillo@libero.it>
 640	 * for helping researching this data */
 641	USB_DEVICE(0x0582, 0x000c),
 642	QUIRK_DRIVER_INFO {
 643		.vendor_name = "Roland",
 644		.product_name = "SC-D70",
 645		QUIRK_DATA_COMPOSITE {
 646			{ QUIRK_DATA_STANDARD_AUDIO(0) },
 647			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 
 
 
 
 
 
 
 
 648			{
 649				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 650					.out_cables = 0x0007,
 651					.in_cables  = 0x0007
 652				}
 653			},
 654			QUIRK_COMPOSITE_END
 
 
 655		}
 656	}
 657},
 658{	/*
 659	 * This quirk is for the "Advanced Driver" mode of the Edirol UA-5.
 660	 * If the advanced mode switch at the back of the unit is off, the
 661	 * UA-5 has ID 0x0582/0x0011 and is standard compliant (no quirks),
 662	 * but offers only 16-bit PCM.
 663	 * In advanced mode, the UA-5 will output S24_3LE samples (two
 664	 * channels) at the rate indicated on the front switch, including
 665	 * the 96kHz sample rate.
 666	 */
 667	USB_DEVICE(0x0582, 0x0010),
 668	QUIRK_DRIVER_INFO {
 669		.vendor_name = "EDIROL",
 670		.product_name = "UA-5",
 671		QUIRK_DATA_COMPOSITE {
 672			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 673			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 674			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 675		}
 676	}
 677},
 678{
 679	/* has ID 0x0013 when not in "Advanced Driver" mode */
 680	USB_DEVICE(0x0582, 0x0012),
 681	QUIRK_DRIVER_INFO {
 682		.vendor_name = "Roland",
 683		.product_name = "XV-5050",
 684		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 685			.out_cables = 0x0001,
 686			.in_cables  = 0x0001
 687		}
 688	}
 689},
 690{
 691	/* has ID 0x0015 when not in "Advanced Driver" mode */
 692	USB_DEVICE(0x0582, 0x0014),
 693	QUIRK_DRIVER_INFO {
 694		.vendor_name = "EDIROL",
 695		.product_name = "UM-880",
 696		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 697			.out_cables = 0x01ff,
 698			.in_cables  = 0x01ff
 699		}
 700	}
 701},
 702{
 703	/* has ID 0x0017 when not in "Advanced Driver" mode */
 704	USB_DEVICE(0x0582, 0x0016),
 705	QUIRK_DRIVER_INFO {
 706		.vendor_name = "EDIROL",
 707		.product_name = "SD-90",
 708		QUIRK_DATA_COMPOSITE {
 709			{ QUIRK_DATA_STANDARD_AUDIO(0) },
 710			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 
 
 
 
 
 
 
 
 711			{
 712				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 713					.out_cables = 0x000f,
 714					.in_cables  = 0x000f
 715				}
 716			},
 717			QUIRK_COMPOSITE_END
 
 
 718		}
 719	}
 720},
 721{
 722	/* has ID 0x001c when not in "Advanced Driver" mode */
 723	USB_DEVICE(0x0582, 0x001b),
 724	QUIRK_DRIVER_INFO {
 725		.vendor_name = "Roland",
 726		.product_name = "MMP-2",
 727		QUIRK_DATA_COMPOSITE {
 728			{ QUIRK_DATA_IGNORE(0) },
 729			{ QUIRK_DATA_IGNORE(1) },
 
 
 
 
 
 
 
 
 730			{
 731				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 732					.out_cables = 0x0001,
 733					.in_cables  = 0x0001
 734				}
 735			},
 736			QUIRK_COMPOSITE_END
 
 
 737		}
 738	}
 739},
 740{
 741	/* has ID 0x001e when not in "Advanced Driver" mode */
 742	USB_DEVICE(0x0582, 0x001d),
 743	QUIRK_DRIVER_INFO {
 744		.vendor_name = "Roland",
 745		.product_name = "V-SYNTH",
 746		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 747			.out_cables = 0x0001,
 748			.in_cables  = 0x0001
 749		}
 750	}
 751},
 752{
 753	/* has ID 0x0024 when not in "Advanced Driver" mode */
 754	USB_DEVICE(0x0582, 0x0023),
 755	QUIRK_DRIVER_INFO {
 756		.vendor_name = "EDIROL",
 757		.product_name = "UM-550",
 758		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 759			.out_cables = 0x003f,
 760			.in_cables  = 0x003f
 761		}
 762	}
 763},
 764{
 765	/*
 766	 * This quirk is for the "Advanced Driver" mode. If off, the UA-20
 767	 * has ID 0x0026 and is standard compliant, but has only 16-bit PCM
 768	 * and no MIDI.
 769	 */
 770	USB_DEVICE(0x0582, 0x0025),
 771	QUIRK_DRIVER_INFO {
 772		.vendor_name = "EDIROL",
 773		.product_name = "UA-20",
 774		QUIRK_DATA_COMPOSITE {
 775			{ QUIRK_DATA_IGNORE(0) },
 
 776			{
 777				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
 
 
 
 
 778					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
 779					.channels = 2,
 780					.iface = 1,
 781					.altsetting = 1,
 782					.altset_idx = 1,
 783					.attributes = 0,
 784					.endpoint = 0x01,
 785					.ep_attr = 0x01,
 786					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 787					.rate_min = 44100,
 788					.rate_max = 44100,
 789				}
 790			},
 791			{
 792				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
 793					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
 794					.channels = 2,
 795					.iface = 2,
 796					.altsetting = 1,
 797					.altset_idx = 1,
 798					.attributes = 0,
 799					.endpoint = 0x82,
 800					.ep_attr = 0x01,
 801					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 802					.rate_min = 44100,
 803					.rate_max = 44100,
 804				}
 805			},
 806			{
 807				QUIRK_DATA_MIDI_FIXED_ENDPOINT(3) {
 
 
 808					.out_cables = 0x0001,
 809					.in_cables  = 0x0001
 810				}
 811			},
 812			QUIRK_COMPOSITE_END
 
 
 813		}
 814	}
 815},
 816{
 817	/* has ID 0x0028 when not in "Advanced Driver" mode */
 818	USB_DEVICE(0x0582, 0x0027),
 819	QUIRK_DRIVER_INFO {
 820		.vendor_name = "EDIROL",
 821		.product_name = "SD-20",
 822		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 823			.out_cables = 0x0003,
 824			.in_cables  = 0x0007
 825		}
 826	}
 827},
 828{
 829	/* has ID 0x002a when not in "Advanced Driver" mode */
 830	USB_DEVICE(0x0582, 0x0029),
 831	QUIRK_DRIVER_INFO {
 832		.vendor_name = "EDIROL",
 833		.product_name = "SD-80",
 834		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 835			.out_cables = 0x000f,
 836			.in_cables  = 0x000f
 837		}
 838	}
 839},
 840{	/*
 841	 * This quirk is for the "Advanced" modes of the Edirol UA-700.
 842	 * If the sample format switch is not in an advanced setting, the
 843	 * UA-700 has ID 0x0582/0x002c and is standard compliant (no quirks),
 844	 * but offers only 16-bit PCM and no MIDI.
 845	 */
 846	USB_DEVICE_VENDOR_SPEC(0x0582, 0x002b),
 847	QUIRK_DRIVER_INFO {
 848		.vendor_name = "EDIROL",
 849		.product_name = "UA-700",
 850		QUIRK_DATA_COMPOSITE {
 851			{ QUIRK_DATA_EDIROL_UAXX(1) },
 852			{ QUIRK_DATA_EDIROL_UAXX(2) },
 853			{ QUIRK_DATA_EDIROL_UAXX(3) },
 854			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 855		}
 856	}
 857},
 858{
 859	/* has ID 0x002e when not in "Advanced Driver" mode */
 860	USB_DEVICE(0x0582, 0x002d),
 861	QUIRK_DRIVER_INFO {
 862		.vendor_name = "Roland",
 863		.product_name = "XV-2020",
 864		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 865			.out_cables = 0x0001,
 866			.in_cables  = 0x0001
 867		}
 868	}
 869},
 870{
 871	/* has ID 0x0030 when not in "Advanced Driver" mode */
 872	USB_DEVICE(0x0582, 0x002f),
 873	QUIRK_DRIVER_INFO {
 874		.vendor_name = "Roland",
 875		.product_name = "VariOS",
 876		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 877			.out_cables = 0x0007,
 878			.in_cables  = 0x0007
 879		}
 880	}
 881},
 882{
 883	/* has ID 0x0034 when not in "Advanced Driver" mode */
 884	USB_DEVICE(0x0582, 0x0033),
 885	QUIRK_DRIVER_INFO {
 886		.vendor_name = "EDIROL",
 887		.product_name = "PCR",
 888		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 889			.out_cables = 0x0003,
 890			.in_cables  = 0x0007
 891		}
 892	}
 893},
 894{
 895	/*
 896	 * Has ID 0x0038 when not in "Advanced Driver" mode;
 897	 * later revisions use IDs 0x0054 and 0x00a2.
 898	 */
 899	USB_DEVICE(0x0582, 0x0037),
 900	QUIRK_DRIVER_INFO {
 901		.vendor_name = "Roland",
 902		.product_name = "Digital Piano",
 903		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 904			.out_cables = 0x0001,
 905			.in_cables  = 0x0001
 906		}
 907	}
 908},
 909{
 910	/*
 911	 * This quirk is for the "Advanced Driver" mode.  If off, the GS-10
 912	 * has ID 0x003c and is standard compliant, but has only 16-bit PCM
 913	 * and no MIDI.
 914	 */
 915	USB_DEVICE_VENDOR_SPEC(0x0582, 0x003b),
 916	QUIRK_DRIVER_INFO {
 917		.vendor_name = "BOSS",
 918		.product_name = "GS-10",
 919		QUIRK_DATA_COMPOSITE {
 920			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 921			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 922			{ QUIRK_DATA_STANDARD_MIDI(3) },
 923			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 924		}
 925	}
 926},
 927{
 928	/* has ID 0x0041 when not in "Advanced Driver" mode */
 929	USB_DEVICE(0x0582, 0x0040),
 930	QUIRK_DRIVER_INFO {
 931		.vendor_name = "Roland",
 932		.product_name = "GI-20",
 933		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 934			.out_cables = 0x0001,
 935			.in_cables  = 0x0001
 936		}
 937	}
 938},
 939{
 940	/* has ID 0x0043 when not in "Advanced Driver" mode */
 941	USB_DEVICE(0x0582, 0x0042),
 942	QUIRK_DRIVER_INFO {
 943		.vendor_name = "Roland",
 944		.product_name = "RS-70",
 945		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 946			.out_cables = 0x0001,
 947			.in_cables  = 0x0001
 948		}
 949	}
 950},
 951{
 952	/* has ID 0x0049 when not in "Advanced Driver" mode */
 953	USB_DEVICE(0x0582, 0x0047),
 954	QUIRK_DRIVER_INFO {
 955		/* .vendor_name = "EDIROL", */
 956		/* .product_name = "UR-80", */
 957		QUIRK_DATA_COMPOSITE {
 
 
 958			/* in the 96 kHz modes, only interface 1 is there */
 959			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 960			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 961			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 962		}
 963	}
 964},
 965{
 966	/* has ID 0x004a when not in "Advanced Driver" mode */
 967	USB_DEVICE(0x0582, 0x0048),
 968	QUIRK_DRIVER_INFO {
 969		/* .vendor_name = "EDIROL", */
 970		/* .product_name = "UR-80", */
 971		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 972			.out_cables = 0x0003,
 973			.in_cables  = 0x0007
 974		}
 975	}
 976},
 977{
 978	/* has ID 0x004e when not in "Advanced Driver" mode */
 979	USB_DEVICE(0x0582, 0x004c),
 980	QUIRK_DRIVER_INFO {
 981		.vendor_name = "EDIROL",
 982		.product_name = "PCR-A",
 983		QUIRK_DATA_COMPOSITE {
 984			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 985			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 986			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 987		}
 988	}
 989},
 990{
 991	/* has ID 0x004f when not in "Advanced Driver" mode */
 992	USB_DEVICE(0x0582, 0x004d),
 993	QUIRK_DRIVER_INFO {
 994		.vendor_name = "EDIROL",
 995		.product_name = "PCR-A",
 996		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
 997			.out_cables = 0x0003,
 998			.in_cables  = 0x0007
 999		}
1000	}
1001},
1002{
1003	/*
1004	 * This quirk is for the "Advanced Driver" mode. If off, the UA-3FX
1005	 * is standard compliant, but has only 16-bit PCM.
1006	 */
1007	USB_DEVICE(0x0582, 0x0050),
1008	QUIRK_DRIVER_INFO {
1009		.vendor_name = "EDIROL",
1010		.product_name = "UA-3FX",
1011		QUIRK_DATA_COMPOSITE {
1012			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1013			{ QUIRK_DATA_STANDARD_AUDIO(2) },
1014			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
1015		}
1016	}
1017},
1018{
1019	USB_DEVICE(0x0582, 0x0052),
1020	QUIRK_DRIVER_INFO {
1021		.vendor_name = "EDIROL",
1022		.product_name = "UM-1SX",
1023		QUIRK_DATA_STANDARD_MIDI(0)
 
1024	}
1025},
1026{
1027	USB_DEVICE(0x0582, 0x0060),
1028	QUIRK_DRIVER_INFO {
1029		.vendor_name = "Roland",
1030		.product_name = "EXR Series",
1031		QUIRK_DATA_STANDARD_MIDI(0)
 
1032	}
1033},
1034{
1035	/* has ID 0x0066 when not in "Advanced Driver" mode */
1036	USB_DEVICE(0x0582, 0x0064),
1037	QUIRK_DRIVER_INFO {
1038		/* .vendor_name = "EDIROL", */
1039		/* .product_name = "PCR-1", */
1040		QUIRK_DATA_COMPOSITE {
1041			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1042			{ QUIRK_DATA_STANDARD_AUDIO(2) },
1043			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
1044		}
1045	}
1046},
1047{
1048	/* has ID 0x0067 when not in "Advanced Driver" mode */
1049	USB_DEVICE(0x0582, 0x0065),
1050	QUIRK_DRIVER_INFO {
1051		/* .vendor_name = "EDIROL", */
1052		/* .product_name = "PCR-1", */
1053		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1054			.out_cables = 0x0001,
1055			.in_cables  = 0x0003
1056		}
1057	}
1058},
1059{
1060	/* has ID 0x006e when not in "Advanced Driver" mode */
1061	USB_DEVICE(0x0582, 0x006d),
1062	QUIRK_DRIVER_INFO {
1063		.vendor_name = "Roland",
1064		.product_name = "FANTOM-X",
1065		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1066			.out_cables = 0x0001,
1067			.in_cables  = 0x0001
1068		}
1069	}
1070},
1071{	/*
1072	 * This quirk is for the "Advanced" modes of the Edirol UA-25.
1073	 * If the switch is not in an advanced setting, the UA-25 has
1074	 * ID 0x0582/0x0073 and is standard compliant (no quirks), but
1075	 * offers only 16-bit PCM at 44.1 kHz and no MIDI.
1076	 */
1077	USB_DEVICE_VENDOR_SPEC(0x0582, 0x0074),
1078	QUIRK_DRIVER_INFO {
1079		.vendor_name = "EDIROL",
1080		.product_name = "UA-25",
1081		QUIRK_DATA_COMPOSITE {
1082			{ QUIRK_DATA_EDIROL_UAXX(0) },
1083			{ QUIRK_DATA_EDIROL_UAXX(1) },
1084			{ QUIRK_DATA_EDIROL_UAXX(2) },
1085			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
1086		}
1087	}
1088},
1089{
1090	/* has ID 0x0076 when not in "Advanced Driver" mode */
1091	USB_DEVICE(0x0582, 0x0075),
1092	QUIRK_DRIVER_INFO {
1093		.vendor_name = "BOSS",
1094		.product_name = "DR-880",
1095		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1096			.out_cables = 0x0001,
1097			.in_cables  = 0x0001
1098		}
1099	}
1100},
1101{
1102	/* has ID 0x007b when not in "Advanced Driver" mode */
1103	USB_DEVICE_VENDOR_SPEC(0x0582, 0x007a),
1104	QUIRK_DRIVER_INFO {
1105		.vendor_name = "Roland",
1106		/* "RD" or "RD-700SX"? */
1107		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1108			.out_cables = 0x0003,
1109			.in_cables  = 0x0003
1110		}
1111	}
1112},
1113{
1114	/* has ID 0x0081 when not in "Advanced Driver" mode */
1115	USB_DEVICE(0x0582, 0x0080),
1116	QUIRK_DRIVER_INFO {
1117		.vendor_name = "Roland",
1118		.product_name = "G-70",
1119		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1120			.out_cables = 0x0001,
1121			.in_cables  = 0x0001
1122		}
1123	}
1124},
1125{
1126	/* has ID 0x008c when not in "Advanced Driver" mode */
1127	USB_DEVICE(0x0582, 0x008b),
1128	QUIRK_DRIVER_INFO {
1129		.vendor_name = "EDIROL",
1130		.product_name = "PC-50",
1131		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1132			.out_cables = 0x0001,
1133			.in_cables  = 0x0001
1134		}
1135	}
1136},
1137{
1138	/*
1139	 * This quirk is for the "Advanced Driver" mode. If off, the UA-4FX
1140	 * is standard compliant, but has only 16-bit PCM and no MIDI.
1141	 */
1142	USB_DEVICE(0x0582, 0x00a3),
1143	QUIRK_DRIVER_INFO {
1144		.vendor_name = "EDIROL",
1145		.product_name = "UA-4FX",
1146		QUIRK_DATA_COMPOSITE {
1147			{ QUIRK_DATA_EDIROL_UAXX(0) },
1148			{ QUIRK_DATA_EDIROL_UAXX(1) },
1149			{ QUIRK_DATA_EDIROL_UAXX(2) },
1150			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
1151		}
1152	}
1153},
1154{
1155	/* Edirol M-16DX */
1156	USB_DEVICE(0x0582, 0x00c4),
1157	QUIRK_DRIVER_INFO {
1158		QUIRK_DATA_COMPOSITE {
1159			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1160			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1161			{
1162				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 
 
 
 
1163					.out_cables = 0x0001,
1164					.in_cables  = 0x0001
1165				}
1166			},
1167			QUIRK_COMPOSITE_END
 
 
1168		}
1169	}
1170},
1171{
1172	/* Advanced modes of the Edirol UA-25EX.
1173	 * For the standard mode, UA-25EX has ID 0582:00e7, which
1174	 * offers only 16-bit PCM at 44.1 kHz and no MIDI.
1175	 */
1176	USB_DEVICE_VENDOR_SPEC(0x0582, 0x00e6),
1177	QUIRK_DRIVER_INFO {
1178		.vendor_name = "EDIROL",
1179		.product_name = "UA-25EX",
1180		QUIRK_DATA_COMPOSITE {
1181			{ QUIRK_DATA_EDIROL_UAXX(0) },
1182			{ QUIRK_DATA_EDIROL_UAXX(1) },
1183			{ QUIRK_DATA_EDIROL_UAXX(2) },
1184			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
1185		}
1186	}
1187},
1188{
1189	/* Edirol UM-3G */
1190	USB_DEVICE_VENDOR_SPEC(0x0582, 0x0108),
1191	QUIRK_DRIVER_INFO {
1192		QUIRK_DATA_MIDI_FIXED_ENDPOINT(0) {
 
 
1193			.out_cables = 0x0007,
1194			.in_cables  = 0x0007
1195		}
1196	}
1197},
1198{
1199	/* BOSS ME-25 */
1200	USB_DEVICE(0x0582, 0x0113),
1201	QUIRK_DRIVER_INFO {
1202		QUIRK_DATA_COMPOSITE {
1203			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1204			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1205			{
1206				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
 
 
 
 
1207					.out_cables = 0x0001,
1208					.in_cables  = 0x0001
1209				}
1210			},
1211			QUIRK_COMPOSITE_END
 
 
1212		}
1213	}
1214},
1215{
1216	/* only 44.1 kHz works at the moment */
1217	USB_DEVICE(0x0582, 0x0120),
1218	QUIRK_DRIVER_INFO {
1219		/* .vendor_name = "Roland", */
1220		/* .product_name = "OCTO-CAPTURE", */
1221		QUIRK_DATA_COMPOSITE {
 
 
1222			{
1223				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
1224					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1225					.channels = 10,
1226					.iface = 0,
1227					.altsetting = 1,
1228					.altset_idx = 1,
1229					.endpoint = 0x05,
1230					.ep_attr = 0x05,
1231					.rates = SNDRV_PCM_RATE_44100,
1232					.rate_min = 44100,
1233					.rate_max = 44100,
1234					.nr_rates = 1,
1235					.rate_table = (unsigned int[]) { 44100 }
1236				}
1237			},
1238			{
1239				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
1240					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1241					.channels = 12,
1242					.iface = 1,
1243					.altsetting = 1,
1244					.altset_idx = 1,
1245					.endpoint = 0x85,
1246					.ep_attr = 0x25,
1247					.rates = SNDRV_PCM_RATE_44100,
1248					.rate_min = 44100,
1249					.rate_max = 44100,
1250					.nr_rates = 1,
1251					.rate_table = (unsigned int[]) { 44100 }
1252				}
1253			},
1254			{
1255				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
1256					.out_cables = 0x0001,
1257					.in_cables  = 0x0001
1258				}
1259			},
1260			{ QUIRK_DATA_IGNORE(3) },
1261			{ QUIRK_DATA_IGNORE(4) },
1262			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
1263		}
1264	}
1265},
1266{
1267	/* only 44.1 kHz works at the moment */
1268	USB_DEVICE(0x0582, 0x012f),
1269	QUIRK_DRIVER_INFO {
1270		/* .vendor_name = "Roland", */
1271		/* .product_name = "QUAD-CAPTURE", */
1272		QUIRK_DATA_COMPOSITE {
 
 
1273			{
1274				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
1275					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1276					.channels = 4,
1277					.iface = 0,
1278					.altsetting = 1,
1279					.altset_idx = 1,
1280					.endpoint = 0x05,
1281					.ep_attr = 0x05,
1282					.rates = SNDRV_PCM_RATE_44100,
1283					.rate_min = 44100,
1284					.rate_max = 44100,
1285					.nr_rates = 1,
1286					.rate_table = (unsigned int[]) { 44100 }
1287				}
1288			},
1289			{
1290				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
1291					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1292					.channels = 6,
1293					.iface = 1,
1294					.altsetting = 1,
1295					.altset_idx = 1,
1296					.endpoint = 0x85,
1297					.ep_attr = 0x25,
1298					.rates = SNDRV_PCM_RATE_44100,
1299					.rate_min = 44100,
1300					.rate_max = 44100,
1301					.nr_rates = 1,
1302					.rate_table = (unsigned int[]) { 44100 }
1303				}
1304			},
1305			{
1306				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
1307					.out_cables = 0x0001,
1308					.in_cables  = 0x0001
1309				}
1310			},
1311			{ QUIRK_DATA_IGNORE(3) },
1312			{ QUIRK_DATA_IGNORE(4) },
1313			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
1314		}
1315	}
1316},
1317{
1318	USB_DEVICE(0x0582, 0x0159),
1319	QUIRK_DRIVER_INFO {
1320		/* .vendor_name = "Roland", */
1321		/* .product_name = "UA-22", */
1322		QUIRK_DATA_COMPOSITE {
1323			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1324			{ QUIRK_DATA_STANDARD_AUDIO(1) },
 
 
 
 
1325			{
1326				QUIRK_DATA_MIDI_FIXED_ENDPOINT(2) {
 
 
 
 
 
 
1327					.out_cables = 0x0001,
1328					.in_cables = 0x0001
1329				}
1330			},
1331			QUIRK_COMPOSITE_END
 
 
1332		}
1333	}
1334},
1335
1336/* UA101 and co are supported by another driver */
1337{
1338	USB_DEVICE(0x0582, 0x0044), /* UA-1000 high speed */
1339	QUIRK_DRIVER_INFO {
1340		.ifnum = QUIRK_NODEV_INTERFACE
1341	},
1342},
1343{
1344	USB_DEVICE(0x0582, 0x007d), /* UA-101 high speed */
1345	QUIRK_DRIVER_INFO {
1346		.ifnum = QUIRK_NODEV_INTERFACE
1347	},
1348},
1349{
1350	USB_DEVICE(0x0582, 0x008d), /* UA-101 full speed */
1351	QUIRK_DRIVER_INFO {
1352		.ifnum = QUIRK_NODEV_INTERFACE
1353	},
1354},
1355
1356/* this catches most recent vendor-specific Roland devices */
1357{
1358	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
1359	               USB_DEVICE_ID_MATCH_INT_CLASS,
1360	.idVendor = 0x0582,
1361	.bInterfaceClass = USB_CLASS_VENDOR_SPEC,
1362	QUIRK_DRIVER_INFO {
1363		.ifnum = QUIRK_ANY_INTERFACE,
1364		.type = QUIRK_AUTODETECT
1365	}
1366},
1367
1368/* Guillemot devices */
1369{
1370	/*
1371	 * This is for the "Windows Edition" where the external MIDI ports are
1372	 * the only MIDI ports; the control data is reported through HID
1373	 * interfaces.  The "Macintosh Edition" has ID 0xd002 and uses standard
1374	 * compliant USB MIDI ports for external MIDI and controls.
1375	 */
1376	USB_DEVICE_VENDOR_SPEC(0x06f8, 0xb000),
1377	QUIRK_DRIVER_INFO {
1378		.vendor_name = "Hercules",
1379		.product_name = "DJ Console (WE)",
1380		QUIRK_DATA_MIDI_FIXED_ENDPOINT(4) {
 
 
1381			.out_cables = 0x0001,
1382			.in_cables = 0x0001
1383		}
1384	}
1385},
1386
1387/* Midiman/M-Audio devices */
1388{
1389	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1002),
1390	QUIRK_DRIVER_INFO {
1391		.vendor_name = "M-Audio",
1392		.product_name = "MidiSport 2x2",
1393		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1394			.out_cables = 0x0003,
1395			.in_cables  = 0x0003
1396		}
1397	}
1398},
1399{
1400	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1011),
1401	QUIRK_DRIVER_INFO {
1402		.vendor_name = "M-Audio",
1403		.product_name = "MidiSport 1x1",
1404		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1405			.out_cables = 0x0001,
1406			.in_cables  = 0x0001
1407		}
1408	}
1409},
1410{
1411	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1015),
1412	QUIRK_DRIVER_INFO {
1413		.vendor_name = "M-Audio",
1414		.product_name = "Keystation",
1415		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1416			.out_cables = 0x0001,
1417			.in_cables  = 0x0001
1418		}
1419	}
1420},
1421{
1422	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1021),
1423	QUIRK_DRIVER_INFO {
1424		.vendor_name = "M-Audio",
1425		.product_name = "MidiSport 4x4",
1426		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1427			.out_cables = 0x000f,
1428			.in_cables  = 0x000f
1429		}
1430	}
1431},
1432{
1433	/*
1434	 * For hardware revision 1.05; in the later revisions (1.10 and
1435	 * 1.21), 0x1031 is the ID for the device without firmware.
1436	 * Thanks to Olaf Giesbrecht <Olaf_Giesbrecht@yahoo.de>
1437	 */
1438	USB_DEVICE_VER(0x0763, 0x1031, 0x0100, 0x0109),
1439	QUIRK_DRIVER_INFO {
1440		.vendor_name = "M-Audio",
1441		.product_name = "MidiSport 8x8",
1442		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1443			.out_cables = 0x01ff,
1444			.in_cables  = 0x01ff
1445		}
1446	}
1447},
1448{
1449	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1033),
1450	QUIRK_DRIVER_INFO {
1451		.vendor_name = "M-Audio",
1452		.product_name = "MidiSport 8x8",
1453		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1454			.out_cables = 0x01ff,
1455			.in_cables  = 0x01ff
1456		}
1457	}
1458},
1459{
1460	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1041),
1461	QUIRK_DRIVER_INFO {
1462		.vendor_name = "M-Audio",
1463		.product_name = "MidiSport 2x4",
1464		QUIRK_DATA_MIDI_MIDIMAN(QUIRK_ANY_INTERFACE) {
 
 
1465			.out_cables = 0x000f,
1466			.in_cables  = 0x0003
1467		}
1468	}
1469},
1470{
1471	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2001),
1472	QUIRK_DRIVER_INFO {
1473		.vendor_name = "M-Audio",
1474		.product_name = "Quattro",
1475		QUIRK_DATA_COMPOSITE {
 
 
1476			/*
1477			 * Interfaces 0-2 are "Windows-compatible", 16-bit only,
1478			 * and share endpoints with the other interfaces.
1479			 * Ignore them.  The other interfaces can do 24 bits,
1480			 * but captured samples are big-endian (see usbaudio.c).
1481			 */
1482			{ QUIRK_DATA_IGNORE(0) },
1483			{ QUIRK_DATA_IGNORE(1) },
1484			{ QUIRK_DATA_IGNORE(2) },
1485			{ QUIRK_DATA_IGNORE(3) },
1486			{ QUIRK_DATA_STANDARD_AUDIO(4) },
1487			{ QUIRK_DATA_STANDARD_AUDIO(5) },
1488			{ QUIRK_DATA_IGNORE(6) },
1489			{ QUIRK_DATA_STANDARD_AUDIO(7) },
1490			{ QUIRK_DATA_STANDARD_AUDIO(8) },
1491			{
1492				QUIRK_DATA_MIDI_MIDIMAN(9) {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1493					.out_cables = 0x0001,
1494					.in_cables  = 0x0001
1495				}
1496			},
1497			QUIRK_COMPOSITE_END
 
 
1498		}
1499	}
1500},
1501{
1502	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2003),
1503	QUIRK_DRIVER_INFO {
1504		.vendor_name = "M-Audio",
1505		.product_name = "AudioPhile",
1506		QUIRK_DATA_MIDI_MIDIMAN(6) {
 
 
1507			.out_cables = 0x0001,
1508			.in_cables  = 0x0001
1509		}
1510	}
1511},
1512{
1513	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2008),
1514	QUIRK_DRIVER_INFO {
1515		.vendor_name = "M-Audio",
1516		.product_name = "Ozone",
1517		QUIRK_DATA_MIDI_MIDIMAN(3) {
 
 
1518			.out_cables = 0x0001,
1519			.in_cables  = 0x0001
1520		}
1521	}
1522},
1523{
1524	USB_DEVICE_VENDOR_SPEC(0x0763, 0x200d),
1525	QUIRK_DRIVER_INFO {
1526		.vendor_name = "M-Audio",
1527		.product_name = "OmniStudio",
1528		QUIRK_DATA_COMPOSITE {
1529			{ QUIRK_DATA_IGNORE(0) },
1530			{ QUIRK_DATA_IGNORE(1) },
1531			{ QUIRK_DATA_IGNORE(2) },
1532			{ QUIRK_DATA_IGNORE(3) },
1533			{ QUIRK_DATA_STANDARD_AUDIO(4) },
1534			{ QUIRK_DATA_STANDARD_AUDIO(5) },
1535			{ QUIRK_DATA_IGNORE(6) },
1536			{ QUIRK_DATA_STANDARD_AUDIO(7) },
1537			{ QUIRK_DATA_STANDARD_AUDIO(8) },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1538			{
1539				QUIRK_DATA_MIDI_MIDIMAN(9) {
 
 
1540					.out_cables = 0x0001,
1541					.in_cables  = 0x0001
1542				}
1543			},
1544			QUIRK_COMPOSITE_END
 
 
1545		}
1546	}
1547},
1548{
1549	USB_DEVICE(0x0763, 0x2019),
1550	QUIRK_DRIVER_INFO {
1551		/* .vendor_name = "M-Audio", */
1552		/* .product_name = "Ozone Academic", */
1553		QUIRK_DATA_COMPOSITE {
1554			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1555			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1556			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 
 
 
 
 
 
 
 
 
 
 
1557			{
1558				QUIRK_DATA_MIDI_MIDIMAN(3) {
 
 
1559					.out_cables = 0x0001,
1560					.in_cables  = 0x0001
1561				}
1562			},
1563			QUIRK_COMPOSITE_END
 
 
1564		}
1565	}
1566},
1567{
1568	/* M-Audio Micro */
1569	USB_DEVICE_VENDOR_SPEC(0x0763, 0x201a),
1570},
1571{
1572	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2030),
1573	QUIRK_DRIVER_INFO {
1574		/* .vendor_name = "M-Audio", */
1575		/* .product_name = "Fast Track C400", */
1576		QUIRK_DATA_COMPOSITE {
1577			{ QUIRK_DATA_STANDARD_MIXER(1) },
 
 
 
 
 
1578			/* Playback */
1579			{
1580				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
1581					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1582					.channels = 6,
1583					.iface = 2,
1584					.altsetting = 1,
1585					.altset_idx = 1,
1586					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1587					.endpoint = 0x01,
1588					.ep_attr = 0x09,
1589					.rates = SNDRV_PCM_RATE_44100 |
1590						 SNDRV_PCM_RATE_48000 |
1591						 SNDRV_PCM_RATE_88200 |
1592						 SNDRV_PCM_RATE_96000,
1593					.rate_min = 44100,
1594					.rate_max = 96000,
1595					.nr_rates = 4,
1596					.rate_table = (unsigned int[]) {
1597							44100, 48000, 88200, 96000
1598					},
1599					.clock = 0x80,
1600				}
1601			},
1602			/* Capture */
1603			{
1604				QUIRK_DATA_AUDIOFORMAT(3) {
 
 
1605					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1606					.channels = 4,
1607					.iface = 3,
1608					.altsetting = 1,
1609					.altset_idx = 1,
1610					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1611					.endpoint = 0x81,
1612					.ep_attr = 0x05,
1613					.rates = SNDRV_PCM_RATE_44100 |
1614						 SNDRV_PCM_RATE_48000 |
1615						 SNDRV_PCM_RATE_88200 |
1616						 SNDRV_PCM_RATE_96000,
1617					.rate_min = 44100,
1618					.rate_max = 96000,
1619					.nr_rates = 4,
1620					.rate_table = (unsigned int[]) {
1621						44100, 48000, 88200, 96000
1622					},
1623					.clock = 0x80,
1624				}
1625			},
1626			/* MIDI: Interface = 4*/
1627			QUIRK_COMPOSITE_END
 
 
1628		}
1629	}
1630},
1631{
1632	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2031),
1633	QUIRK_DRIVER_INFO {
1634		/* .vendor_name = "M-Audio", */
1635		/* .product_name = "Fast Track C600", */
1636		QUIRK_DATA_COMPOSITE {
1637			{ QUIRK_DATA_STANDARD_MIXER(1) },
 
 
 
 
 
1638			/* Playback */
1639			{
1640				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
1641					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1642					.channels = 8,
1643					.iface = 2,
1644					.altsetting = 1,
1645					.altset_idx = 1,
1646					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1647					.endpoint = 0x01,
1648					.ep_attr = 0x09,
1649					.rates = SNDRV_PCM_RATE_44100 |
1650						 SNDRV_PCM_RATE_48000 |
1651						 SNDRV_PCM_RATE_88200 |
1652						 SNDRV_PCM_RATE_96000,
1653					.rate_min = 44100,
1654					.rate_max = 96000,
1655					.nr_rates = 4,
1656					.rate_table = (unsigned int[]) {
1657							44100, 48000, 88200, 96000
1658					},
1659					.clock = 0x80,
1660				}
1661			},
1662			/* Capture */
1663			{
1664				QUIRK_DATA_AUDIOFORMAT(3) {
 
 
1665					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1666					.channels = 6,
1667					.iface = 3,
1668					.altsetting = 1,
1669					.altset_idx = 1,
1670					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1671					.endpoint = 0x81,
1672					.ep_attr = 0x05,
1673					.rates = SNDRV_PCM_RATE_44100 |
1674						 SNDRV_PCM_RATE_48000 |
1675						 SNDRV_PCM_RATE_88200 |
1676						 SNDRV_PCM_RATE_96000,
1677					.rate_min = 44100,
1678					.rate_max = 96000,
1679					.nr_rates = 4,
1680					.rate_table = (unsigned int[]) {
1681						44100, 48000, 88200, 96000
1682					},
1683					.clock = 0x80,
1684				}
1685			},
1686			/* MIDI: Interface = 4 */
1687			QUIRK_COMPOSITE_END
 
 
1688		}
1689	}
1690},
1691{
1692	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2080),
1693	QUIRK_DRIVER_INFO {
1694		/* .vendor_name = "M-Audio", */
1695		/* .product_name = "Fast Track Ultra", */
1696		QUIRK_DATA_COMPOSITE {
1697			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
1698			{
1699				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
 
 
 
 
1700					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1701					.channels = 8,
1702					.iface = 1,
1703					.altsetting = 1,
1704					.altset_idx = 1,
1705					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1706					.endpoint = 0x01,
1707					.ep_attr = 0x09,
1708					.rates = SNDRV_PCM_RATE_44100 |
1709						 SNDRV_PCM_RATE_48000 |
1710						 SNDRV_PCM_RATE_88200 |
1711						 SNDRV_PCM_RATE_96000,
1712					.rate_min = 44100,
1713					.rate_max = 96000,
1714					.nr_rates = 4,
1715					.rate_table = (unsigned int[]) {
1716						44100, 48000, 88200, 96000
1717					}
1718				}
1719			},
1720			{
1721				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
1722					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1723					.channels = 8,
1724					.iface = 2,
1725					.altsetting = 1,
1726					.altset_idx = 1,
1727					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1728					.endpoint = 0x81,
1729					.ep_attr = 0x05,
1730					.rates = SNDRV_PCM_RATE_44100 |
1731						 SNDRV_PCM_RATE_48000 |
1732						 SNDRV_PCM_RATE_88200 |
1733						 SNDRV_PCM_RATE_96000,
1734					.rate_min = 44100,
1735					.rate_max = 96000,
1736					.nr_rates = 4,
1737					.rate_table = (unsigned int[]) {
1738						44100, 48000, 88200, 96000
1739					}
1740				}
1741			},
1742			/* interface 3 (MIDI) is standard compliant */
1743			QUIRK_COMPOSITE_END
 
 
1744		}
1745	}
1746},
1747{
1748	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2081),
1749	QUIRK_DRIVER_INFO {
1750		/* .vendor_name = "M-Audio", */
1751		/* .product_name = "Fast Track Ultra 8R", */
1752		QUIRK_DATA_COMPOSITE {
1753			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
 
 
 
 
1754			{
1755				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
1756					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1757					.channels = 8,
1758					.iface = 1,
1759					.altsetting = 1,
1760					.altset_idx = 1,
1761					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1762					.endpoint = 0x01,
1763					.ep_attr = 0x09,
1764					.rates = SNDRV_PCM_RATE_44100 |
1765						 SNDRV_PCM_RATE_48000 |
1766						 SNDRV_PCM_RATE_88200 |
1767						 SNDRV_PCM_RATE_96000,
1768					.rate_min = 44100,
1769					.rate_max = 96000,
1770					.nr_rates = 4,
1771					.rate_table = (unsigned int[]) {
1772							44100, 48000, 88200, 96000
1773					}
1774				}
1775			},
1776			{
1777				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
1778					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1779					.channels = 8,
1780					.iface = 2,
1781					.altsetting = 1,
1782					.altset_idx = 1,
1783					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
1784					.endpoint = 0x81,
1785					.ep_attr = 0x05,
1786					.rates = SNDRV_PCM_RATE_44100 |
1787						 SNDRV_PCM_RATE_48000 |
1788						 SNDRV_PCM_RATE_88200 |
1789						 SNDRV_PCM_RATE_96000,
1790					.rate_min = 44100,
1791					.rate_max = 96000,
1792					.nr_rates = 4,
1793					.rate_table = (unsigned int[]) {
1794						44100, 48000, 88200, 96000
1795					}
1796				}
1797			},
1798			/* interface 3 (MIDI) is standard compliant */
1799			QUIRK_COMPOSITE_END
 
 
1800		}
1801	}
1802},
1803
1804/* Casio devices */
1805{
1806	USB_DEVICE(0x07cf, 0x6801),
1807	QUIRK_DRIVER_INFO {
1808		.vendor_name = "Casio",
1809		.product_name = "PL-40R",
1810		QUIRK_DATA_MIDI_YAMAHA(0)
 
1811	}
1812},
1813{
1814	/* this ID is used by several devices without a product ID */
1815	USB_DEVICE(0x07cf, 0x6802),
1816	QUIRK_DRIVER_INFO {
1817		.vendor_name = "Casio",
1818		.product_name = "Keyboard",
1819		QUIRK_DATA_MIDI_YAMAHA(0)
 
1820	}
1821},
1822
1823/* Mark of the Unicorn devices */
1824{
1825	/* thanks to Robert A. Lerche <ral 'at' msbit.com> */
1826	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
1827		       USB_DEVICE_ID_MATCH_PRODUCT |
1828		       USB_DEVICE_ID_MATCH_DEV_SUBCLASS,
1829	.idVendor = 0x07fd,
1830	.idProduct = 0x0001,
1831	.bDeviceSubClass = 2,
1832	QUIRK_DRIVER_INFO {
1833		.vendor_name = "MOTU",
1834		.product_name = "Fastlane",
1835		QUIRK_DATA_COMPOSITE {
1836			{ QUIRK_DATA_RAW_BYTES(0) },
1837			{ QUIRK_DATA_IGNORE(1) },
1838			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
1839		}
1840	}
1841},
1842
1843/* Emagic devices */
1844{
1845	USB_DEVICE(0x086a, 0x0001),
1846	QUIRK_DRIVER_INFO {
1847		.vendor_name = "Emagic",
1848		.product_name = "Unitor8",
1849		QUIRK_DATA_MIDI_EMAGIC(2) {
 
 
1850			.out_cables = 0x80ff,
1851			.in_cables  = 0x80ff
1852		}
1853	}
1854},
1855{
1856	USB_DEVICE(0x086a, 0x0002),
1857	QUIRK_DRIVER_INFO {
1858		.vendor_name = "Emagic",
1859		/* .product_name = "AMT8", */
1860		QUIRK_DATA_MIDI_EMAGIC(2) {
 
 
1861			.out_cables = 0x80ff,
1862			.in_cables  = 0x80ff
1863		}
1864	}
1865},
1866{
1867	USB_DEVICE(0x086a, 0x0003),
1868	QUIRK_DRIVER_INFO {
1869		.vendor_name = "Emagic",
1870		/* .product_name = "MT4", */
1871		QUIRK_DATA_MIDI_EMAGIC(2) {
 
 
1872			.out_cables = 0x800f,
1873			.in_cables  = 0x8003
1874		}
1875	}
1876},
1877
1878/* KORG devices */
1879{
1880	USB_DEVICE_VENDOR_SPEC(0x0944, 0x0200),
1881	QUIRK_DRIVER_INFO {
1882		.vendor_name = "KORG, Inc.",
1883		/* .product_name = "PANDORA PX5D", */
1884		QUIRK_DATA_STANDARD_MIDI(3)
 
1885	}
1886},
1887
1888{
1889	USB_DEVICE_VENDOR_SPEC(0x0944, 0x0201),
1890	QUIRK_DRIVER_INFO {
1891		.vendor_name = "KORG, Inc.",
1892		/* .product_name = "ToneLab ST", */
1893		QUIRK_DATA_STANDARD_MIDI(3)
1894	}
1895},
1896
1897{
1898	USB_DEVICE_VENDOR_SPEC(0x0944, 0x0204),
1899	QUIRK_DRIVER_INFO {
1900		.vendor_name = "KORG, Inc.",
1901		/* .product_name = "ToneLab EX", */
1902		QUIRK_DATA_STANDARD_MIDI(3)
1903	}
1904},
1905
1906/* AKAI devices */
1907{
1908	USB_DEVICE(0x09e8, 0x0062),
1909	QUIRK_DRIVER_INFO {
1910		.vendor_name = "AKAI",
1911		.product_name = "MPD16",
1912		.ifnum = 0,
1913		.type = QUIRK_MIDI_AKAI,
1914	}
1915},
1916
1917{
1918	/* Akai MPC Element */
1919	USB_DEVICE(0x09e8, 0x0021),
1920	QUIRK_DRIVER_INFO {
1921		QUIRK_DATA_COMPOSITE {
1922			{ QUIRK_DATA_IGNORE(0) },
1923			{ QUIRK_DATA_STANDARD_MIDI(1) },
1924			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
1925		}
1926	}
1927},
1928
1929/* Steinberg devices */
1930{
1931	/* Steinberg MI2 */
1932	USB_DEVICE_VENDOR_SPEC(0x0a4e, 0x2040),
1933	QUIRK_DRIVER_INFO {
1934		QUIRK_DATA_COMPOSITE {
1935			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1936			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1937			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 
 
 
 
 
 
 
 
 
 
 
1938			{
1939				QUIRK_DATA_MIDI_FIXED_ENDPOINT(3) {
 
 
1940					.out_cables = 0x0001,
1941					.in_cables  = 0x0001
1942				}
1943			},
1944			QUIRK_COMPOSITE_END
 
 
1945		}
1946	}
1947},
1948{
1949	/* Steinberg MI4 */
1950	USB_DEVICE_VENDOR_SPEC(0x0a4e, 0x4040),
1951	QUIRK_DRIVER_INFO {
1952		QUIRK_DATA_COMPOSITE {
1953			{ QUIRK_DATA_STANDARD_AUDIO(0) },
1954			{ QUIRK_DATA_STANDARD_AUDIO(1) },
1955			{ QUIRK_DATA_STANDARD_AUDIO(2) },
 
 
 
 
 
 
 
 
 
 
 
1956			{
1957				QUIRK_DATA_MIDI_FIXED_ENDPOINT(3) {
 
 
1958					.out_cables = 0x0001,
1959					.in_cables  = 0x0001
1960				}
1961			},
1962			QUIRK_COMPOSITE_END
 
 
1963		}
1964	}
1965},
1966
1967/* TerraTec devices */
1968{
1969	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0012),
1970	QUIRK_DRIVER_INFO {
1971		.vendor_name = "TerraTec",
1972		.product_name = "PHASE 26",
1973		QUIRK_DATA_STANDARD_MIDI(3)
 
1974	}
1975},
1976{
1977	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0013),
1978	QUIRK_DRIVER_INFO {
1979		.vendor_name = "TerraTec",
1980		.product_name = "PHASE 26",
1981		QUIRK_DATA_STANDARD_MIDI(3)
 
1982	}
1983},
1984{
1985	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0014),
1986	QUIRK_DRIVER_INFO {
1987		.vendor_name = "TerraTec",
1988		.product_name = "PHASE 26",
1989		QUIRK_DATA_STANDARD_MIDI(3)
 
 
 
 
 
 
 
 
 
1990	}
1991},
1992{
1993	USB_DEVICE(0x0ccd, 0x0035),
1994	QUIRK_DRIVER_INFO {
1995		.vendor_name = "Miditech",
1996		.product_name = "Play'n Roll",
1997		.ifnum = 0,
1998		.type = QUIRK_MIDI_CME
1999	}
2000},
2001
2002/* Stanton ScratchAmp */
2003{ USB_DEVICE(0x103d, 0x0100) },
2004{ USB_DEVICE(0x103d, 0x0101) },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2005
2006/* Novation EMS devices */
2007{
2008	USB_DEVICE_VENDOR_SPEC(0x1235, 0x0001),
2009	QUIRK_DRIVER_INFO {
2010		.vendor_name = "Novation",
2011		.product_name = "ReMOTE Audio/XStation",
2012		.ifnum = 4,
2013		.type = QUIRK_MIDI_NOVATION
2014	}
2015},
2016{
2017	USB_DEVICE_VENDOR_SPEC(0x1235, 0x0002),
2018	QUIRK_DRIVER_INFO {
2019		.vendor_name = "Novation",
2020		.product_name = "Speedio",
2021		.ifnum = 3,
2022		.type = QUIRK_MIDI_NOVATION
2023	}
2024},
2025{
2026	USB_DEVICE(0x1235, 0x000a),
2027	QUIRK_DRIVER_INFO {
2028		/* .vendor_name = "Novation", */
2029		/* .product_name = "Nocturn", */
2030		QUIRK_DATA_RAW_BYTES(0)
 
2031	}
2032},
2033{
2034	USB_DEVICE(0x1235, 0x000e),
2035	QUIRK_DRIVER_INFO {
2036		/* .vendor_name = "Novation", */
2037		/* .product_name = "Launchpad", */
2038		QUIRK_DATA_RAW_BYTES(0)
 
2039	}
2040},
2041{
2042	USB_DEVICE(0x1235, 0x0010),
2043	QUIRK_DRIVER_INFO {
2044		.vendor_name = "Focusrite",
2045		.product_name = "Saffire 6 USB",
2046		QUIRK_DATA_COMPOSITE {
2047			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
2048			{
2049				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
2050					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2051					.channels = 4,
2052					.iface = 0,
2053					.altsetting = 1,
2054					.altset_idx = 1,
2055					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2056					.endpoint = 0x01,
2057					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2058					.datainterval = 1,
2059					.maxpacksize = 0x024c,
2060					.rates = SNDRV_PCM_RATE_44100 |
2061						 SNDRV_PCM_RATE_48000,
2062					.rate_min = 44100,
2063					.rate_max = 48000,
2064					.nr_rates = 2,
2065					.rate_table = (unsigned int[]) {
2066						44100, 48000
2067					},
2068					.sync_ep = 0x82,
2069					.sync_iface = 0,
2070					.sync_altsetting = 1,
2071					.sync_ep_idx = 1,
2072					.implicit_fb = 1,
2073				}
2074			},
2075			{
2076				QUIRK_DATA_AUDIOFORMAT(0) {
2077					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2078					.channels = 2,
2079					.iface = 0,
2080					.altsetting = 1,
2081					.altset_idx = 1,
2082					.attributes = 0,
2083					.endpoint = 0x82,
2084					.ep_idx = 1,
2085					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2086					.datainterval = 1,
2087					.maxpacksize = 0x0126,
2088					.rates = SNDRV_PCM_RATE_44100 |
2089						 SNDRV_PCM_RATE_48000,
2090					.rate_min = 44100,
2091					.rate_max = 48000,
2092					.nr_rates = 2,
2093					.rate_table = (unsigned int[]) {
2094						44100, 48000
2095					}
2096				}
2097			},
2098			{ QUIRK_DATA_RAW_BYTES(1) },
2099			QUIRK_COMPOSITE_END
 
2100		}
2101	}
2102},
2103{
2104	USB_DEVICE(0x1235, 0x0018),
2105	QUIRK_DRIVER_INFO {
2106		.vendor_name = "Novation",
2107		.product_name = "Twitch",
2108		QUIRK_DATA_COMPOSITE {
 
 
2109			{
2110				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
2111					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2112					.channels = 4,
2113					.iface = 0,
2114					.altsetting = 1,
2115					.altset_idx = 1,
2116					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2117					.endpoint = 0x01,
2118					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2119					.rates = SNDRV_PCM_RATE_44100 |
2120						 SNDRV_PCM_RATE_48000,
2121					.rate_min = 44100,
2122					.rate_max = 48000,
2123					.nr_rates = 2,
2124					.rate_table = (unsigned int[]) {
2125						44100, 48000
2126					}
2127				}
2128			},
2129			{ QUIRK_DATA_RAW_BYTES(1) },
2130			QUIRK_COMPOSITE_END
 
 
 
 
 
2131		}
2132	}
2133},
2134{
2135	USB_DEVICE_VENDOR_SPEC(0x1235, 0x4661),
2136	QUIRK_DRIVER_INFO {
2137		.vendor_name = "Novation",
2138		.product_name = "ReMOTE25",
2139		.ifnum = 0,
2140		.type = QUIRK_MIDI_NOVATION
2141	}
2142},
2143
2144/* Access Music devices */
2145{
2146	/* VirusTI Desktop */
2147	USB_DEVICE_VENDOR_SPEC(0x133e, 0x0815),
2148	QUIRK_DRIVER_INFO {
2149		QUIRK_DATA_COMPOSITE {
 
 
2150			{
2151				QUIRK_DATA_MIDI_FIXED_ENDPOINT(3) {
 
 
2152					.out_cables = 0x0003,
2153					.in_cables  = 0x0003
2154				}
2155			},
2156			{ QUIRK_DATA_IGNORE(4) },
2157			QUIRK_COMPOSITE_END
 
 
 
 
 
2158		}
2159	}
2160},
2161
 
 
 
 
 
 
 
 
 
 
 
2162/* Native Instruments MK2 series */
2163{
2164	/* Komplete Audio 6 */
2165	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2166	.idVendor = 0x17cc,
2167	.idProduct = 0x1000,
2168},
2169{
2170	/* Traktor Audio 6 */
2171	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2172	.idVendor = 0x17cc,
2173	.idProduct = 0x1010,
2174},
2175{
2176	/* Traktor Audio 10 */
2177	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2178	.idVendor = 0x17cc,
2179	.idProduct = 0x1020,
2180},
2181
2182/* QinHeng devices */
2183{
2184	USB_DEVICE(0x1a86, 0x752d),
2185	QUIRK_DRIVER_INFO {
2186		.vendor_name = "QinHeng",
2187		.product_name = "CH345",
2188		.ifnum = 1,
2189		.type = QUIRK_MIDI_CH345
2190	}
2191},
2192
2193/* KeithMcMillen Stringport */
2194{ USB_DEVICE(0x1f38, 0x0001) }, /* FIXME: should be more restrictive matching */
 
 
 
2195
2196/* Miditech devices */
2197{
2198	USB_DEVICE(0x4752, 0x0011),
2199	QUIRK_DRIVER_INFO {
2200		.vendor_name = "Miditech",
2201		.product_name = "Midistart-2",
2202		.ifnum = 0,
2203		.type = QUIRK_MIDI_CME
2204	}
2205},
2206
2207/* Central Music devices */
2208{
2209	/* this ID used by both Miditech MidiStudio-2 and CME UF-x */
2210	USB_DEVICE(0x7104, 0x2202),
2211	QUIRK_DRIVER_INFO {
2212		.ifnum = 0,
2213		.type = QUIRK_MIDI_CME
2214	}
2215},
2216
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2217/* Digidesign Mbox */
2218{
2219	/* Thanks to Clemens Ladisch <clemens@ladisch.de> */
2220	USB_DEVICE(0x0dba, 0x1000),
2221	QUIRK_DRIVER_INFO {
2222		.vendor_name = "Digidesign",
2223		.product_name = "MBox",
2224		QUIRK_DATA_COMPOSITE{
2225			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
 
 
 
 
2226			{
2227				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
2228					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2229					.channels = 2,
2230					.iface = 1,
2231					.altsetting = 1,
2232					.altset_idx = 1,
2233					.attributes = 0x4,
2234					.endpoint = 0x02,
2235					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2236						USB_ENDPOINT_SYNC_SYNC,
2237					.maxpacksize = 0x130,
2238					.rates = SNDRV_PCM_RATE_48000,
2239					.rate_min = 48000,
2240					.rate_max = 48000,
2241					.nr_rates = 1,
2242					.rate_table = (unsigned int[]) {
2243						48000
2244					}
2245				}
2246			},
2247			{
2248				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
2249					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2250					.channels = 2,
2251					.iface = 1,
2252					.altsetting = 1,
2253					.altset_idx = 1,
2254					.attributes = 0x4,
2255					.endpoint = 0x81,
2256					.ep_idx = 1,
2257					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2258						USB_ENDPOINT_SYNC_ASYNC,
2259					.maxpacksize = 0x130,
2260					.rates = SNDRV_PCM_RATE_48000,
2261					.rate_min = 48000,
2262					.rate_max = 48000,
2263					.nr_rates = 1,
2264					.rate_table = (unsigned int[]) {
2265						48000
2266					}
2267				}
2268			},
2269			QUIRK_COMPOSITE_END
 
 
2270		}
2271	}
2272},
2273
2274/* DIGIDESIGN MBOX 2 */
2275{
2276	USB_DEVICE(0x0dba, 0x3000),
2277	QUIRK_DRIVER_INFO {
2278		.vendor_name = "Digidesign",
2279		.product_name = "Mbox 2",
2280		QUIRK_DATA_COMPOSITE {
2281			{ QUIRK_DATA_IGNORE(0) },
2282			{ QUIRK_DATA_IGNORE(1) },
2283			{
2284				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
 
 
 
 
 
 
 
 
2285					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2286					.channels = 2,
2287					.iface = 2,
2288					.altsetting = 2,
2289					.altset_idx = 1,
2290					.attributes = 0x00,
2291					.endpoint = 0x03,
2292					.ep_attr = USB_ENDPOINT_SYNC_ASYNC,
2293					.rates = SNDRV_PCM_RATE_48000,
2294					.rate_min = 48000,
2295					.rate_max = 48000,
2296					.nr_rates = 1,
2297					.rate_table = (unsigned int[]) {
2298						48000
2299					}
2300				}
2301			},
2302			{ QUIRK_DATA_IGNORE(3) },
2303			{
2304				QUIRK_DATA_AUDIOFORMAT(4) {
2305					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
 
 
 
 
 
 
2306					.channels = 2,
2307					.iface = 4,
2308					.altsetting = 2,
2309					.altset_idx = 1,
2310					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2311					.endpoint = 0x85,
2312					.ep_attr = USB_ENDPOINT_SYNC_SYNC,
2313					.rates = SNDRV_PCM_RATE_48000,
2314					.rate_min = 48000,
2315					.rate_max = 48000,
2316					.nr_rates = 1,
2317					.rate_table = (unsigned int[]) {
2318						48000
2319					}
2320				}
2321			},
2322			{ QUIRK_DATA_IGNORE(5) },
2323			{
2324				QUIRK_DATA_MIDI_MIDIMAN(6) {
 
 
 
 
 
 
2325					.out_ep =  0x02,
2326					.out_cables = 0x0001,
2327					.in_ep = 0x81,
2328					.in_interval = 0x01,
2329					.in_cables = 0x0001
2330				}
2331			},
2332			QUIRK_COMPOSITE_END
2333		}
2334	}
2335},
2336/* DIGIDESIGN MBOX 3 */
2337{
2338	USB_DEVICE(0x0dba, 0x5000),
2339	QUIRK_DRIVER_INFO {
2340		.vendor_name = "Digidesign",
2341		.product_name = "Mbox 3",
2342		QUIRK_DATA_COMPOSITE {
2343			{ QUIRK_DATA_IGNORE(0) },
2344			{ QUIRK_DATA_IGNORE(1) },
2345			{
2346				QUIRK_DATA_AUDIOFORMAT(2) {
2347					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2348					.fmt_bits = 24,
2349					.channels = 4,
2350					.iface = 2,
2351					.altsetting = 1,
2352					.altset_idx = 1,
2353					.attributes = 0x00,
2354					.endpoint = USB_RECIP_INTERFACE | USB_DIR_OUT,
2355					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2356						USB_ENDPOINT_SYNC_ASYNC,
2357					.rates = SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
2358							SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000,
2359					.rate_min = 44100,
2360					.rate_max = 96000,
2361					.nr_rates = 4,
2362					.rate_table = (unsigned int[]) {
2363						44100, 48000, 88200, 96000
2364					},
2365					.sync_ep = USB_RECIP_INTERFACE | USB_DIR_IN,
2366					.sync_iface = 3,
2367					.sync_altsetting = 1,
2368					.sync_ep_idx = 1,
2369					.implicit_fb = 1,
2370				}
2371			},
2372			{
2373				QUIRK_DATA_AUDIOFORMAT(3) {
2374					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2375					.fmt_bits = 24,
2376					.channels = 4,
2377					.iface = 3,
2378					.altsetting = 1,
2379					.altset_idx = 1,
2380					.attributes = 0x00,
2381					.endpoint = USB_RECIP_INTERFACE | USB_DIR_IN,
2382					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2383						USB_ENDPOINT_SYNC_ASYNC,
2384					.maxpacksize = 0x009c,
2385					.rates = SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
2386							SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000,
2387					.rate_min = 44100,
2388					.rate_max = 96000,
2389					.nr_rates = 4,
2390					.rate_table = (unsigned int[]) {
2391						44100, 48000, 88200, 96000
2392					},
2393					.implicit_fb = 0,
2394				}
2395			},
2396			{
2397				QUIRK_DATA_MIDI_FIXED_ENDPOINT(4) {
2398					.out_cables = 0x0001,
2399					.in_cables  = 0x0001
2400				}
2401			},
2402			QUIRK_COMPOSITE_END
2403		}
2404	}
2405},
2406{
2407	/* Tascam US122 MKII - playback-only support */
2408	USB_DEVICE_VENDOR_SPEC(0x0644, 0x8021),
2409	QUIRK_DRIVER_INFO {
 
 
 
2410		.vendor_name = "TASCAM",
2411		.product_name = "US122 MKII",
2412		QUIRK_DATA_COMPOSITE {
2413			{ QUIRK_DATA_IGNORE(0) },
 
 
 
 
 
2414			{
2415				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
2416					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2417					.channels = 2,
2418					.iface = 1,
2419					.altsetting = 1,
2420					.altset_idx = 1,
2421					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2422					.endpoint = 0x02,
2423					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2424					.rates = SNDRV_PCM_RATE_44100 |
2425						 SNDRV_PCM_RATE_48000 |
2426						 SNDRV_PCM_RATE_88200 |
2427						 SNDRV_PCM_RATE_96000,
2428					.rate_min = 44100,
2429					.rate_max = 96000,
2430					.nr_rates = 4,
2431					.rate_table = (unsigned int[]) {
2432						44100, 48000, 88200, 96000
2433					}
2434				}
2435			},
2436			QUIRK_COMPOSITE_END
2437		}
2438	}
2439},
2440
2441/* Denon DN-X1600 */
2442{
2443	USB_AUDIO_DEVICE(0x154e, 0x500e),
2444	QUIRK_DRIVER_INFO {
2445		.vendor_name = "Denon",
2446		.product_name = "DN-X1600",
2447		QUIRK_DATA_COMPOSITE{
2448			{ QUIRK_DATA_IGNORE(0) },
2449			{
2450				QUIRK_DATA_AUDIOFORMAT(1) {
2451					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2452					.channels = 8,
2453					.iface = 1,
2454					.altsetting = 1,
2455					.altset_idx = 1,
2456					.attributes = 0x0,
2457					.endpoint = 0x01,
2458					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2459						USB_ENDPOINT_SYNC_ADAPTIVE,
2460					.maxpacksize = 0x138,
2461					.rates = SNDRV_PCM_RATE_48000,
2462					.rate_min = 48000,
2463					.rate_max = 48000,
2464					.nr_rates = 1,
2465					.rate_table = (unsigned int[]) {
2466						48000
2467					}
2468				}
2469			},
2470			{
2471				QUIRK_DATA_AUDIOFORMAT(2) {
2472					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2473					.channels = 8,
2474					.iface = 2,
2475					.altsetting = 1,
2476					.altset_idx = 1,
2477					.attributes = 0x0,
2478					.endpoint = 0x85,
2479					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2480						USB_ENDPOINT_SYNC_ADAPTIVE,
2481					.maxpacksize = 0x138,
2482					.rates = SNDRV_PCM_RATE_48000,
2483					.rate_min = 48000,
2484					.rate_max = 48000,
2485					.nr_rates = 1,
2486					.rate_table = (unsigned int[]) {
2487						48000
2488					}
2489				}
2490			},
2491			{ QUIRK_DATA_STANDARD_MIDI(4) },
2492			QUIRK_COMPOSITE_END
2493		}
2494	}
2495},
2496
2497/* Microsoft XboxLive Headset/Xbox Communicator */
2498{
2499	USB_DEVICE(0x045e, 0x0283),
2500	.bInterfaceClass = USB_CLASS_PER_INTERFACE,
2501	QUIRK_DRIVER_INFO {
2502		.vendor_name = "Microsoft",
2503		.product_name = "XboxLive Headset/Xbox Communicator",
2504		QUIRK_DATA_COMPOSITE {
 
 
2505			{
2506				/* playback */
2507				QUIRK_DATA_AUDIOFORMAT(0) {
 
 
2508					.formats = SNDRV_PCM_FMTBIT_S16_LE,
2509					.channels = 1,
2510					.iface = 0,
2511					.altsetting = 0,
2512					.altset_idx = 0,
2513					.attributes = 0,
2514					.endpoint = 0x04,
2515					.ep_attr = 0x05,
2516					.rates = SNDRV_PCM_RATE_CONTINUOUS,
2517					.rate_min = 22050,
2518					.rate_max = 22050
2519				}
2520			},
2521			{
2522				/* capture */
2523				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
2524					.formats = SNDRV_PCM_FMTBIT_S16_LE,
2525					.channels = 1,
2526					.iface = 1,
2527					.altsetting = 0,
2528					.altset_idx = 0,
2529					.attributes = 0,
2530					.endpoint = 0x85,
2531					.ep_attr = 0x05,
2532					.rates = SNDRV_PCM_RATE_CONTINUOUS,
2533					.rate_min = 16000,
2534					.rate_max = 16000
2535				}
2536			},
2537			QUIRK_COMPOSITE_END
 
 
2538		}
2539	}
2540},
2541
2542/* Reloop Play */
2543{
2544	USB_DEVICE(0x200c, 0x100b),
2545	.bInterfaceClass = USB_CLASS_PER_INTERFACE,
2546	QUIRK_DRIVER_INFO {
2547		QUIRK_DATA_COMPOSITE {
2548			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
2549			{
2550				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
 
 
 
 
2551					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2552					.channels = 4,
2553					.iface = 1,
2554					.altsetting = 1,
2555					.altset_idx = 1,
2556					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2557					.endpoint = 0x01,
2558					.ep_attr = USB_ENDPOINT_SYNC_ADAPTIVE,
2559					.rates = SNDRV_PCM_RATE_44100 |
2560						 SNDRV_PCM_RATE_48000,
2561					.rate_min = 44100,
2562					.rate_max = 48000,
2563					.nr_rates = 2,
2564					.rate_table = (unsigned int[]) {
2565						44100, 48000
2566					}
2567				}
2568			},
2569			QUIRK_COMPOSITE_END
 
 
2570		}
2571	}
2572},
2573
2574{
2575	/*
2576	 * ZOOM R16/24 in audio interface mode.
2577	 * Playback requires an extra four byte LE length indicator
2578	 * at the start of each isochronous packet. This quirk is
2579	 * enabled in create_standard_audio_quirk().
2580	 */
2581	USB_DEVICE(0x1686, 0x00dd),
2582	QUIRK_DRIVER_INFO {
2583		QUIRK_DATA_COMPOSITE {
2584			{ QUIRK_DATA_STANDARD_AUDIO(1) }, /* Playback  */
2585			{ QUIRK_DATA_STANDARD_AUDIO(2) }, /* Capture */
2586			{ QUIRK_DATA_STANDARD_MIDI(3) }, /* Midi */
2587			QUIRK_COMPOSITE_END
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2588		}
2589	}
2590},
2591
2592{
2593	/*
2594	 * Some USB MIDI devices don't have an audio control interface,
2595	 * so we have to grab MIDI streaming interfaces here.
2596	 */
2597	.match_flags = USB_DEVICE_ID_MATCH_INT_CLASS |
2598		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
2599	.bInterfaceClass = USB_CLASS_AUDIO,
2600	.bInterfaceSubClass = USB_SUBCLASS_MIDISTREAMING,
2601	QUIRK_DRIVER_INFO {
2602		QUIRK_DATA_STANDARD_MIDI(QUIRK_ANY_INTERFACE)
 
2603	}
2604},
2605
2606/* Rane SL-1 */
2607{
2608	USB_DEVICE(0x13e5, 0x0001),
2609	QUIRK_DRIVER_INFO {
2610		QUIRK_DATA_STANDARD_AUDIO(QUIRK_ANY_INTERFACE)
2611        }
 
 
 
 
 
2612},
2613
2614/* disabled due to regression for other devices;
2615 * see https://bugzilla.kernel.org/show_bug.cgi?id=199905
2616 */
2617#if 0
2618{
2619	/*
2620	 * Nura's first gen headphones use Cambridge Silicon Radio's vendor
2621	 * ID, but it looks like the product ID actually is only for Nura.
2622	 * The capture interface does not work at all (even on Windows),
2623	 * and only the 48 kHz sample rate works for the playback interface.
2624	 */
2625	USB_DEVICE(0x0a12, 0x1243),
2626	QUIRK_DRIVER_INFO {
2627		QUIRK_DATA_COMPOSITE {
2628			{ QUIRK_DATA_STANDARD_MIXER(0) },
2629			{ QUIRK_DATA_IGNORE(1) }, /* Capture */
 
 
 
 
 
 
 
 
 
2630			/* Playback */
2631			{
2632				QUIRK_DATA_AUDIOFORMAT(2) {
 
 
2633					.formats = SNDRV_PCM_FMTBIT_S16_LE,
2634					.channels = 2,
2635					.iface = 2,
2636					.altsetting = 1,
2637					.altset_idx = 1,
2638					.attributes = UAC_EP_CS_ATTR_FILL_MAX |
2639						UAC_EP_CS_ATTR_SAMPLE_RATE,
2640					.endpoint = 0x03,
2641					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2642					.rates = SNDRV_PCM_RATE_48000,
2643					.rate_min = 48000,
2644					.rate_max = 48000,
2645					.nr_rates = 1,
2646					.rate_table = (unsigned int[]) {
2647						48000
2648					}
2649				}
2650			},
2651			QUIRK_COMPOSITE_END
2652		}
2653	}
2654},
2655#endif /* disabled */
2656
2657{
2658	/*
2659	 * Bower's & Wilkins PX headphones only support the 48 kHz sample rate
2660	 * even though it advertises more. The capture interface doesn't work
2661	 * even on windows.
2662	 */
2663	USB_DEVICE(0x19b5, 0x0021),
2664	QUIRK_DRIVER_INFO {
2665		QUIRK_DATA_COMPOSITE {
2666			{ QUIRK_DATA_STANDARD_MIXER(0) },
 
 
 
 
 
 
 
 
 
 
2667			/* Playback */
2668			{
2669				QUIRK_DATA_AUDIOFORMAT(1) {
 
 
2670					.formats = SNDRV_PCM_FMTBIT_S16_LE,
2671					.channels = 2,
2672					.iface = 1,
2673					.altsetting = 1,
2674					.altset_idx = 1,
2675					.attributes = UAC_EP_CS_ATTR_FILL_MAX |
2676						UAC_EP_CS_ATTR_SAMPLE_RATE,
2677					.endpoint = 0x03,
2678					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2679					.rates = SNDRV_PCM_RATE_48000,
2680					.rate_min = 48000,
2681					.rate_max = 48000,
2682					.nr_rates = 1,
2683					.rate_table = (unsigned int[]) {
2684						48000
2685					}
2686				}
2687			},
2688			QUIRK_COMPOSITE_END
2689		}
2690	}
2691},
2692/* MOTU Microbook II */
2693{
2694	USB_DEVICE_VENDOR_SPEC(0x07fd, 0x0004),
2695	QUIRK_DRIVER_INFO {
2696		.vendor_name = "MOTU",
2697		.product_name = "MicroBookII",
2698		QUIRK_DATA_COMPOSITE {
2699			{ QUIRK_DATA_STANDARD_MIXER(0) },
2700			{
2701				QUIRK_DATA_AUDIOFORMAT(0) {
2702					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2703					.channels = 6,
2704					.iface = 0,
2705					.altsetting = 1,
2706					.altset_idx = 1,
2707					.attributes = 0,
2708					.endpoint = 0x84,
2709					.rates = SNDRV_PCM_RATE_96000,
2710					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2711						   USB_ENDPOINT_SYNC_ASYNC,
2712					.rate_min = 96000,
2713					.rate_max = 96000,
2714					.nr_rates = 1,
2715					.maxpacksize = 0x00d8,
2716					.rate_table = (unsigned int[]) {
2717						96000
2718					}
2719				}
2720			},
2721			{
2722				QUIRK_DATA_AUDIOFORMAT(0) {
2723					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2724					.channels = 8,
2725					.iface = 0,
2726					.altsetting = 1,
2727					.altset_idx = 1,
2728					.attributes = 0,
2729					.endpoint = 0x03,
2730					.ep_idx = 1,
2731					.rates = SNDRV_PCM_RATE_96000,
2732					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2733						   USB_ENDPOINT_SYNC_ASYNC,
2734					.rate_min = 96000,
2735					.rate_max = 96000,
2736					.nr_rates = 1,
2737					.maxpacksize = 0x0120,
2738					.rate_table = (unsigned int[]) {
2739						96000
2740					}
2741				}
2742			},
2743			QUIRK_COMPOSITE_END
2744		}
2745	}
2746},
2747{
2748	/*
2749	 * PIONEER DJ DDJ-SX3
2750	 * PCM is 12 channels out, 10 channels in @ 44.1 fixed
2751	 * interface 0, vendor class alt setting 1 for endpoints 5 and 0x86
2752	 * The feedback for the output is the input.
2753	 */
2754	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x0023),
2755	QUIRK_DRIVER_INFO {
2756		QUIRK_DATA_COMPOSITE {
2757			{
2758				QUIRK_DATA_AUDIOFORMAT(0) {
2759					.formats = SNDRV_PCM_FMTBIT_S32_LE,
2760					.channels = 12,
2761					.iface = 0,
2762					.altsetting = 1,
2763					.altset_idx = 1,
2764					.endpoint = 0x05,
2765					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2766						   USB_ENDPOINT_SYNC_ASYNC,
2767					.rates = SNDRV_PCM_RATE_44100,
2768					.rate_min = 44100,
2769					.rate_max = 44100,
2770					.nr_rates = 1,
2771					.rate_table = (unsigned int[]) { 44100 }
2772				}
2773			},
2774			{
2775				QUIRK_DATA_AUDIOFORMAT(0) {
2776					.formats = SNDRV_PCM_FMTBIT_S32_LE,
2777					.channels = 10,
2778					.iface = 0,
2779					.altsetting = 1,
2780					.altset_idx = 1,
2781					.endpoint = 0x86,
2782					.ep_idx = 1,
2783					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2784						 USB_ENDPOINT_SYNC_ASYNC|
2785						 USB_ENDPOINT_USAGE_IMPLICIT_FB,
2786					.rates = SNDRV_PCM_RATE_44100,
2787					.rate_min = 44100,
2788					.rate_max = 44100,
2789					.nr_rates = 1,
2790					.rate_table = (unsigned int[]) { 44100 }
2791				}
2792			},
2793			QUIRK_COMPOSITE_END
2794		}
2795	}
2796},
2797{
2798	/*
2799	 * Pioneer DJ DJM-250MK2
2800	 * PCM is 8 channels out @ 48 fixed (endpoint 0x01)
2801	 * and 8 channels in @ 48 fixed (endpoint 0x82).
2802	 *
2803	 * Both playback and recording is working, even simultaneously.
2804	 *
2805	 * Playback channels could be mapped to:
2806	 *  - CH1
2807	 *  - CH2
2808	 *  - AUX
2809	 *
2810	 * Recording channels could be mapped to:
2811	 *  - Post CH1 Fader
2812	 *  - Post CH2 Fader
2813	 *  - Cross Fader A
2814	 *  - Cross Fader B
2815	 *  - MIC
2816	 *  - AUX
2817	 *  - REC OUT
2818	 *
2819	 * There is remaining problem with recording directly from PHONO/LINE.
2820	 * If we map a channel to:
2821	 *  - CH1 Control Tone PHONO
2822	 *  - CH1 Control Tone LINE
2823	 *  - CH2 Control Tone PHONO
2824	 *  - CH2 Control Tone LINE
2825	 * it is silent.
2826	 * There is no signal even on other operating systems with official drivers.
2827	 * The signal appears only when a supported application is started.
2828	 * This needs to be investigated yet...
2829	 * (there is quite a lot communication on the USB in both directions)
2830	 *
2831	 * In current version this mixer could be used for playback
2832	 * and for recording from vinyls (through Post CH* Fader)
2833	 * but not for DVS (Digital Vinyl Systems) like in Mixxx.
2834	 */
2835	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x0017),
2836	QUIRK_DRIVER_INFO {
2837		QUIRK_DATA_COMPOSITE {
2838			{
2839				QUIRK_DATA_AUDIOFORMAT(0) {
2840					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2841					.channels = 8, // outputs
2842					.iface = 0,
2843					.altsetting = 1,
2844					.altset_idx = 1,
2845					.endpoint = 0x01,
2846					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2847						USB_ENDPOINT_SYNC_ASYNC,
2848					.rates = SNDRV_PCM_RATE_48000,
2849					.rate_min = 48000,
2850					.rate_max = 48000,
2851					.nr_rates = 1,
2852					.rate_table = (unsigned int[]) { 48000 }
2853					}
2854			},
2855			{
2856				QUIRK_DATA_AUDIOFORMAT(0) {
2857					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2858					.channels = 8, // inputs
2859					.iface = 0,
2860					.altsetting = 1,
2861					.altset_idx = 1,
2862					.endpoint = 0x82,
2863					.ep_idx = 1,
2864					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2865						USB_ENDPOINT_SYNC_ASYNC|
2866						USB_ENDPOINT_USAGE_IMPLICIT_FB,
2867					.rates = SNDRV_PCM_RATE_48000,
2868					.rate_min = 48000,
2869					.rate_max = 48000,
2870					.nr_rates = 1,
2871					.rate_table = (unsigned int[]) { 48000 }
2872				}
2873			},
2874			QUIRK_COMPOSITE_END
2875		}
2876	}
2877},
2878{
2879	/*
2880	 * PIONEER DJ DDJ-RB
2881	 * PCM is 4 channels out, 2 dummy channels in @ 44.1 fixed
2882	 * The feedback for the output is the dummy input.
2883	 */
2884	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x000e),
2885	QUIRK_DRIVER_INFO {
2886		QUIRK_DATA_COMPOSITE {
2887			{
2888				QUIRK_DATA_AUDIOFORMAT(0) {
2889					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2890					.channels = 4,
2891					.iface = 0,
2892					.altsetting = 1,
2893					.altset_idx = 1,
2894					.endpoint = 0x01,
2895					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2896						   USB_ENDPOINT_SYNC_ASYNC,
2897					.rates = SNDRV_PCM_RATE_44100,
2898					.rate_min = 44100,
2899					.rate_max = 44100,
2900					.nr_rates = 1,
2901					.rate_table = (unsigned int[]) { 44100 }
2902				}
2903			},
2904			{
2905				QUIRK_DATA_AUDIOFORMAT(0) {
2906					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2907					.channels = 2,
2908					.iface = 0,
2909					.altsetting = 1,
2910					.altset_idx = 1,
2911					.endpoint = 0x82,
2912					.ep_idx = 1,
2913					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2914						 USB_ENDPOINT_SYNC_ASYNC|
2915						 USB_ENDPOINT_USAGE_IMPLICIT_FB,
2916					.rates = SNDRV_PCM_RATE_44100,
2917					.rate_min = 44100,
2918					.rate_max = 44100,
2919					.nr_rates = 1,
2920					.rate_table = (unsigned int[]) { 44100 }
2921				}
2922			},
2923			QUIRK_COMPOSITE_END
2924		}
2925	}
2926},
2927
2928{
2929	/*
2930	 * PIONEER DJ DDJ-RR
2931	 * PCM is 6 channels out & 4 channels in @ 44.1 fixed
2932	 */
2933	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x000d),
2934	QUIRK_DRIVER_INFO {
2935		QUIRK_DATA_COMPOSITE {
2936			{
2937				QUIRK_DATA_AUDIOFORMAT(0) {
2938					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2939					.channels = 6, //Master, Headphones & Booth
2940					.iface = 0,
2941					.altsetting = 1,
2942					.altset_idx = 1,
2943					.endpoint = 0x01,
2944					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2945						   USB_ENDPOINT_SYNC_ASYNC,
2946					.rates = SNDRV_PCM_RATE_44100,
2947					.rate_min = 44100,
2948					.rate_max = 44100,
2949					.nr_rates = 1,
2950					.rate_table = (unsigned int[]) { 44100 }
2951				}
2952			},
2953			{
2954				QUIRK_DATA_AUDIOFORMAT(0) {
2955					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2956					.channels = 4, //2x RCA inputs (CH1 & CH2)
2957					.iface = 0,
2958					.altsetting = 1,
2959					.altset_idx = 1,
2960					.endpoint = 0x82,
2961					.ep_idx = 1,
2962					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2963						 USB_ENDPOINT_SYNC_ASYNC|
2964						 USB_ENDPOINT_USAGE_IMPLICIT_FB,
2965					.rates = SNDRV_PCM_RATE_44100,
2966					.rate_min = 44100,
2967					.rate_max = 44100,
2968					.nr_rates = 1,
2969					.rate_table = (unsigned int[]) { 44100 }
2970				}
2971			},
2972			QUIRK_COMPOSITE_END
2973		}
2974	}
2975},
2976
2977{
2978	/*
2979	 * PIONEER DJ DDJ-SR2
2980	 * PCM is 4 channels out, 6 channels in @ 44.1 fixed
2981	 * The Feedback for the output is the input
2982	 */
2983	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x001e),
2984	QUIRK_DRIVER_INFO {
2985		QUIRK_DATA_COMPOSITE {
2986			{
2987				QUIRK_DATA_AUDIOFORMAT(0) {
2988					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2989					.channels = 4,
2990					.iface = 0,
2991					.altsetting = 1,
2992					.altset_idx = 1,
2993					.endpoint = 0x01,
2994					.ep_attr = USB_ENDPOINT_XFER_ISOC|
2995						USB_ENDPOINT_SYNC_ASYNC,
2996					.rates = SNDRV_PCM_RATE_44100,
2997					.rate_min = 44100,
2998					.rate_max = 44100,
2999					.nr_rates = 1,
3000					.rate_table = (unsigned int[]) { 44100 }
3001				}
3002			},
3003			{
3004				QUIRK_DATA_AUDIOFORMAT(0) {
3005					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3006					.channels = 6,
3007					.iface = 0,
3008					.altsetting = 1,
3009					.altset_idx = 1,
3010					.endpoint = 0x82,
3011					.ep_idx = 1,
3012					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3013						USB_ENDPOINT_SYNC_ASYNC|
3014					USB_ENDPOINT_USAGE_IMPLICIT_FB,
3015					.rates = SNDRV_PCM_RATE_44100,
3016					.rate_min = 44100,
3017					.rate_max = 44100,
3018					.nr_rates = 1,
3019					.rate_table = (unsigned int[]) { 44100 }
3020				}
3021			},
3022			QUIRK_COMPOSITE_END
3023		}
3024	}
3025},
3026
3027{
3028	/*
3029	 * Pioneer DJ DJM-900NXS2
3030	 * 10 channels playback & 12 channels capture @ 44.1/48/96kHz S24LE
3031	 */
3032	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x000a),
3033	QUIRK_DRIVER_INFO {
3034		QUIRK_DATA_COMPOSITE {
3035			{
3036				QUIRK_DATA_AUDIOFORMAT(0) {
3037					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3038					.channels = 10,
3039					.iface = 0,
3040					.altsetting = 1,
3041					.altset_idx = 1,
3042					.endpoint = 0x01,
3043					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3044					    USB_ENDPOINT_SYNC_ASYNC,
3045					.rates = SNDRV_PCM_RATE_44100|
3046					    SNDRV_PCM_RATE_48000|
3047					    SNDRV_PCM_RATE_96000,
3048					.rate_min = 44100,
3049					.rate_max = 96000,
3050					.nr_rates = 3,
3051					.rate_table = (unsigned int[]) {
3052						44100, 48000, 96000
3053					}
3054				}
3055			},
3056			{
3057				QUIRK_DATA_AUDIOFORMAT(0) {
3058					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3059					.channels = 12,
3060					.iface = 0,
3061					.altsetting = 1,
3062					.altset_idx = 1,
3063					.endpoint = 0x82,
3064					.ep_idx = 1,
3065					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3066					    USB_ENDPOINT_SYNC_ASYNC|
3067					    USB_ENDPOINT_USAGE_IMPLICIT_FB,
3068					.rates = SNDRV_PCM_RATE_44100|
3069					    SNDRV_PCM_RATE_48000|
3070					    SNDRV_PCM_RATE_96000,
3071					.rate_min = 44100,
3072					.rate_max = 96000,
3073					.nr_rates = 3,
3074					.rate_table = (unsigned int[]) {
3075						44100, 48000, 96000
3076					}
3077				}
3078			},
3079			QUIRK_COMPOSITE_END
3080		}
3081	}
3082},
3083
3084{
3085	/*
3086	 * PIONEER DJ DDJ-800
3087	 * PCM is 6 channels out, 6 channels in @ 44.1 fixed
3088	 * The Feedback for the output is the input
3089	 */
3090	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x0029),
3091	QUIRK_DRIVER_INFO {
3092		QUIRK_DATA_COMPOSITE {
3093			{
3094				QUIRK_DATA_AUDIOFORMAT(0) {
3095					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3096					.channels = 6,
3097					.iface = 0,
3098					.altsetting = 1,
3099					.altset_idx = 1,
3100					.endpoint = 0x01,
3101					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3102						USB_ENDPOINT_SYNC_ASYNC,
3103					.rates = SNDRV_PCM_RATE_44100,
3104					.rate_min = 44100,
3105					.rate_max = 44100,
3106					.nr_rates = 1,
3107					.rate_table = (unsigned int[]) { 44100 }
3108				}
3109			},
3110			{
3111				QUIRK_DATA_AUDIOFORMAT(0) {
3112					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3113					.channels = 6,
3114					.iface = 0,
3115					.altsetting = 1,
3116					.altset_idx = 1,
3117					.endpoint = 0x82,
3118					.ep_idx = 1,
3119					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3120						USB_ENDPOINT_SYNC_ASYNC|
3121					USB_ENDPOINT_USAGE_IMPLICIT_FB,
3122					.rates = SNDRV_PCM_RATE_44100,
3123					.rate_min = 44100,
3124					.rate_max = 44100,
3125					.nr_rates = 1,
3126					.rate_table = (unsigned int[]) { 44100 }
3127				}
3128			},
3129			QUIRK_COMPOSITE_END
3130		}
3131	}
3132},
3133
3134{
3135	/*
3136	 * Pioneer DJ / AlphaTheta DJM-A9
3137	 * 10 channels playback & 12 channels capture @ 44.1/48/96kHz S24LE
3138	 */
3139	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x003c),
3140	QUIRK_DRIVER_INFO {
3141		QUIRK_DATA_COMPOSITE {
3142			{
3143				QUIRK_DATA_AUDIOFORMAT(0) {
3144					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3145					.channels = 10,
3146					.iface = 0,
3147					.altsetting = 1,
3148					.altset_idx = 1,
3149					.endpoint = 0x01,
3150					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3151					    USB_ENDPOINT_SYNC_ASYNC,
3152					.rates = SNDRV_PCM_RATE_44100|
3153					    SNDRV_PCM_RATE_48000|
3154					    SNDRV_PCM_RATE_96000,
3155					.rate_min = 44100,
3156					.rate_max = 96000,
3157					.nr_rates = 3,
3158					.rate_table = (unsigned int[]) {
3159						44100, 48000, 96000
3160					}
3161				}
3162			},
3163			{
3164				QUIRK_DATA_AUDIOFORMAT(0) {
3165					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3166					.channels = 12,
3167					.iface = 0,
3168					.altsetting = 1,
3169					.altset_idx = 1,
3170					.endpoint = 0x82,
3171					.ep_idx = 1,
3172					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3173					    USB_ENDPOINT_SYNC_ASYNC|
3174					    USB_ENDPOINT_USAGE_IMPLICIT_FB,
3175					.rates = SNDRV_PCM_RATE_44100|
3176					    SNDRV_PCM_RATE_48000|
3177					    SNDRV_PCM_RATE_96000,
3178					.rate_min = 44100,
3179					.rate_max = 96000,
3180					.nr_rates = 3,
3181					.rate_table = (unsigned int[]) {
3182						44100, 48000, 96000
3183					}
3184				}
3185			},
3186			QUIRK_COMPOSITE_END
3187		}
3188	}
3189},
3190
3191/*
3192 * MacroSilicon MS2100/MS2106 based AV capture cards
3193 *
3194 * These claim 96kHz 1ch in the descriptors, but are actually 48kHz 2ch.
3195 * They also need QUIRK_FLAG_ALIGN_TRANSFER, which makes one wonder if
3196 * they pretend to be 96kHz mono as a workaround for stereo being broken
3197 * by that...
3198 *
3199 * They also have an issue with initial stream alignment that causes the
3200 * channels to be swapped and out of phase, which is dealt with in quirks.c.
3201 */
3202{
3203	USB_AUDIO_DEVICE(0x534d, 0x0021),
3204	QUIRK_DRIVER_INFO {
3205		.vendor_name = "MacroSilicon",
3206		.product_name = "MS210x",
3207		QUIRK_DATA_COMPOSITE {
3208			{ QUIRK_DATA_STANDARD_MIXER(2) },
3209			{
3210				QUIRK_DATA_AUDIOFORMAT(3) {
3211					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3212					.channels = 2,
3213					.iface = 3,
3214					.altsetting = 1,
3215					.altset_idx = 1,
3216					.attributes = 0,
3217					.endpoint = 0x82,
3218					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3219						USB_ENDPOINT_SYNC_ASYNC,
3220					.rates = SNDRV_PCM_RATE_CONTINUOUS,
3221					.rate_min = 48000,
3222					.rate_max = 48000,
3223				}
3224			},
3225			QUIRK_COMPOSITE_END
3226		}
3227	}
3228},
3229
3230/*
3231 * MacroSilicon MS2109 based HDMI capture cards
3232 *
3233 * These claim 96kHz 1ch in the descriptors, but are actually 48kHz 2ch.
3234 * They also need QUIRK_FLAG_ALIGN_TRANSFER, which makes one wonder if
3235 * they pretend to be 96kHz mono as a workaround for stereo being broken
3236 * by that...
3237 *
3238 * They also have an issue with initial stream alignment that causes the
3239 * channels to be swapped and out of phase, which is dealt with in quirks.c.
3240 */
3241{
3242	USB_AUDIO_DEVICE(0x534d, 0x2109),
3243	QUIRK_DRIVER_INFO {
3244		.vendor_name = "MacroSilicon",
3245		.product_name = "MS2109",
3246		QUIRK_DATA_COMPOSITE {
3247			{ QUIRK_DATA_STANDARD_MIXER(2) },
3248			{
3249				QUIRK_DATA_AUDIOFORMAT(3) {
3250					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3251					.channels = 2,
3252					.iface = 3,
3253					.altsetting = 1,
3254					.altset_idx = 1,
3255					.attributes = 0,
3256					.endpoint = 0x82,
3257					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3258						USB_ENDPOINT_SYNC_ASYNC,
3259					.rates = SNDRV_PCM_RATE_CONTINUOUS,
3260					.rate_min = 48000,
3261					.rate_max = 48000,
3262				}
3263			},
3264			QUIRK_COMPOSITE_END
3265		}
3266	}
3267},
3268{
3269	/*
3270	 * Pioneer DJ DJM-750
3271	 * 8 channels playback & 8 channels capture @ 44.1/48/96kHz S24LE
3272	 */
3273	USB_DEVICE_VENDOR_SPEC(0x08e4, 0x017f),
3274	QUIRK_DRIVER_INFO {
3275		QUIRK_DATA_COMPOSITE {
3276			{
3277				QUIRK_DATA_AUDIOFORMAT(0) {
3278					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3279					.channels = 8,
3280					.iface = 0,
3281					.altsetting = 1,
3282					.altset_idx = 1,
3283					.endpoint = 0x05,
3284					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3285					    USB_ENDPOINT_SYNC_ASYNC,
3286					.rates = SNDRV_PCM_RATE_44100|
3287						SNDRV_PCM_RATE_48000|
3288						SNDRV_PCM_RATE_96000,
3289					.rate_min = 44100,
3290					.rate_max = 96000,
3291					.nr_rates = 3,
3292					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
3293				}
3294			},
3295			{
3296				QUIRK_DATA_AUDIOFORMAT(0) {
3297					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3298					.channels = 8,
3299					.iface = 0,
3300					.altsetting = 1,
3301					.altset_idx = 1,
3302					.endpoint = 0x86,
3303					.ep_idx = 1,
3304					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3305						USB_ENDPOINT_SYNC_ASYNC|
3306						USB_ENDPOINT_USAGE_IMPLICIT_FB,
3307					.rates = SNDRV_PCM_RATE_44100|
3308						SNDRV_PCM_RATE_48000|
3309						SNDRV_PCM_RATE_96000,
3310					.rate_min = 44100,
3311					.rate_max = 96000,
3312					.nr_rates = 3,
3313					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
3314				}
3315			},
3316			QUIRK_COMPOSITE_END
3317		}
3318	}
3319},
3320{
3321	/*
3322	 * Pioneer DJ DJM-750MK2
3323	 * 10 channels playback & 12 channels capture @ 48kHz S24LE
3324	 */
3325	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x001b),
3326	QUIRK_DRIVER_INFO {
3327		QUIRK_DATA_COMPOSITE {
3328			{
3329				QUIRK_DATA_AUDIOFORMAT(0) {
3330					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3331					.channels = 10,
3332					.iface = 0,
3333					.altsetting = 1,
3334					.altset_idx = 1,
3335					.endpoint = 0x01,
3336					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3337					    USB_ENDPOINT_SYNC_ASYNC,
3338					.rates = SNDRV_PCM_RATE_48000,
3339					.rate_min = 48000,
3340					.rate_max = 48000,
3341					.nr_rates = 1,
3342					.rate_table = (unsigned int[]) {
3343						48000
3344					}
3345				}
3346			},
3347			{
3348				QUIRK_DATA_AUDIOFORMAT(0) {
3349					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3350					.channels = 12,
3351					.iface = 0,
3352					.altsetting = 1,
3353					.altset_idx = 1,
3354					.endpoint = 0x82,
3355					.ep_idx = 1,
3356					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3357						USB_ENDPOINT_SYNC_ASYNC|
3358						USB_ENDPOINT_USAGE_IMPLICIT_FB,
3359					.rates = SNDRV_PCM_RATE_48000,
3360					.rate_min = 48000,
3361					.rate_max = 48000,
3362					.nr_rates = 1,
3363					.rate_table = (unsigned int[]) { 48000 }
3364				}
3365			},
3366			QUIRK_COMPOSITE_END
3367		}
3368	}
3369},
3370{
3371	/*
3372	 * Pioneer DJ DJM-850
3373	 * 8 channels playback and 8 channels capture @ 44.1/48/96kHz S24LE
3374	 * Playback on EP 0x05
3375	 * Capture on EP 0x86
3376	 */
3377	USB_DEVICE_VENDOR_SPEC(0x08e4, 0x0163),
3378	QUIRK_DRIVER_INFO {
3379		QUIRK_DATA_COMPOSITE {
3380			{
3381				QUIRK_DATA_AUDIOFORMAT(0) {
3382					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3383					.channels = 8,
3384					.iface = 0,
3385					.altsetting = 1,
3386					.altset_idx = 1,
3387					.endpoint = 0x05,
3388					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3389					    USB_ENDPOINT_SYNC_ASYNC|
3390						USB_ENDPOINT_USAGE_DATA,
3391					.rates = SNDRV_PCM_RATE_44100|
3392						SNDRV_PCM_RATE_48000|
3393						SNDRV_PCM_RATE_96000,
3394					.rate_min = 44100,
3395					.rate_max = 96000,
3396					.nr_rates = 3,
3397					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
3398				}
3399			},
3400			{
3401				QUIRK_DATA_AUDIOFORMAT(0) {
3402					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3403					.channels = 8,
3404					.iface = 0,
3405					.altsetting = 1,
3406					.altset_idx = 1,
3407					.endpoint = 0x86,
3408					.ep_idx = 1,
3409					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3410						USB_ENDPOINT_SYNC_ASYNC|
3411						USB_ENDPOINT_USAGE_DATA,
3412					.rates = SNDRV_PCM_RATE_44100|
3413						SNDRV_PCM_RATE_48000|
3414						SNDRV_PCM_RATE_96000,
3415					.rate_min = 44100,
3416					.rate_max = 96000,
3417					.nr_rates = 3,
3418					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
3419				}
3420			},
3421			QUIRK_COMPOSITE_END
3422		}
3423	}
3424},
3425{
3426	/*
3427	 * Pioneer DJ DJM-450
3428	 * PCM is 8 channels out @ 48 fixed (endpoint 0x01)
3429	 * and 8 channels in @ 48 fixed (endpoint 0x82).
3430	 */
3431	USB_DEVICE_VENDOR_SPEC(0x2b73, 0x0013),
3432	QUIRK_DRIVER_INFO {
3433		QUIRK_DATA_COMPOSITE {
3434			{
3435				QUIRK_DATA_AUDIOFORMAT(0) {
3436					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3437					.channels = 8, // outputs
3438					.iface = 0,
3439					.altsetting = 1,
3440					.altset_idx = 1,
3441					.endpoint = 0x01,
3442					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3443						USB_ENDPOINT_SYNC_ASYNC,
3444					.rates = SNDRV_PCM_RATE_48000,
3445					.rate_min = 48000,
3446					.rate_max = 48000,
3447					.nr_rates = 1,
3448					.rate_table = (unsigned int[]) { 48000 }
3449					}
3450			},
3451			{
3452				QUIRK_DATA_AUDIOFORMAT(0) {
3453					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3454					.channels = 8, // inputs
3455					.iface = 0,
3456					.altsetting = 1,
3457					.altset_idx = 1,
3458					.endpoint = 0x82,
3459					.ep_idx = 1,
3460					.ep_attr = USB_ENDPOINT_XFER_ISOC|
3461						USB_ENDPOINT_SYNC_ASYNC|
3462						USB_ENDPOINT_USAGE_IMPLICIT_FB,
3463					.rates = SNDRV_PCM_RATE_48000,
3464					.rate_min = 48000,
3465					.rate_max = 48000,
3466					.nr_rates = 1,
3467					.rate_table = (unsigned int[]) { 48000 }
3468				}
3469			},
3470			QUIRK_COMPOSITE_END
3471		}
3472	}
3473},
3474{
3475	/*
3476	 * Sennheiser GSP670
3477	 * Change order of interfaces loaded
3478	 */
3479	USB_DEVICE(0x1395, 0x0300),
3480	.bInterfaceClass = USB_CLASS_PER_INTERFACE,
3481	QUIRK_DRIVER_INFO {
3482		QUIRK_DATA_COMPOSITE {
3483			// Communication
3484			{ QUIRK_DATA_STANDARD_AUDIO(3) },
3485			// Recording
3486			{ QUIRK_DATA_STANDARD_AUDIO(4) },
3487			// Main
3488			{ QUIRK_DATA_STANDARD_AUDIO(1) },
3489			QUIRK_COMPOSITE_END
3490		}
3491	}
3492},
3493{
3494	/*
3495	 * Fiero SC-01 (firmware v1.0.0 @ 48 kHz)
3496	 */
3497	USB_DEVICE(0x2b53, 0x0023),
3498	QUIRK_DRIVER_INFO {
3499		.vendor_name = "Fiero",
3500		.product_name = "SC-01",
3501		QUIRK_DATA_COMPOSITE {
3502			{ QUIRK_DATA_STANDARD_AUDIO(0) },
3503			/* Playback */
3504			{
3505				QUIRK_DATA_AUDIOFORMAT(1) {
3506					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3507					.channels = 2,
3508					.fmt_bits = 24,
3509					.iface = 1,
3510					.altsetting = 1,
3511					.altset_idx = 1,
3512					.endpoint = 0x01,
3513					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3514						   USB_ENDPOINT_SYNC_ASYNC,
3515					.rates = SNDRV_PCM_RATE_48000,
3516					.rate_min = 48000,
3517					.rate_max = 48000,
3518					.nr_rates = 1,
3519					.rate_table = (unsigned int[]) { 48000 },
3520					.clock = 0x29
3521				}
3522			},
3523			/* Capture */
3524			{
3525				QUIRK_DATA_AUDIOFORMAT(2) {
3526					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3527					.channels = 2,
3528					.fmt_bits = 24,
3529					.iface = 2,
3530					.altsetting = 1,
3531					.altset_idx = 1,
3532					.endpoint = 0x82,
3533					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3534						   USB_ENDPOINT_SYNC_ASYNC |
3535						   USB_ENDPOINT_USAGE_IMPLICIT_FB,
3536					.rates = SNDRV_PCM_RATE_48000,
3537					.rate_min = 48000,
3538					.rate_max = 48000,
3539					.nr_rates = 1,
3540					.rate_table = (unsigned int[]) { 48000 },
3541					.clock = 0x29
3542				}
3543			},
3544			QUIRK_COMPOSITE_END
3545		}
3546	}
3547},
3548{
3549	/*
3550	 * Fiero SC-01 (firmware v1.0.0 @ 96 kHz)
3551	 */
3552	USB_DEVICE(0x2b53, 0x0024),
3553	QUIRK_DRIVER_INFO {
3554		.vendor_name = "Fiero",
3555		.product_name = "SC-01",
3556		QUIRK_DATA_COMPOSITE {
3557			{ QUIRK_DATA_STANDARD_AUDIO(0) },
3558			/* Playback */
3559			{
3560				QUIRK_DATA_AUDIOFORMAT(1) {
3561					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3562					.channels = 2,
3563					.fmt_bits = 24,
3564					.iface = 1,
3565					.altsetting = 1,
3566					.altset_idx = 1,
3567					.endpoint = 0x01,
3568					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3569						   USB_ENDPOINT_SYNC_ASYNC,
3570					.rates = SNDRV_PCM_RATE_96000,
3571					.rate_min = 96000,
3572					.rate_max = 96000,
3573					.nr_rates = 1,
3574					.rate_table = (unsigned int[]) { 96000 },
3575					.clock = 0x29
3576				}
3577			},
3578			/* Capture */
3579			{
3580				QUIRK_DATA_AUDIOFORMAT(2) {
3581					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3582					.channels = 2,
3583					.fmt_bits = 24,
3584					.iface = 2,
3585					.altsetting = 1,
3586					.altset_idx = 1,
3587					.endpoint = 0x82,
3588					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3589						   USB_ENDPOINT_SYNC_ASYNC |
3590						   USB_ENDPOINT_USAGE_IMPLICIT_FB,
3591					.rates = SNDRV_PCM_RATE_96000,
3592					.rate_min = 96000,
3593					.rate_max = 96000,
3594					.nr_rates = 1,
3595					.rate_table = (unsigned int[]) { 96000 },
3596					.clock = 0x29
3597				}
3598			},
3599			QUIRK_COMPOSITE_END
3600		}
3601	}
3602},
3603{
3604	/*
3605	 * Fiero SC-01 (firmware v1.1.0)
3606	 */
3607	USB_DEVICE(0x2b53, 0x0031),
3608	QUIRK_DRIVER_INFO {
3609		.vendor_name = "Fiero",
3610		.product_name = "SC-01",
3611		QUIRK_DATA_COMPOSITE {
3612			{ QUIRK_DATA_STANDARD_AUDIO(0) },
3613			/* Playback */
3614			{
3615				QUIRK_DATA_AUDIOFORMAT(1) {
3616					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3617					.channels = 2,
3618					.fmt_bits = 24,
3619					.iface = 1,
3620					.altsetting = 1,
3621					.altset_idx = 1,
3622					.endpoint = 0x01,
3623					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3624						   USB_ENDPOINT_SYNC_ASYNC,
3625					.rates = SNDRV_PCM_RATE_48000 |
3626						 SNDRV_PCM_RATE_96000,
3627					.rate_min = 48000,
3628					.rate_max = 96000,
3629					.nr_rates = 2,
3630					.rate_table = (unsigned int[]) { 48000, 96000 },
3631					.clock = 0x29
3632				}
3633			},
3634			/* Capture */
3635			{
3636				QUIRK_DATA_AUDIOFORMAT(2) {
3637					.formats = SNDRV_PCM_FMTBIT_S32_LE,
3638					.channels = 2,
3639					.fmt_bits = 24,
3640					.iface = 2,
3641					.altsetting = 1,
3642					.altset_idx = 1,
3643					.endpoint = 0x82,
3644					.ep_attr = USB_ENDPOINT_XFER_ISOC |
3645						   USB_ENDPOINT_SYNC_ASYNC |
3646						   USB_ENDPOINT_USAGE_IMPLICIT_FB,
3647					.rates = SNDRV_PCM_RATE_48000 |
3648						 SNDRV_PCM_RATE_96000,
3649					.rate_min = 48000,
3650					.rate_max = 96000,
3651					.nr_rates = 2,
3652					.rate_table = (unsigned int[]) { 48000, 96000 },
3653					.clock = 0x29
3654				}
3655			},
3656			QUIRK_COMPOSITE_END
3657		}
3658	}
3659},
3660{
3661	/* Advanced modes of the Mythware XA001AU.
3662	 * For the standard mode, Mythware XA001AU has ID ffad:a001
3663	 */
3664	USB_DEVICE_VENDOR_SPEC(0xffad, 0xa001),
3665	QUIRK_DRIVER_INFO {
3666		.vendor_name = "Mythware",
3667		.product_name = "XA001AU",
3668		QUIRK_DATA_COMPOSITE {
3669			{ QUIRK_DATA_IGNORE(0) },
3670			{ QUIRK_DATA_STANDARD_AUDIO(1) },
3671			{ QUIRK_DATA_STANDARD_AUDIO(2) },
3672			QUIRK_COMPOSITE_END
3673		}
3674	}
3675},
3676#define QUIRK_RME_DIGIFACE(pid) \
3677{ \
3678	/* Only claim interface 0 */ \
3679	.match_flags = USB_DEVICE_ID_MATCH_VENDOR | \
3680		       USB_DEVICE_ID_MATCH_PRODUCT | \
3681		       USB_DEVICE_ID_MATCH_INT_CLASS | \
3682		       USB_DEVICE_ID_MATCH_INT_NUMBER, \
3683	.idVendor = 0x2a39, \
3684	.idProduct = pid, \
3685	.bInterfaceClass = USB_CLASS_VENDOR_SPEC, \
3686	.bInterfaceNumber = 0, \
3687	QUIRK_DRIVER_INFO { \
3688		QUIRK_DATA_COMPOSITE { \
3689			/*
3690			 * Three modes depending on sample rate band,
3691			 * with different channel counts for in/out
3692			 */ \
3693			{ QUIRK_DATA_STANDARD_MIXER(0) }, \
3694			{ \
3695				QUIRK_DATA_AUDIOFORMAT(0) { \
3696					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3697					.channels = 34, /* outputs */ \
3698					.fmt_bits = 24, \
3699					.iface = 0, \
3700					.altsetting = 1, \
3701					.altset_idx = 1, \
3702					.endpoint = 0x02, \
3703					.ep_idx = 1, \
3704					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3705						USB_ENDPOINT_SYNC_ASYNC, \
3706					.rates = SNDRV_PCM_RATE_32000 | \
3707						SNDRV_PCM_RATE_44100 | \
3708						SNDRV_PCM_RATE_48000, \
3709					.rate_min = 32000, \
3710					.rate_max = 48000, \
3711					.nr_rates = 3, \
3712					.rate_table = (unsigned int[]) { \
3713						32000, 44100, 48000, \
3714					}, \
3715					.sync_ep = 0x81, \
3716					.sync_iface = 0, \
3717					.sync_altsetting = 1, \
3718					.sync_ep_idx = 0, \
3719					.implicit_fb = 1, \
3720				}, \
3721			}, \
3722			{ \
3723				QUIRK_DATA_AUDIOFORMAT(0) { \
3724					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3725					.channels = 18, /* outputs */ \
3726					.fmt_bits = 24, \
3727					.iface = 0, \
3728					.altsetting = 1, \
3729					.altset_idx = 1, \
3730					.endpoint = 0x02, \
3731					.ep_idx = 1, \
3732					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3733						USB_ENDPOINT_SYNC_ASYNC, \
3734					.rates = SNDRV_PCM_RATE_64000 | \
3735						SNDRV_PCM_RATE_88200 | \
3736						SNDRV_PCM_RATE_96000, \
3737					.rate_min = 64000, \
3738					.rate_max = 96000, \
3739					.nr_rates = 3, \
3740					.rate_table = (unsigned int[]) { \
3741						64000, 88200, 96000, \
3742					}, \
3743					.sync_ep = 0x81, \
3744					.sync_iface = 0, \
3745					.sync_altsetting = 1, \
3746					.sync_ep_idx = 0, \
3747					.implicit_fb = 1, \
3748				}, \
3749			}, \
3750			{ \
3751				QUIRK_DATA_AUDIOFORMAT(0) { \
3752					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3753					.channels = 10, /* outputs */ \
3754					.fmt_bits = 24, \
3755					.iface = 0, \
3756					.altsetting = 1, \
3757					.altset_idx = 1, \
3758					.endpoint = 0x02, \
3759					.ep_idx = 1, \
3760					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3761						USB_ENDPOINT_SYNC_ASYNC, \
3762					.rates = SNDRV_PCM_RATE_KNOT | \
3763						SNDRV_PCM_RATE_176400 | \
3764						SNDRV_PCM_RATE_192000, \
3765					.rate_min = 128000, \
3766					.rate_max = 192000, \
3767					.nr_rates = 3, \
3768					.rate_table = (unsigned int[]) { \
3769						128000, 176400, 192000, \
3770					}, \
3771					.sync_ep = 0x81, \
3772					.sync_iface = 0, \
3773					.sync_altsetting = 1, \
3774					.sync_ep_idx = 0, \
3775					.implicit_fb = 1, \
3776				}, \
3777			}, \
3778			{ \
3779				QUIRK_DATA_AUDIOFORMAT(0) { \
3780					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3781					.channels = 32, /* inputs */ \
3782					.fmt_bits = 24, \
3783					.iface = 0, \
3784					.altsetting = 1, \
3785					.altset_idx = 1, \
3786					.endpoint = 0x81, \
3787					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3788						USB_ENDPOINT_SYNC_ASYNC, \
3789					.rates = SNDRV_PCM_RATE_32000 | \
3790						SNDRV_PCM_RATE_44100 | \
3791						SNDRV_PCM_RATE_48000, \
3792					.rate_min = 32000, \
3793					.rate_max = 48000, \
3794					.nr_rates = 3, \
3795					.rate_table = (unsigned int[]) { \
3796						32000, 44100, 48000, \
3797					} \
3798				} \
3799			}, \
3800			{ \
3801				QUIRK_DATA_AUDIOFORMAT(0) { \
3802					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3803					.channels = 16, /* inputs */ \
3804					.fmt_bits = 24, \
3805					.iface = 0, \
3806					.altsetting = 1, \
3807					.altset_idx = 1, \
3808					.endpoint = 0x81, \
3809					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3810						USB_ENDPOINT_SYNC_ASYNC, \
3811					.rates = SNDRV_PCM_RATE_64000 | \
3812						SNDRV_PCM_RATE_88200 | \
3813						SNDRV_PCM_RATE_96000, \
3814					.rate_min = 64000, \
3815					.rate_max = 96000, \
3816					.nr_rates = 3, \
3817					.rate_table = (unsigned int[]) { \
3818						64000, 88200, 96000, \
3819					} \
3820				} \
3821			}, \
3822			{ \
3823				QUIRK_DATA_AUDIOFORMAT(0) { \
3824					.formats = SNDRV_PCM_FMTBIT_S32_LE, \
3825					.channels = 8, /* inputs */ \
3826					.fmt_bits = 24, \
3827					.iface = 0, \
3828					.altsetting = 1, \
3829					.altset_idx = 1, \
3830					.endpoint = 0x81, \
3831					.ep_attr = USB_ENDPOINT_XFER_ISOC | \
3832						USB_ENDPOINT_SYNC_ASYNC, \
3833					.rates = SNDRV_PCM_RATE_KNOT | \
3834						SNDRV_PCM_RATE_176400 | \
3835						SNDRV_PCM_RATE_192000, \
3836					.rate_min = 128000, \
3837					.rate_max = 192000, \
3838					.nr_rates = 3, \
3839					.rate_table = (unsigned int[]) { \
3840						128000, 176400, 192000, \
3841					} \
3842				} \
3843			}, \
3844			QUIRK_COMPOSITE_END \
3845		} \
3846	} \
3847}
3848
3849QUIRK_RME_DIGIFACE(0x3f8c),
3850QUIRK_RME_DIGIFACE(0x3fa0),
3851
3852#undef USB_DEVICE_VENDOR_SPEC
3853#undef USB_AUDIO_DEVICE
v4.17
 
   1/*
   2 * ALSA USB Audio Driver
   3 *
   4 * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>,
   5 *                       Clemens Ladisch <clemens@ladisch.de>
   6 *
   7 *
   8 *  This program is free software; you can redistribute it and/or modify
   9 *  it under the terms of the GNU General Public License as published by
  10 *  the Free Software Foundation; either version 2 of the License, or
  11 *  (at your option) any later version.
  12 *
  13 *  This program is distributed in the hope that it will be useful,
  14 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  15 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16 *  GNU General Public License for more details.
  17 *
  18 *  You should have received a copy of the GNU General Public License
  19 *  along with this program; if not, write to the Free Software
  20 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  21 */
  22
  23/*
  24 * The contents of this file are part of the driver's id_table.
  25 *
  26 * In a perfect world, this file would be empty.
  27 */
  28
  29/*
  30 * Use this for devices where other interfaces are standard compliant,
  31 * to prevent the quirk being applied to those interfaces. (To work with
  32 * hotplugging, bDeviceClass must be set to USB_CLASS_PER_INTERFACE.)
  33 */
  34#define USB_DEVICE_VENDOR_SPEC(vend, prod) \
  35	.match_flags = USB_DEVICE_ID_MATCH_VENDOR | \
  36		       USB_DEVICE_ID_MATCH_PRODUCT | \
  37		       USB_DEVICE_ID_MATCH_INT_CLASS, \
  38	.idVendor = vend, \
  39	.idProduct = prod, \
  40	.bInterfaceClass = USB_CLASS_VENDOR_SPEC
  41
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  42/* FTDI devices */
  43{
  44	USB_DEVICE(0x0403, 0xb8d8),
  45	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
  46		/* .vendor_name = "STARR LABS", */
  47		/* .product_name = "Starr Labs MIDI USB device", */
  48		.ifnum = 0,
  49		.type = QUIRK_MIDI_FTDI
  50	}
  51},
  52
  53{
  54	/* Creative BT-D1 */
  55	USB_DEVICE(0x041e, 0x0005),
  56	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
  57		.ifnum = 1,
  58		.type = QUIRK_AUDIO_FIXED_ENDPOINT,
  59		.data = &(const struct audioformat) {
  60			.formats = SNDRV_PCM_FMTBIT_S16_LE,
  61			.channels = 2,
  62			.iface = 1,
  63			.altsetting = 1,
  64			.altset_idx = 1,
  65			.endpoint = 0x03,
  66			.ep_attr = USB_ENDPOINT_XFER_ISOC,
  67			.attributes = 0,
  68			.rates = SNDRV_PCM_RATE_CONTINUOUS,
  69			.rate_min = 48000,
  70			.rate_max = 48000,
  71		}
  72	}
  73},
  74
  75/* Creative/E-Mu devices */
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  76{
  77	USB_DEVICE(0x041e, 0x3010),
  78	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
  79		.vendor_name = "Creative Labs",
  80		.product_name = "Sound Blaster MP3+",
  81		.ifnum = QUIRK_NO_INTERFACE
  82	}
  83},
  84/* Creative/Toshiba Multimedia Center SB-0500 */
  85{
  86	USB_DEVICE(0x041e, 0x3048),
  87	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
  88		.vendor_name = "Toshiba",
  89		.product_name = "SB-0500",
  90		.ifnum = QUIRK_NO_INTERFACE
  91	}
  92},
  93{
  94	/* E-Mu 0202 USB */
  95	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
  96	.idVendor = 0x041e,
  97	.idProduct = 0x3f02,
  98	.bInterfaceClass = USB_CLASS_AUDIO,
  99},
 100{
 101	/* E-Mu 0404 USB */
 102	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
 103	.idVendor = 0x041e,
 104	.idProduct = 0x3f04,
 105	.bInterfaceClass = USB_CLASS_AUDIO,
 106},
 107{
 108	/* E-Mu Tracker Pre */
 109	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
 110	.idVendor = 0x041e,
 111	.idProduct = 0x3f0a,
 112	.bInterfaceClass = USB_CLASS_AUDIO,
 113},
 114{
 115	/* E-Mu 0204 USB */
 116	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
 117	.idVendor = 0x041e,
 118	.idProduct = 0x3f19,
 119	.bInterfaceClass = USB_CLASS_AUDIO,
 120},
 121
 122/*
 123 * HP Wireless Audio
 124 * When not ignored, causes instability issues for some users, forcing them to
 125 * blacklist the entire module.
 126 */
 127{
 128	USB_DEVICE(0x0424, 0xb832),
 129	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
 130		.vendor_name = "Standard Microsystems Corp.",
 131		.product_name = "HP Wireless Audio",
 132		.ifnum = QUIRK_ANY_INTERFACE,
 133		.type = QUIRK_COMPOSITE,
 134		.data = (const struct snd_usb_audio_quirk[]) {
 135			/* Mixer */
 136			{
 137				.ifnum = 0,
 138				.type = QUIRK_IGNORE_INTERFACE,
 139			},
 140			/* Playback */
 141			{
 142				.ifnum = 1,
 143				.type = QUIRK_IGNORE_INTERFACE,
 144			},
 145			/* Capture */
 146			{
 147				.ifnum = 2,
 148				.type = QUIRK_IGNORE_INTERFACE,
 149			},
 150			/* HID Device, .ifnum = 3 */
 151			{
 152				.ifnum = -1,
 153			}
 154		}
 155	}
 156},
 157
 158/*
 159 * Logitech QuickCam: bDeviceClass is vendor-specific, so generic interface
 160 * class matches do not take effect without an explicit ID match.
 161 */
 162{
 163	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 164		       USB_DEVICE_ID_MATCH_INT_CLASS |
 165		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 166	.idVendor = 0x046d,
 167	.idProduct = 0x0850,
 168	.bInterfaceClass = USB_CLASS_AUDIO,
 169	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 170},
 171{
 172	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 173		       USB_DEVICE_ID_MATCH_INT_CLASS |
 174		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 175	.idVendor = 0x046d,
 176	.idProduct = 0x08ae,
 177	.bInterfaceClass = USB_CLASS_AUDIO,
 178	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 179},
 180{
 181	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 182		       USB_DEVICE_ID_MATCH_INT_CLASS |
 183		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 184	.idVendor = 0x046d,
 185	.idProduct = 0x08c6,
 186	.bInterfaceClass = USB_CLASS_AUDIO,
 187	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 188},
 189{
 190	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 191		       USB_DEVICE_ID_MATCH_INT_CLASS |
 192		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 193	.idVendor = 0x046d,
 194	.idProduct = 0x08f0,
 195	.bInterfaceClass = USB_CLASS_AUDIO,
 196	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 197},
 198{
 199	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 200		       USB_DEVICE_ID_MATCH_INT_CLASS |
 201		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 202	.idVendor = 0x046d,
 203	.idProduct = 0x08f5,
 204	.bInterfaceClass = USB_CLASS_AUDIO,
 205	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 206},
 207{
 208	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 209		       USB_DEVICE_ID_MATCH_INT_CLASS |
 210		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 211	.idVendor = 0x046d,
 212	.idProduct = 0x08f6,
 213	.bInterfaceClass = USB_CLASS_AUDIO,
 214	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
 215},
 216{
 217	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
 218		       USB_DEVICE_ID_MATCH_INT_CLASS |
 219		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 220	.idVendor = 0x046d,
 221	.idProduct = 0x0990,
 222	.bInterfaceClass = USB_CLASS_AUDIO,
 223	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL,
 224	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 225		.vendor_name = "Logitech, Inc.",
 226		.product_name = "QuickCam Pro 9000",
 227		.ifnum = QUIRK_NO_INTERFACE
 228	}
 229},
 230
 231/*
 232 * Yamaha devices
 233 */
 234
 235#define YAMAHA_DEVICE(id, name) { \
 236	USB_DEVICE(0x0499, id), \
 237	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \
 238		.vendor_name = "Yamaha", \
 239		.product_name = name, \
 240		.ifnum = QUIRK_ANY_INTERFACE, \
 241		.type = QUIRK_MIDI_YAMAHA \
 242	} \
 243}
 244#define YAMAHA_INTERFACE(id, intf, name) { \
 245	USB_DEVICE_VENDOR_SPEC(0x0499, id), \
 246	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \
 247		.vendor_name = "Yamaha", \
 248		.product_name = name, \
 249		.ifnum = intf, \
 250		.type = QUIRK_MIDI_YAMAHA \
 251	} \
 252}
 253YAMAHA_DEVICE(0x1000, "UX256"),
 254YAMAHA_DEVICE(0x1001, "MU1000"),
 255YAMAHA_DEVICE(0x1002, "MU2000"),
 256YAMAHA_DEVICE(0x1003, "MU500"),
 257YAMAHA_INTERFACE(0x1004, 3, "UW500"),
 258YAMAHA_DEVICE(0x1005, "MOTIF6"),
 259YAMAHA_DEVICE(0x1006, "MOTIF7"),
 260YAMAHA_DEVICE(0x1007, "MOTIF8"),
 261YAMAHA_DEVICE(0x1008, "UX96"),
 262YAMAHA_DEVICE(0x1009, "UX16"),
 263YAMAHA_INTERFACE(0x100a, 3, "EOS BX"),
 264YAMAHA_DEVICE(0x100c, "UC-MX"),
 265YAMAHA_DEVICE(0x100d, "UC-KX"),
 266YAMAHA_DEVICE(0x100e, "S08"),
 267YAMAHA_DEVICE(0x100f, "CLP-150"),
 268YAMAHA_DEVICE(0x1010, "CLP-170"),
 269YAMAHA_DEVICE(0x1011, "P-250"),
 270YAMAHA_DEVICE(0x1012, "TYROS"),
 271YAMAHA_DEVICE(0x1013, "PF-500"),
 272YAMAHA_DEVICE(0x1014, "S90"),
 273YAMAHA_DEVICE(0x1015, "MOTIF-R"),
 274YAMAHA_DEVICE(0x1016, "MDP-5"),
 275YAMAHA_DEVICE(0x1017, "CVP-204"),
 276YAMAHA_DEVICE(0x1018, "CVP-206"),
 277YAMAHA_DEVICE(0x1019, "CVP-208"),
 278YAMAHA_DEVICE(0x101a, "CVP-210"),
 279YAMAHA_DEVICE(0x101b, "PSR-1100"),
 280YAMAHA_DEVICE(0x101c, "PSR-2100"),
 281YAMAHA_DEVICE(0x101d, "CLP-175"),
 282YAMAHA_DEVICE(0x101e, "PSR-K1"),
 283YAMAHA_DEVICE(0x101f, "EZ-J24"),
 284YAMAHA_DEVICE(0x1020, "EZ-250i"),
 285YAMAHA_DEVICE(0x1021, "MOTIF ES 6"),
 286YAMAHA_DEVICE(0x1022, "MOTIF ES 7"),
 287YAMAHA_DEVICE(0x1023, "MOTIF ES 8"),
 288YAMAHA_DEVICE(0x1024, "CVP-301"),
 289YAMAHA_DEVICE(0x1025, "CVP-303"),
 290YAMAHA_DEVICE(0x1026, "CVP-305"),
 291YAMAHA_DEVICE(0x1027, "CVP-307"),
 292YAMAHA_DEVICE(0x1028, "CVP-309"),
 293YAMAHA_DEVICE(0x1029, "CVP-309GP"),
 294YAMAHA_DEVICE(0x102a, "PSR-1500"),
 295YAMAHA_DEVICE(0x102b, "PSR-3000"),
 296YAMAHA_DEVICE(0x102e, "ELS-01/01C"),
 297YAMAHA_DEVICE(0x1030, "PSR-295/293"),
 298YAMAHA_DEVICE(0x1031, "DGX-205/203"),
 299YAMAHA_DEVICE(0x1032, "DGX-305"),
 300YAMAHA_DEVICE(0x1033, "DGX-505"),
 301YAMAHA_DEVICE(0x1034, NULL),
 302YAMAHA_DEVICE(0x1035, NULL),
 303YAMAHA_DEVICE(0x1036, NULL),
 304YAMAHA_DEVICE(0x1037, NULL),
 305YAMAHA_DEVICE(0x1038, NULL),
 306YAMAHA_DEVICE(0x1039, NULL),
 307YAMAHA_DEVICE(0x103a, NULL),
 308YAMAHA_DEVICE(0x103b, NULL),
 309YAMAHA_DEVICE(0x103c, NULL),
 310YAMAHA_DEVICE(0x103d, NULL),
 311YAMAHA_DEVICE(0x103e, NULL),
 312YAMAHA_DEVICE(0x103f, NULL),
 313YAMAHA_DEVICE(0x1040, NULL),
 314YAMAHA_DEVICE(0x1041, NULL),
 315YAMAHA_DEVICE(0x1042, NULL),
 316YAMAHA_DEVICE(0x1043, NULL),
 317YAMAHA_DEVICE(0x1044, NULL),
 318YAMAHA_DEVICE(0x1045, NULL),
 319YAMAHA_INTERFACE(0x104e, 0, NULL),
 320YAMAHA_DEVICE(0x104f, NULL),
 321YAMAHA_DEVICE(0x1050, NULL),
 322YAMAHA_DEVICE(0x1051, NULL),
 323YAMAHA_DEVICE(0x1052, NULL),
 324YAMAHA_INTERFACE(0x1053, 0, NULL),
 325YAMAHA_INTERFACE(0x1054, 0, NULL),
 326YAMAHA_DEVICE(0x1055, NULL),
 327YAMAHA_DEVICE(0x1056, NULL),
 328YAMAHA_DEVICE(0x1057, NULL),
 329YAMAHA_DEVICE(0x1058, NULL),
 330YAMAHA_DEVICE(0x1059, NULL),
 331YAMAHA_DEVICE(0x105a, NULL),
 332YAMAHA_DEVICE(0x105b, NULL),
 333YAMAHA_DEVICE(0x105c, NULL),
 334YAMAHA_DEVICE(0x105d, NULL),
 335{
 336	USB_DEVICE(0x0499, 0x1503),
 337	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 338		/* .vendor_name = "Yamaha", */
 339		/* .product_name = "MOX6/MOX8", */
 340		.ifnum = QUIRK_ANY_INTERFACE,
 341		.type = QUIRK_COMPOSITE,
 342		.data = (const struct snd_usb_audio_quirk[]) {
 343			{
 344				.ifnum = 1,
 345				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 346			},
 347			{
 348				.ifnum = 2,
 349				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 350			},
 351			{
 352				.ifnum = 3,
 353				.type = QUIRK_MIDI_YAMAHA
 354			},
 355			{
 356				.ifnum = -1
 357			}
 358		}
 359	}
 360},
 361{
 362	USB_DEVICE(0x0499, 0x1507),
 363	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 364		/* .vendor_name = "Yamaha", */
 365		/* .product_name = "THR10", */
 366		.ifnum = QUIRK_ANY_INTERFACE,
 367		.type = QUIRK_COMPOSITE,
 368		.data = (const struct snd_usb_audio_quirk[]) {
 369			{
 370				.ifnum = 1,
 371				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 372			},
 373			{
 374				.ifnum = 2,
 375				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 376			},
 377			{
 378				.ifnum = 3,
 379				.type = QUIRK_MIDI_YAMAHA
 380			},
 381			{
 382				.ifnum = -1
 383			}
 384		}
 385	}
 386},
 387{
 388	USB_DEVICE(0x0499, 0x1509),
 389	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 390		/* .vendor_name = "Yamaha", */
 391		/* .product_name = "Steinberg UR22", */
 392		.ifnum = QUIRK_ANY_INTERFACE,
 393		.type = QUIRK_COMPOSITE,
 394		.data = (const struct snd_usb_audio_quirk[]) {
 395			{
 396				.ifnum = 1,
 397				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 398			},
 399			{
 400				.ifnum = 2,
 401				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 402			},
 403			{
 404				.ifnum = 3,
 405				.type = QUIRK_MIDI_YAMAHA
 406			},
 407			{
 408				.ifnum = 4,
 409				.type = QUIRK_IGNORE_INTERFACE
 410			},
 411			{
 412				.ifnum = -1
 413			}
 414		}
 415	}
 416},
 417{
 418	USB_DEVICE(0x0499, 0x150a),
 419	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 420		/* .vendor_name = "Yamaha", */
 421		/* .product_name = "THR5A", */
 422		.ifnum = QUIRK_ANY_INTERFACE,
 423		.type = QUIRK_COMPOSITE,
 424		.data = (const struct snd_usb_audio_quirk[]) {
 425			{
 426				.ifnum = 1,
 427				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 428			},
 429			{
 430				.ifnum = 2,
 431				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 432			},
 433			{
 434				.ifnum = 3,
 435				.type = QUIRK_MIDI_YAMAHA
 436			},
 437			{
 438				.ifnum = -1
 439			}
 440		}
 441	}
 442},
 443{
 444	USB_DEVICE(0x0499, 0x150c),
 445	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 446		/* .vendor_name = "Yamaha", */
 447		/* .product_name = "THR10C", */
 448		.ifnum = QUIRK_ANY_INTERFACE,
 449		.type = QUIRK_COMPOSITE,
 450		.data = (const struct snd_usb_audio_quirk[]) {
 451			{
 452				.ifnum = 1,
 453				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 454			},
 455			{
 456				.ifnum = 2,
 457				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 458			},
 459			{
 460				.ifnum = 3,
 461				.type = QUIRK_MIDI_YAMAHA
 462			},
 463			{
 464				.ifnum = -1
 465			}
 466		}
 467	}
 468},
 469YAMAHA_DEVICE(0x2000, "DGP-7"),
 470YAMAHA_DEVICE(0x2001, "DGP-5"),
 471YAMAHA_DEVICE(0x2002, NULL),
 472YAMAHA_DEVICE(0x2003, NULL),
 473YAMAHA_DEVICE(0x5000, "CS1D"),
 474YAMAHA_DEVICE(0x5001, "DSP1D"),
 475YAMAHA_DEVICE(0x5002, "DME32"),
 476YAMAHA_DEVICE(0x5003, "DM2000"),
 477YAMAHA_DEVICE(0x5004, "02R96"),
 478YAMAHA_DEVICE(0x5005, "ACU16-C"),
 479YAMAHA_DEVICE(0x5006, "NHB32-C"),
 480YAMAHA_DEVICE(0x5007, "DM1000"),
 481YAMAHA_DEVICE(0x5008, "01V96"),
 482YAMAHA_DEVICE(0x5009, "SPX2000"),
 483YAMAHA_DEVICE(0x500a, "PM5D"),
 484YAMAHA_DEVICE(0x500b, "DME64N"),
 485YAMAHA_DEVICE(0x500c, "DME24N"),
 486YAMAHA_DEVICE(0x500d, NULL),
 487YAMAHA_DEVICE(0x500e, NULL),
 488YAMAHA_DEVICE(0x500f, NULL),
 489YAMAHA_DEVICE(0x7000, "DTX"),
 490YAMAHA_DEVICE(0x7010, "UB99"),
 491#undef YAMAHA_DEVICE
 492#undef YAMAHA_INTERFACE
 493/* this catches most recent vendor-specific Yamaha devices */
 494{
 495	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
 496	               USB_DEVICE_ID_MATCH_INT_CLASS,
 497	.idVendor = 0x0499,
 498	.bInterfaceClass = USB_CLASS_VENDOR_SPEC,
 499	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
 500		.ifnum = QUIRK_ANY_INTERFACE,
 501		.type = QUIRK_AUTODETECT
 502	}
 503},
 504
 505/*
 506 * Roland/RolandED/Edirol/BOSS devices
 507 */
 508{
 509	USB_DEVICE(0x0582, 0x0000),
 510	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 511		.vendor_name = "Roland",
 512		.product_name = "UA-100",
 513		.ifnum = QUIRK_ANY_INTERFACE,
 514		.type = QUIRK_COMPOSITE,
 515		.data = (const struct snd_usb_audio_quirk[]) {
 516			{
 517				.ifnum = 0,
 518				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
 519				.data = & (const struct audioformat) {
 520					.formats = SNDRV_PCM_FMTBIT_S16_LE,
 521					.channels = 4,
 522					.iface = 0,
 523					.altsetting = 1,
 524					.altset_idx = 1,
 525					.attributes = 0,
 526					.endpoint = 0x01,
 527					.ep_attr = 0x09,
 528					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 529					.rate_min = 44100,
 530					.rate_max = 44100,
 531				}
 532			},
 533			{
 534				.ifnum = 1,
 535				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
 536				.data = & (const struct audioformat) {
 537					.formats = SNDRV_PCM_FMTBIT_S16_LE,
 538					.channels = 2,
 539					.iface = 1,
 540					.altsetting = 1,
 541					.altset_idx = 1,
 542					.attributes = UAC_EP_CS_ATTR_FILL_MAX,
 543					.endpoint = 0x81,
 544					.ep_attr = 0x05,
 545					.rates = SNDRV_PCM_RATE_CONTINUOUS,
 546					.rate_min = 44100,
 547					.rate_max = 44100,
 548				}
 549			},
 550			{
 551				.ifnum = 2,
 552				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 553				.data = & (const struct snd_usb_midi_endpoint_info) {
 554					.out_cables = 0x0007,
 555					.in_cables  = 0x0007
 556				}
 557			},
 558			{
 559				.ifnum = -1
 560			}
 561		}
 562	}
 563},
 564{
 565	USB_DEVICE(0x0582, 0x0002),
 566	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 567		.vendor_name = "EDIROL",
 568		.product_name = "UM-4",
 569		.ifnum = QUIRK_ANY_INTERFACE,
 570		.type = QUIRK_COMPOSITE,
 571		.data = (const struct snd_usb_audio_quirk[]) {
 572			{
 573				.ifnum = 0,
 574				.type = QUIRK_IGNORE_INTERFACE
 575			},
 576			{
 577				.ifnum = 1,
 578				.type = QUIRK_IGNORE_INTERFACE
 579			},
 580			{
 581				.ifnum = 2,
 582				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 583				.data = & (const struct snd_usb_midi_endpoint_info) {
 584					.out_cables = 0x000f,
 585					.in_cables  = 0x000f
 586				}
 587			},
 588			{
 589				.ifnum = -1
 590			}
 591		}
 592	}
 593},
 594{
 595	USB_DEVICE(0x0582, 0x0003),
 596	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 597		.vendor_name = "Roland",
 598		.product_name = "SC-8850",
 599		.ifnum = QUIRK_ANY_INTERFACE,
 600		.type = QUIRK_COMPOSITE,
 601		.data = (const struct snd_usb_audio_quirk[]) {
 602			{
 603				.ifnum = 0,
 604				.type = QUIRK_IGNORE_INTERFACE
 605			},
 606			{
 607				.ifnum = 1,
 608				.type = QUIRK_IGNORE_INTERFACE
 609			},
 610			{
 611				.ifnum = 2,
 612				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 613				.data = & (const struct snd_usb_midi_endpoint_info) {
 614					.out_cables = 0x003f,
 615					.in_cables  = 0x003f
 616				}
 617			},
 618			{
 619				.ifnum = -1
 620			}
 621		}
 622	}
 623},
 624{
 625	USB_DEVICE(0x0582, 0x0004),
 626	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 627		.vendor_name = "Roland",
 628		.product_name = "U-8",
 629		.ifnum = QUIRK_ANY_INTERFACE,
 630		.type = QUIRK_COMPOSITE,
 631		.data = (const struct snd_usb_audio_quirk[]) {
 632			{
 633				.ifnum = 0,
 634				.type = QUIRK_IGNORE_INTERFACE
 635			},
 636			{
 637				.ifnum = 1,
 638				.type = QUIRK_IGNORE_INTERFACE
 639			},
 640			{
 641				.ifnum = 2,
 642				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 643				.data = & (const struct snd_usb_midi_endpoint_info) {
 644					.out_cables = 0x0005,
 645					.in_cables  = 0x0005
 646				}
 647			},
 648			{
 649				.ifnum = -1
 650			}
 651		}
 652	}
 653},
 654{
 655	/* Has ID 0x0099 when not in "Advanced Driver" mode.
 656	 * The UM-2EX has only one input, but we cannot detect this. */
 657	USB_DEVICE(0x0582, 0x0005),
 658	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 659		.vendor_name = "EDIROL",
 660		.product_name = "UM-2",
 661		.ifnum = QUIRK_ANY_INTERFACE,
 662		.type = QUIRK_COMPOSITE,
 663		.data = (const struct snd_usb_audio_quirk[]) {
 664			{
 665				.ifnum = 0,
 666				.type = QUIRK_IGNORE_INTERFACE
 667			},
 668			{
 669				.ifnum = 1,
 670				.type = QUIRK_IGNORE_INTERFACE
 671			},
 672			{
 673				.ifnum = 2,
 674				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 675				.data = & (const struct snd_usb_midi_endpoint_info) {
 676					.out_cables = 0x0003,
 677					.in_cables  = 0x0003
 678				}
 679			},
 680			{
 681				.ifnum = -1
 682			}
 683		}
 684	}
 685},
 686{
 687	USB_DEVICE(0x0582, 0x0007),
 688	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 689		.vendor_name = "Roland",
 690		.product_name = "SC-8820",
 691		.ifnum = QUIRK_ANY_INTERFACE,
 692		.type = QUIRK_COMPOSITE,
 693		.data = (const struct snd_usb_audio_quirk[]) {
 694			{
 695				.ifnum = 0,
 696				.type = QUIRK_IGNORE_INTERFACE
 697			},
 698			{
 699				.ifnum = 1,
 700				.type = QUIRK_IGNORE_INTERFACE
 701			},
 702			{
 703				.ifnum = 2,
 704				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 705				.data = & (const struct snd_usb_midi_endpoint_info) {
 706					.out_cables = 0x0013,
 707					.in_cables  = 0x0013
 708				}
 709			},
 710			{
 711				.ifnum = -1
 712			}
 713		}
 714	}
 715},
 716{
 717	USB_DEVICE(0x0582, 0x0008),
 718	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 719		.vendor_name = "Roland",
 720		.product_name = "PC-300",
 721		.ifnum = QUIRK_ANY_INTERFACE,
 722		.type = QUIRK_COMPOSITE,
 723		.data = (const struct snd_usb_audio_quirk[]) {
 724			{
 725				.ifnum = 0,
 726				.type = QUIRK_IGNORE_INTERFACE
 727			},
 728			{
 729				.ifnum = 1,
 730				.type = QUIRK_IGNORE_INTERFACE
 731			},
 732			{
 733				.ifnum = 2,
 734				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 735				.data = & (const struct snd_usb_midi_endpoint_info) {
 736					.out_cables = 0x0001,
 737					.in_cables  = 0x0001
 738				}
 739			},
 740			{
 741				.ifnum = -1
 742			}
 743		}
 744	}
 745},
 746{
 747	/* has ID 0x009d when not in "Advanced Driver" mode */
 748	USB_DEVICE(0x0582, 0x0009),
 749	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 750		.vendor_name = "EDIROL",
 751		.product_name = "UM-1",
 752		.ifnum = QUIRK_ANY_INTERFACE,
 753		.type = QUIRK_COMPOSITE,
 754		.data = (const struct snd_usb_audio_quirk[]) {
 755			{
 756				.ifnum = 0,
 757				.type = QUIRK_IGNORE_INTERFACE
 758			},
 759			{
 760				.ifnum = 1,
 761				.type = QUIRK_IGNORE_INTERFACE
 762			},
 763			{
 764				.ifnum = 2,
 765				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 766				.data = & (const struct snd_usb_midi_endpoint_info) {
 767					.out_cables = 0x0001,
 768					.in_cables  = 0x0001
 769				}
 770			},
 771			{
 772				.ifnum = -1
 773			}
 774		}
 775	}
 776},
 777{
 778	USB_DEVICE(0x0582, 0x000b),
 779	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 780		.vendor_name = "Roland",
 781		.product_name = "SK-500",
 782		.ifnum = QUIRK_ANY_INTERFACE,
 783		.type = QUIRK_COMPOSITE,
 784		.data = (const struct snd_usb_audio_quirk[]) {
 785			{
 786				.ifnum = 0,
 787				.type = QUIRK_IGNORE_INTERFACE
 788			},
 789			{
 790				.ifnum = 1,
 791				.type = QUIRK_IGNORE_INTERFACE
 792			},
 793			{
 794				.ifnum = 2,
 795				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 796				.data = & (const struct snd_usb_midi_endpoint_info) {
 797					.out_cables = 0x0013,
 798					.in_cables  = 0x0013
 799				}
 800			},
 801			{
 802				.ifnum = -1
 803			}
 804		}
 805	}
 806},
 807{
 808	/* thanks to Emiliano Grilli <emillo@libero.it>
 809	 * for helping researching this data */
 810	USB_DEVICE(0x0582, 0x000c),
 811	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 812		.vendor_name = "Roland",
 813		.product_name = "SC-D70",
 814		.ifnum = QUIRK_ANY_INTERFACE,
 815		.type = QUIRK_COMPOSITE,
 816		.data = (const struct snd_usb_audio_quirk[]) {
 817			{
 818				.ifnum = 0,
 819				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 820			},
 821			{
 822				.ifnum = 1,
 823				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 824			},
 825			{
 826				.ifnum = 2,
 827				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 828				.data = & (const struct snd_usb_midi_endpoint_info) {
 829					.out_cables = 0x0007,
 830					.in_cables  = 0x0007
 831				}
 832			},
 833			{
 834				.ifnum = -1
 835			}
 836		}
 837	}
 838},
 839{	/*
 840	 * This quirk is for the "Advanced Driver" mode of the Edirol UA-5.
 841	 * If the advanced mode switch at the back of the unit is off, the
 842	 * UA-5 has ID 0x0582/0x0011 and is standard compliant (no quirks),
 843	 * but offers only 16-bit PCM.
 844	 * In advanced mode, the UA-5 will output S24_3LE samples (two
 845	 * channels) at the rate indicated on the front switch, including
 846	 * the 96kHz sample rate.
 847	 */
 848	USB_DEVICE(0x0582, 0x0010),
 849	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 850		.vendor_name = "EDIROL",
 851		.product_name = "UA-5",
 852		.ifnum = QUIRK_ANY_INTERFACE,
 853		.type = QUIRK_COMPOSITE,
 854		.data = (const struct snd_usb_audio_quirk[]) {
 855			{
 856				.ifnum = 1,
 857				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 858			},
 859			{
 860				.ifnum = 2,
 861				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 862			},
 863			{
 864				.ifnum = -1
 865			}
 866		}
 867	}
 868},
 869{
 870	/* has ID 0x0013 when not in "Advanced Driver" mode */
 871	USB_DEVICE(0x0582, 0x0012),
 872	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 873		.vendor_name = "Roland",
 874		.product_name = "XV-5050",
 875		.ifnum = 0,
 876		.type = QUIRK_MIDI_FIXED_ENDPOINT,
 877		.data = & (const struct snd_usb_midi_endpoint_info) {
 878			.out_cables = 0x0001,
 879			.in_cables  = 0x0001
 880		}
 881	}
 882},
 883{
 884	/* has ID 0x0015 when not in "Advanced Driver" mode */
 885	USB_DEVICE(0x0582, 0x0014),
 886	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 887		.vendor_name = "EDIROL",
 888		.product_name = "UM-880",
 889		.ifnum = 0,
 890		.type = QUIRK_MIDI_FIXED_ENDPOINT,
 891		.data = & (const struct snd_usb_midi_endpoint_info) {
 892			.out_cables = 0x01ff,
 893			.in_cables  = 0x01ff
 894		}
 895	}
 896},
 897{
 898	/* has ID 0x0017 when not in "Advanced Driver" mode */
 899	USB_DEVICE(0x0582, 0x0016),
 900	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 901		.vendor_name = "EDIROL",
 902		.product_name = "SD-90",
 903		.ifnum = QUIRK_ANY_INTERFACE,
 904		.type = QUIRK_COMPOSITE,
 905		.data = (const struct snd_usb_audio_quirk[]) {
 906			{
 907				.ifnum = 0,
 908				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 909			},
 910			{
 911				.ifnum = 1,
 912				.type = QUIRK_AUDIO_STANDARD_INTERFACE
 913			},
 914			{
 915				.ifnum = 2,
 916				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 917				.data = & (const struct snd_usb_midi_endpoint_info) {
 918					.out_cables = 0x000f,
 919					.in_cables  = 0x000f
 920				}
 921			},
 922			{
 923				.ifnum = -1
 924			}
 925		}
 926	}
 927},
 928{
 929	/* has ID 0x001c when not in "Advanced Driver" mode */
 930	USB_DEVICE(0x0582, 0x001b),
 931	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 932		.vendor_name = "Roland",
 933		.product_name = "MMP-2",
 934		.ifnum = QUIRK_ANY_INTERFACE,
 935		.type = QUIRK_COMPOSITE,
 936		.data = (const struct snd_usb_audio_quirk[]) {
 937			{
 938				.ifnum = 0,
 939				.type = QUIRK_IGNORE_INTERFACE
 940			},
 941			{
 942				.ifnum = 1,
 943				.type = QUIRK_IGNORE_INTERFACE
 944			},
 945			{
 946				.ifnum = 2,
 947				.type = QUIRK_MIDI_FIXED_ENDPOINT,
 948				.data = & (const struct snd_usb_midi_endpoint_info) {
 949					.out_cables = 0x0001,
 950					.in_cables  = 0x0001
 951				}
 952			},
 953			{
 954				.ifnum = -1
 955			}
 956		}
 957	}
 958},
 959{
 960	/* has ID 0x001e when not in "Advanced Driver" mode */
 961	USB_DEVICE(0x0582, 0x001d),
 962	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 963		.vendor_name = "Roland",
 964		.product_name = "V-SYNTH",
 965		.ifnum = 0,
 966		.type = QUIRK_MIDI_FIXED_ENDPOINT,
 967		.data = & (const struct snd_usb_midi_endpoint_info) {
 968			.out_cables = 0x0001,
 969			.in_cables  = 0x0001
 970		}
 971	}
 972},
 973{
 974	/* has ID 0x0024 when not in "Advanced Driver" mode */
 975	USB_DEVICE(0x0582, 0x0023),
 976	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 977		.vendor_name = "EDIROL",
 978		.product_name = "UM-550",
 979		.ifnum = 0,
 980		.type = QUIRK_MIDI_FIXED_ENDPOINT,
 981		.data = & (const struct snd_usb_midi_endpoint_info) {
 982			.out_cables = 0x003f,
 983			.in_cables  = 0x003f
 984		}
 985	}
 986},
 987{
 988	/*
 989	 * This quirk is for the "Advanced Driver" mode. If off, the UA-20
 990	 * has ID 0x0026 and is standard compliant, but has only 16-bit PCM
 991	 * and no MIDI.
 992	 */
 993	USB_DEVICE(0x0582, 0x0025),
 994	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 995		.vendor_name = "EDIROL",
 996		.product_name = "UA-20",
 997		.ifnum = QUIRK_ANY_INTERFACE,
 998		.type = QUIRK_COMPOSITE,
 999		.data = (const struct snd_usb_audio_quirk[]) {
1000			{
1001				.ifnum = 0,
1002				.type = QUIRK_IGNORE_INTERFACE
1003			},
1004			{
1005				.ifnum = 1,
1006				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1007				.data = & (const struct audioformat) {
1008					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1009					.channels = 2,
1010					.iface = 1,
1011					.altsetting = 1,
1012					.altset_idx = 1,
1013					.attributes = 0,
1014					.endpoint = 0x01,
1015					.ep_attr = 0x01,
1016					.rates = SNDRV_PCM_RATE_CONTINUOUS,
1017					.rate_min = 44100,
1018					.rate_max = 44100,
1019				}
1020			},
1021			{
1022				.ifnum = 2,
1023				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1024				.data = & (const struct audioformat) {
1025					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
1026					.channels = 2,
1027					.iface = 2,
1028					.altsetting = 1,
1029					.altset_idx = 1,
1030					.attributes = 0,
1031					.endpoint = 0x82,
1032					.ep_attr = 0x01,
1033					.rates = SNDRV_PCM_RATE_CONTINUOUS,
1034					.rate_min = 44100,
1035					.rate_max = 44100,
1036				}
1037			},
1038			{
1039				.ifnum = 3,
1040				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1041				.data = & (const struct snd_usb_midi_endpoint_info) {
1042					.out_cables = 0x0001,
1043					.in_cables  = 0x0001
1044				}
1045			},
1046			{
1047				.ifnum = -1
1048			}
1049		}
1050	}
1051},
1052{
1053	/* has ID 0x0028 when not in "Advanced Driver" mode */
1054	USB_DEVICE(0x0582, 0x0027),
1055	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1056		.vendor_name = "EDIROL",
1057		.product_name = "SD-20",
1058		.ifnum = 0,
1059		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1060		.data = & (const struct snd_usb_midi_endpoint_info) {
1061			.out_cables = 0x0003,
1062			.in_cables  = 0x0007
1063		}
1064	}
1065},
1066{
1067	/* has ID 0x002a when not in "Advanced Driver" mode */
1068	USB_DEVICE(0x0582, 0x0029),
1069	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1070		.vendor_name = "EDIROL",
1071		.product_name = "SD-80",
1072		.ifnum = 0,
1073		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1074		.data = & (const struct snd_usb_midi_endpoint_info) {
1075			.out_cables = 0x000f,
1076			.in_cables  = 0x000f
1077		}
1078	}
1079},
1080{	/*
1081	 * This quirk is for the "Advanced" modes of the Edirol UA-700.
1082	 * If the sample format switch is not in an advanced setting, the
1083	 * UA-700 has ID 0x0582/0x002c and is standard compliant (no quirks),
1084	 * but offers only 16-bit PCM and no MIDI.
1085	 */
1086	USB_DEVICE_VENDOR_SPEC(0x0582, 0x002b),
1087	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1088		.vendor_name = "EDIROL",
1089		.product_name = "UA-700",
1090		.ifnum = QUIRK_ANY_INTERFACE,
1091		.type = QUIRK_COMPOSITE,
1092		.data = (const struct snd_usb_audio_quirk[]) {
1093			{
1094				.ifnum = 1,
1095				.type = QUIRK_AUDIO_EDIROL_UAXX
1096			},
1097			{
1098				.ifnum = 2,
1099				.type = QUIRK_AUDIO_EDIROL_UAXX
1100			},
1101			{
1102				.ifnum = 3,
1103				.type = QUIRK_AUDIO_EDIROL_UAXX
1104			},
1105			{
1106				.ifnum = -1
1107			}
1108		}
1109	}
1110},
1111{
1112	/* has ID 0x002e when not in "Advanced Driver" mode */
1113	USB_DEVICE(0x0582, 0x002d),
1114	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1115		.vendor_name = "Roland",
1116		.product_name = "XV-2020",
1117		.ifnum = 0,
1118		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1119		.data = & (const struct snd_usb_midi_endpoint_info) {
1120			.out_cables = 0x0001,
1121			.in_cables  = 0x0001
1122		}
1123	}
1124},
1125{
1126	/* has ID 0x0030 when not in "Advanced Driver" mode */
1127	USB_DEVICE(0x0582, 0x002f),
1128	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1129		.vendor_name = "Roland",
1130		.product_name = "VariOS",
1131		.ifnum = 0,
1132		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1133		.data = & (const struct snd_usb_midi_endpoint_info) {
1134			.out_cables = 0x0007,
1135			.in_cables  = 0x0007
1136		}
1137	}
1138},
1139{
1140	/* has ID 0x0034 when not in "Advanced Driver" mode */
1141	USB_DEVICE(0x0582, 0x0033),
1142	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1143		.vendor_name = "EDIROL",
1144		.product_name = "PCR",
1145		.ifnum = 0,
1146		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1147		.data = & (const struct snd_usb_midi_endpoint_info) {
1148			.out_cables = 0x0003,
1149			.in_cables  = 0x0007
1150		}
1151	}
1152},
1153{
1154	/*
1155	 * Has ID 0x0038 when not in "Advanced Driver" mode;
1156	 * later revisions use IDs 0x0054 and 0x00a2.
1157	 */
1158	USB_DEVICE(0x0582, 0x0037),
1159	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1160		.vendor_name = "Roland",
1161		.product_name = "Digital Piano",
1162		.ifnum = 0,
1163		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1164		.data = & (const struct snd_usb_midi_endpoint_info) {
1165			.out_cables = 0x0001,
1166			.in_cables  = 0x0001
1167		}
1168	}
1169},
1170{
1171	/*
1172	 * This quirk is for the "Advanced Driver" mode.  If off, the GS-10
1173	 * has ID 0x003c and is standard compliant, but has only 16-bit PCM
1174	 * and no MIDI.
1175	 */
1176	USB_DEVICE_VENDOR_SPEC(0x0582, 0x003b),
1177	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1178		.vendor_name = "BOSS",
1179		.product_name = "GS-10",
1180		.ifnum = QUIRK_ANY_INTERFACE,
1181		.type = QUIRK_COMPOSITE,
1182		.data = & (const struct snd_usb_audio_quirk[]) {
1183			{
1184				.ifnum = 1,
1185				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1186			},
1187			{
1188				.ifnum = 2,
1189				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1190			},
1191			{
1192				.ifnum = 3,
1193				.type = QUIRK_MIDI_STANDARD_INTERFACE
1194			},
1195			{
1196				.ifnum = -1
1197			}
1198		}
1199	}
1200},
1201{
1202	/* has ID 0x0041 when not in "Advanced Driver" mode */
1203	USB_DEVICE(0x0582, 0x0040),
1204	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1205		.vendor_name = "Roland",
1206		.product_name = "GI-20",
1207		.ifnum = 0,
1208		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1209		.data = & (const struct snd_usb_midi_endpoint_info) {
1210			.out_cables = 0x0001,
1211			.in_cables  = 0x0001
1212		}
1213	}
1214},
1215{
1216	/* has ID 0x0043 when not in "Advanced Driver" mode */
1217	USB_DEVICE(0x0582, 0x0042),
1218	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1219		.vendor_name = "Roland",
1220		.product_name = "RS-70",
1221		.ifnum = 0,
1222		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1223		.data = & (const struct snd_usb_midi_endpoint_info) {
1224			.out_cables = 0x0001,
1225			.in_cables  = 0x0001
1226		}
1227	}
1228},
1229{
1230	/* has ID 0x0049 when not in "Advanced Driver" mode */
1231	USB_DEVICE(0x0582, 0x0047),
1232	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1233		/* .vendor_name = "EDIROL", */
1234		/* .product_name = "UR-80", */
1235		.ifnum = QUIRK_ANY_INTERFACE,
1236		.type = QUIRK_COMPOSITE,
1237		.data = (const struct snd_usb_audio_quirk[]) {
1238			/* in the 96 kHz modes, only interface 1 is there */
1239			{
1240				.ifnum = 1,
1241				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1242			},
1243			{
1244				.ifnum = 2,
1245				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1246			},
1247			{
1248				.ifnum = -1
1249			}
1250		}
1251	}
1252},
1253{
1254	/* has ID 0x004a when not in "Advanced Driver" mode */
1255	USB_DEVICE(0x0582, 0x0048),
1256	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1257		/* .vendor_name = "EDIROL", */
1258		/* .product_name = "UR-80", */
1259		.ifnum = 0,
1260		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1261		.data = & (const struct snd_usb_midi_endpoint_info) {
1262			.out_cables = 0x0003,
1263			.in_cables  = 0x0007
1264		}
1265	}
1266},
1267{
1268	/* has ID 0x004e when not in "Advanced Driver" mode */
1269	USB_DEVICE(0x0582, 0x004c),
1270	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1271		.vendor_name = "EDIROL",
1272		.product_name = "PCR-A",
1273		.ifnum = QUIRK_ANY_INTERFACE,
1274		.type = QUIRK_COMPOSITE,
1275		.data = (const struct snd_usb_audio_quirk[]) {
1276			{
1277				.ifnum = 1,
1278				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1279			},
1280			{
1281				.ifnum = 2,
1282				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1283			},
1284			{
1285				.ifnum = -1
1286			}
1287		}
1288	}
1289},
1290{
1291	/* has ID 0x004f when not in "Advanced Driver" mode */
1292	USB_DEVICE(0x0582, 0x004d),
1293	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1294		.vendor_name = "EDIROL",
1295		.product_name = "PCR-A",
1296		.ifnum = 0,
1297		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1298		.data = & (const struct snd_usb_midi_endpoint_info) {
1299			.out_cables = 0x0003,
1300			.in_cables  = 0x0007
1301		}
1302	}
1303},
1304{
1305	/*
1306	 * This quirk is for the "Advanced Driver" mode. If off, the UA-3FX
1307	 * is standard compliant, but has only 16-bit PCM.
1308	 */
1309	USB_DEVICE(0x0582, 0x0050),
1310	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1311		.vendor_name = "EDIROL",
1312		.product_name = "UA-3FX",
1313		.ifnum = QUIRK_ANY_INTERFACE,
1314		.type = QUIRK_COMPOSITE,
1315		.data = (const struct snd_usb_audio_quirk[]) {
1316			{
1317				.ifnum = 1,
1318				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1319			},
1320			{
1321				.ifnum = 2,
1322				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1323			},
1324			{
1325				.ifnum = -1
1326			}
1327		}
1328	}
1329},
1330{
1331	USB_DEVICE(0x0582, 0x0052),
1332	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1333		.vendor_name = "EDIROL",
1334		.product_name = "UM-1SX",
1335		.ifnum = 0,
1336		.type = QUIRK_MIDI_STANDARD_INTERFACE
1337	}
1338},
1339{
1340	USB_DEVICE(0x0582, 0x0060),
1341	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1342		.vendor_name = "Roland",
1343		.product_name = "EXR Series",
1344		.ifnum = 0,
1345		.type = QUIRK_MIDI_STANDARD_INTERFACE
1346	}
1347},
1348{
1349	/* has ID 0x0066 when not in "Advanced Driver" mode */
1350	USB_DEVICE(0x0582, 0x0064),
1351	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1352		/* .vendor_name = "EDIROL", */
1353		/* .product_name = "PCR-1", */
1354		.ifnum = QUIRK_ANY_INTERFACE,
1355		.type = QUIRK_COMPOSITE,
1356		.data = (const struct snd_usb_audio_quirk[]) {
1357			{
1358				.ifnum = 1,
1359				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1360			},
1361			{
1362				.ifnum = 2,
1363				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1364			},
1365			{
1366				.ifnum = -1
1367			}
1368		}
1369	}
1370},
1371{
1372	/* has ID 0x0067 when not in "Advanced Driver" mode */
1373	USB_DEVICE(0x0582, 0x0065),
1374	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1375		/* .vendor_name = "EDIROL", */
1376		/* .product_name = "PCR-1", */
1377		.ifnum = 0,
1378		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1379		.data = & (const struct snd_usb_midi_endpoint_info) {
1380			.out_cables = 0x0001,
1381			.in_cables  = 0x0003
1382		}
1383	}
1384},
1385{
1386	/* has ID 0x006e when not in "Advanced Driver" mode */
1387	USB_DEVICE(0x0582, 0x006d),
1388	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1389		.vendor_name = "Roland",
1390		.product_name = "FANTOM-X",
1391		.ifnum = 0,
1392		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1393		.data = & (const struct snd_usb_midi_endpoint_info) {
1394			.out_cables = 0x0001,
1395			.in_cables  = 0x0001
1396		}
1397	}
1398},
1399{	/*
1400	 * This quirk is for the "Advanced" modes of the Edirol UA-25.
1401	 * If the switch is not in an advanced setting, the UA-25 has
1402	 * ID 0x0582/0x0073 and is standard compliant (no quirks), but
1403	 * offers only 16-bit PCM at 44.1 kHz and no MIDI.
1404	 */
1405	USB_DEVICE_VENDOR_SPEC(0x0582, 0x0074),
1406	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1407		.vendor_name = "EDIROL",
1408		.product_name = "UA-25",
1409		.ifnum = QUIRK_ANY_INTERFACE,
1410		.type = QUIRK_COMPOSITE,
1411		.data = (const struct snd_usb_audio_quirk[]) {
1412			{
1413				.ifnum = 0,
1414				.type = QUIRK_AUDIO_EDIROL_UAXX
1415			},
1416			{
1417				.ifnum = 1,
1418				.type = QUIRK_AUDIO_EDIROL_UAXX
1419			},
1420			{
1421				.ifnum = 2,
1422				.type = QUIRK_AUDIO_EDIROL_UAXX
1423			},
1424			{
1425				.ifnum = -1
1426			}
1427		}
1428	}
1429},
1430{
1431	/* has ID 0x0076 when not in "Advanced Driver" mode */
1432	USB_DEVICE(0x0582, 0x0075),
1433	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1434		.vendor_name = "BOSS",
1435		.product_name = "DR-880",
1436		.ifnum = 0,
1437		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1438		.data = & (const struct snd_usb_midi_endpoint_info) {
1439			.out_cables = 0x0001,
1440			.in_cables  = 0x0001
1441		}
1442	}
1443},
1444{
1445	/* has ID 0x007b when not in "Advanced Driver" mode */
1446	USB_DEVICE_VENDOR_SPEC(0x0582, 0x007a),
1447	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1448		.vendor_name = "Roland",
1449		/* "RD" or "RD-700SX"? */
1450		.ifnum = 0,
1451		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1452		.data = & (const struct snd_usb_midi_endpoint_info) {
1453			.out_cables = 0x0003,
1454			.in_cables  = 0x0003
1455		}
1456	}
1457},
1458{
1459	/* has ID 0x0081 when not in "Advanced Driver" mode */
1460	USB_DEVICE(0x0582, 0x0080),
1461	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1462		.vendor_name = "Roland",
1463		.product_name = "G-70",
1464		.ifnum = 0,
1465		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1466		.data = & (const struct snd_usb_midi_endpoint_info) {
1467			.out_cables = 0x0001,
1468			.in_cables  = 0x0001
1469		}
1470	}
1471},
1472{
1473	/* has ID 0x008c when not in "Advanced Driver" mode */
1474	USB_DEVICE(0x0582, 0x008b),
1475	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1476		.vendor_name = "EDIROL",
1477		.product_name = "PC-50",
1478		.ifnum = 0,
1479		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1480		.data = & (const struct snd_usb_midi_endpoint_info) {
1481			.out_cables = 0x0001,
1482			.in_cables  = 0x0001
1483		}
1484	}
1485},
1486{
1487	/*
1488	 * This quirk is for the "Advanced Driver" mode. If off, the UA-4FX
1489	 * is standard compliant, but has only 16-bit PCM and no MIDI.
1490	 */
1491	USB_DEVICE(0x0582, 0x00a3),
1492	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1493		.vendor_name = "EDIROL",
1494		.product_name = "UA-4FX",
1495		.ifnum = QUIRK_ANY_INTERFACE,
1496		.type = QUIRK_COMPOSITE,
1497		.data = (const struct snd_usb_audio_quirk[]) {
1498			{
1499				.ifnum = 0,
1500				.type = QUIRK_AUDIO_EDIROL_UAXX
1501			},
1502			{
1503				.ifnum = 1,
1504				.type = QUIRK_AUDIO_EDIROL_UAXX
1505			},
1506			{
1507				.ifnum = 2,
1508				.type = QUIRK_AUDIO_EDIROL_UAXX
1509			},
1510			{
1511				.ifnum = -1
1512			}
1513		}
1514	}
1515},
1516{
1517	/* Edirol M-16DX */
1518	USB_DEVICE(0x0582, 0x00c4),
1519	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1520		.ifnum = QUIRK_ANY_INTERFACE,
1521		.type = QUIRK_COMPOSITE,
1522		.data = (const struct snd_usb_audio_quirk[]) {
1523			{
1524				.ifnum = 0,
1525				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1526			},
1527			{
1528				.ifnum = 1,
1529				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1530			},
1531			{
1532				.ifnum = 2,
1533				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1534				.data = & (const struct snd_usb_midi_endpoint_info) {
1535					.out_cables = 0x0001,
1536					.in_cables  = 0x0001
1537				}
1538			},
1539			{
1540				.ifnum = -1
1541			}
1542		}
1543	}
1544},
1545{
1546	/* Advanced modes of the Edirol UA-25EX.
1547	 * For the standard mode, UA-25EX has ID 0582:00e7, which
1548	 * offers only 16-bit PCM at 44.1 kHz and no MIDI.
1549	 */
1550	USB_DEVICE_VENDOR_SPEC(0x0582, 0x00e6),
1551	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1552		.vendor_name = "EDIROL",
1553		.product_name = "UA-25EX",
1554		.ifnum = QUIRK_ANY_INTERFACE,
1555		.type = QUIRK_COMPOSITE,
1556		.data = (const struct snd_usb_audio_quirk[]) {
1557			{
1558				.ifnum = 0,
1559				.type = QUIRK_AUDIO_EDIROL_UAXX
1560			},
1561			{
1562				.ifnum = 1,
1563				.type = QUIRK_AUDIO_EDIROL_UAXX
1564			},
1565			{
1566				.ifnum = 2,
1567				.type = QUIRK_AUDIO_EDIROL_UAXX
1568			},
1569			{
1570				.ifnum = -1
1571			}
1572		}
1573	}
1574},
1575{
1576	/* Edirol UM-3G */
1577	USB_DEVICE_VENDOR_SPEC(0x0582, 0x0108),
1578	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1579		.ifnum = 0,
1580		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1581		.data = & (const struct snd_usb_midi_endpoint_info) {
1582			.out_cables = 0x0007,
1583			.in_cables  = 0x0007
1584		}
1585	}
1586},
1587{
1588	/* BOSS ME-25 */
1589	USB_DEVICE(0x0582, 0x0113),
1590	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1591		.ifnum = QUIRK_ANY_INTERFACE,
1592		.type = QUIRK_COMPOSITE,
1593		.data = (const struct snd_usb_audio_quirk[]) {
1594			{
1595				.ifnum = 0,
1596				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1597			},
1598			{
1599				.ifnum = 1,
1600				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1601			},
1602			{
1603				.ifnum = 2,
1604				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1605				.data = & (const struct snd_usb_midi_endpoint_info) {
1606					.out_cables = 0x0001,
1607					.in_cables  = 0x0001
1608				}
1609			},
1610			{
1611				.ifnum = -1
1612			}
1613		}
1614	}
1615},
1616{
1617	/* only 44.1 kHz works at the moment */
1618	USB_DEVICE(0x0582, 0x0120),
1619	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1620		/* .vendor_name = "Roland", */
1621		/* .product_name = "OCTO-CAPTURE", */
1622		.ifnum = QUIRK_ANY_INTERFACE,
1623		.type = QUIRK_COMPOSITE,
1624		.data = (const struct snd_usb_audio_quirk[]) {
1625			{
1626				.ifnum = 0,
1627				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1628				.data = & (const struct audioformat) {
1629					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1630					.channels = 10,
1631					.iface = 0,
1632					.altsetting = 1,
1633					.altset_idx = 1,
1634					.endpoint = 0x05,
1635					.ep_attr = 0x05,
1636					.rates = SNDRV_PCM_RATE_44100,
1637					.rate_min = 44100,
1638					.rate_max = 44100,
1639					.nr_rates = 1,
1640					.rate_table = (unsigned int[]) { 44100 }
1641				}
1642			},
1643			{
1644				.ifnum = 1,
1645				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1646				.data = & (const struct audioformat) {
1647					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1648					.channels = 12,
1649					.iface = 1,
1650					.altsetting = 1,
1651					.altset_idx = 1,
1652					.endpoint = 0x85,
1653					.ep_attr = 0x25,
1654					.rates = SNDRV_PCM_RATE_44100,
1655					.rate_min = 44100,
1656					.rate_max = 44100,
1657					.nr_rates = 1,
1658					.rate_table = (unsigned int[]) { 44100 }
1659				}
1660			},
1661			{
1662				.ifnum = 2,
1663				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1664				.data = & (const struct snd_usb_midi_endpoint_info) {
1665					.out_cables = 0x0001,
1666					.in_cables  = 0x0001
1667				}
1668			},
1669			{
1670				.ifnum = 3,
1671				.type = QUIRK_IGNORE_INTERFACE
1672			},
1673			{
1674				.ifnum = 4,
1675				.type = QUIRK_IGNORE_INTERFACE
1676			},
1677			{
1678				.ifnum = -1
1679			}
1680		}
1681	}
1682},
1683{
1684	/* only 44.1 kHz works at the moment */
1685	USB_DEVICE(0x0582, 0x012f),
1686	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1687		/* .vendor_name = "Roland", */
1688		/* .product_name = "QUAD-CAPTURE", */
1689		.ifnum = QUIRK_ANY_INTERFACE,
1690		.type = QUIRK_COMPOSITE,
1691		.data = (const struct snd_usb_audio_quirk[]) {
1692			{
1693				.ifnum = 0,
1694				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1695				.data = & (const struct audioformat) {
1696					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1697					.channels = 4,
1698					.iface = 0,
1699					.altsetting = 1,
1700					.altset_idx = 1,
1701					.endpoint = 0x05,
1702					.ep_attr = 0x05,
1703					.rates = SNDRV_PCM_RATE_44100,
1704					.rate_min = 44100,
1705					.rate_max = 44100,
1706					.nr_rates = 1,
1707					.rate_table = (unsigned int[]) { 44100 }
1708				}
1709			},
1710			{
1711				.ifnum = 1,
1712				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
1713				.data = & (const struct audioformat) {
1714					.formats = SNDRV_PCM_FMTBIT_S32_LE,
1715					.channels = 6,
1716					.iface = 1,
1717					.altsetting = 1,
1718					.altset_idx = 1,
1719					.endpoint = 0x85,
1720					.ep_attr = 0x25,
1721					.rates = SNDRV_PCM_RATE_44100,
1722					.rate_min = 44100,
1723					.rate_max = 44100,
1724					.nr_rates = 1,
1725					.rate_table = (unsigned int[]) { 44100 }
1726				}
1727			},
1728			{
1729				.ifnum = 2,
1730				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1731				.data = & (const struct snd_usb_midi_endpoint_info) {
1732					.out_cables = 0x0001,
1733					.in_cables  = 0x0001
1734				}
1735			},
1736			{
1737				.ifnum = 3,
1738				.type = QUIRK_IGNORE_INTERFACE
1739			},
1740			{
1741				.ifnum = 4,
1742				.type = QUIRK_IGNORE_INTERFACE
1743			},
1744			{
1745				.ifnum = -1
1746			}
1747		}
1748	}
1749},
1750{
1751	USB_DEVICE(0x0582, 0x0159),
1752	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1753		/* .vendor_name = "Roland", */
1754		/* .product_name = "UA-22", */
1755		.ifnum = QUIRK_ANY_INTERFACE,
1756		.type = QUIRK_COMPOSITE,
1757		.data = (const struct snd_usb_audio_quirk[]) {
1758			{
1759				.ifnum = 0,
1760				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1761			},
1762			{
1763				.ifnum = 1,
1764				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1765			},
1766			{
1767				.ifnum = 2,
1768				.type = QUIRK_MIDI_FIXED_ENDPOINT,
1769				.data = & (const struct snd_usb_midi_endpoint_info) {
1770					.out_cables = 0x0001,
1771					.in_cables = 0x0001
1772				}
1773			},
1774			{
1775				.ifnum = -1
1776			}
1777		}
1778	}
1779},
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1780/* this catches most recent vendor-specific Roland devices */
1781{
1782	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
1783	               USB_DEVICE_ID_MATCH_INT_CLASS,
1784	.idVendor = 0x0582,
1785	.bInterfaceClass = USB_CLASS_VENDOR_SPEC,
1786	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
1787		.ifnum = QUIRK_ANY_INTERFACE,
1788		.type = QUIRK_AUTODETECT
1789	}
1790},
1791
1792/* Guillemot devices */
1793{
1794	/*
1795	 * This is for the "Windows Edition" where the external MIDI ports are
1796	 * the only MIDI ports; the control data is reported through HID
1797	 * interfaces.  The "Macintosh Edition" has ID 0xd002 and uses standard
1798	 * compliant USB MIDI ports for external MIDI and controls.
1799	 */
1800	USB_DEVICE_VENDOR_SPEC(0x06f8, 0xb000),
1801	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1802		.vendor_name = "Hercules",
1803		.product_name = "DJ Console (WE)",
1804		.ifnum = 4,
1805		.type = QUIRK_MIDI_FIXED_ENDPOINT,
1806		.data = & (const struct snd_usb_midi_endpoint_info) {
1807			.out_cables = 0x0001,
1808			.in_cables = 0x0001
1809		}
1810	}
1811},
1812
1813/* Midiman/M-Audio devices */
1814{
1815	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1002),
1816	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1817		.vendor_name = "M-Audio",
1818		.product_name = "MidiSport 2x2",
1819		.ifnum = QUIRK_ANY_INTERFACE,
1820		.type = QUIRK_MIDI_MIDIMAN,
1821		.data = & (const struct snd_usb_midi_endpoint_info) {
1822			.out_cables = 0x0003,
1823			.in_cables  = 0x0003
1824		}
1825	}
1826},
1827{
1828	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1011),
1829	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1830		.vendor_name = "M-Audio",
1831		.product_name = "MidiSport 1x1",
1832		.ifnum = QUIRK_ANY_INTERFACE,
1833		.type = QUIRK_MIDI_MIDIMAN,
1834		.data = & (const struct snd_usb_midi_endpoint_info) {
1835			.out_cables = 0x0001,
1836			.in_cables  = 0x0001
1837		}
1838	}
1839},
1840{
1841	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1015),
1842	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1843		.vendor_name = "M-Audio",
1844		.product_name = "Keystation",
1845		.ifnum = QUIRK_ANY_INTERFACE,
1846		.type = QUIRK_MIDI_MIDIMAN,
1847		.data = & (const struct snd_usb_midi_endpoint_info) {
1848			.out_cables = 0x0001,
1849			.in_cables  = 0x0001
1850		}
1851	}
1852},
1853{
1854	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1021),
1855	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1856		.vendor_name = "M-Audio",
1857		.product_name = "MidiSport 4x4",
1858		.ifnum = QUIRK_ANY_INTERFACE,
1859		.type = QUIRK_MIDI_MIDIMAN,
1860		.data = & (const struct snd_usb_midi_endpoint_info) {
1861			.out_cables = 0x000f,
1862			.in_cables  = 0x000f
1863		}
1864	}
1865},
1866{
1867	/*
1868	 * For hardware revision 1.05; in the later revisions (1.10 and
1869	 * 1.21), 0x1031 is the ID for the device without firmware.
1870	 * Thanks to Olaf Giesbrecht <Olaf_Giesbrecht@yahoo.de>
1871	 */
1872	USB_DEVICE_VER(0x0763, 0x1031, 0x0100, 0x0109),
1873	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1874		.vendor_name = "M-Audio",
1875		.product_name = "MidiSport 8x8",
1876		.ifnum = QUIRK_ANY_INTERFACE,
1877		.type = QUIRK_MIDI_MIDIMAN,
1878		.data = & (const struct snd_usb_midi_endpoint_info) {
1879			.out_cables = 0x01ff,
1880			.in_cables  = 0x01ff
1881		}
1882	}
1883},
1884{
1885	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1033),
1886	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1887		.vendor_name = "M-Audio",
1888		.product_name = "MidiSport 8x8",
1889		.ifnum = QUIRK_ANY_INTERFACE,
1890		.type = QUIRK_MIDI_MIDIMAN,
1891		.data = & (const struct snd_usb_midi_endpoint_info) {
1892			.out_cables = 0x01ff,
1893			.in_cables  = 0x01ff
1894		}
1895	}
1896},
1897{
1898	USB_DEVICE_VENDOR_SPEC(0x0763, 0x1041),
1899	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1900		.vendor_name = "M-Audio",
1901		.product_name = "MidiSport 2x4",
1902		.ifnum = QUIRK_ANY_INTERFACE,
1903		.type = QUIRK_MIDI_MIDIMAN,
1904		.data = & (const struct snd_usb_midi_endpoint_info) {
1905			.out_cables = 0x000f,
1906			.in_cables  = 0x0003
1907		}
1908	}
1909},
1910{
1911	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2001),
1912	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1913		.vendor_name = "M-Audio",
1914		.product_name = "Quattro",
1915		.ifnum = QUIRK_ANY_INTERFACE,
1916		.type = QUIRK_COMPOSITE,
1917		.data = & (const struct snd_usb_audio_quirk[]) {
1918			/*
1919			 * Interfaces 0-2 are "Windows-compatible", 16-bit only,
1920			 * and share endpoints with the other interfaces.
1921			 * Ignore them.  The other interfaces can do 24 bits,
1922			 * but captured samples are big-endian (see usbaudio.c).
1923			 */
 
 
 
 
 
 
 
 
 
1924			{
1925				.ifnum = 0,
1926				.type = QUIRK_IGNORE_INTERFACE
1927			},
1928			{
1929				.ifnum = 1,
1930				.type = QUIRK_IGNORE_INTERFACE
1931			},
1932			{
1933				.ifnum = 2,
1934				.type = QUIRK_IGNORE_INTERFACE
1935			},
1936			{
1937				.ifnum = 3,
1938				.type = QUIRK_IGNORE_INTERFACE
1939			},
1940			{
1941				.ifnum = 4,
1942				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1943			},
1944			{
1945				.ifnum = 5,
1946				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1947			},
1948			{
1949				.ifnum = 6,
1950				.type = QUIRK_IGNORE_INTERFACE
1951			},
1952			{
1953				.ifnum = 7,
1954				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1955			},
1956			{
1957				.ifnum = 8,
1958				.type = QUIRK_AUDIO_STANDARD_INTERFACE
1959			},
1960			{
1961				.ifnum = 9,
1962				.type = QUIRK_MIDI_MIDIMAN,
1963				.data = & (const struct snd_usb_midi_endpoint_info) {
1964					.out_cables = 0x0001,
1965					.in_cables  = 0x0001
1966				}
1967			},
1968			{
1969				.ifnum = -1
1970			}
1971		}
1972	}
1973},
1974{
1975	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2003),
1976	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1977		.vendor_name = "M-Audio",
1978		.product_name = "AudioPhile",
1979		.ifnum = 6,
1980		.type = QUIRK_MIDI_MIDIMAN,
1981		.data = & (const struct snd_usb_midi_endpoint_info) {
1982			.out_cables = 0x0001,
1983			.in_cables  = 0x0001
1984		}
1985	}
1986},
1987{
1988	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2008),
1989	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
1990		.vendor_name = "M-Audio",
1991		.product_name = "Ozone",
1992		.ifnum = 3,
1993		.type = QUIRK_MIDI_MIDIMAN,
1994		.data = & (const struct snd_usb_midi_endpoint_info) {
1995			.out_cables = 0x0001,
1996			.in_cables  = 0x0001
1997		}
1998	}
1999},
2000{
2001	USB_DEVICE_VENDOR_SPEC(0x0763, 0x200d),
2002	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2003		.vendor_name = "M-Audio",
2004		.product_name = "OmniStudio",
2005		.ifnum = QUIRK_ANY_INTERFACE,
2006		.type = QUIRK_COMPOSITE,
2007		.data = & (const struct snd_usb_audio_quirk[]) {
2008			{
2009				.ifnum = 0,
2010				.type = QUIRK_IGNORE_INTERFACE
2011			},
2012			{
2013				.ifnum = 1,
2014				.type = QUIRK_IGNORE_INTERFACE
2015			},
2016			{
2017				.ifnum = 2,
2018				.type = QUIRK_IGNORE_INTERFACE
2019			},
2020			{
2021				.ifnum = 3,
2022				.type = QUIRK_IGNORE_INTERFACE
2023			},
2024			{
2025				.ifnum = 4,
2026				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2027			},
2028			{
2029				.ifnum = 5,
2030				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2031			},
2032			{
2033				.ifnum = 6,
2034				.type = QUIRK_IGNORE_INTERFACE
2035			},
2036			{
2037				.ifnum = 7,
2038				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2039			},
2040			{
2041				.ifnum = 8,
2042				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2043			},
2044			{
2045				.ifnum = 9,
2046				.type = QUIRK_MIDI_MIDIMAN,
2047				.data = & (const struct snd_usb_midi_endpoint_info) {
2048					.out_cables = 0x0001,
2049					.in_cables  = 0x0001
2050				}
2051			},
2052			{
2053				.ifnum = -1
2054			}
2055		}
2056	}
2057},
2058{
2059	USB_DEVICE(0x0763, 0x2019),
2060	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2061		/* .vendor_name = "M-Audio", */
2062		/* .product_name = "Ozone Academic", */
2063		.ifnum = QUIRK_ANY_INTERFACE,
2064		.type = QUIRK_COMPOSITE,
2065		.data = & (const struct snd_usb_audio_quirk[]) {
2066			{
2067				.ifnum = 0,
2068				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2069			},
2070			{
2071				.ifnum = 1,
2072				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2073			},
2074			{
2075				.ifnum = 2,
2076				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2077			},
2078			{
2079				.ifnum = 3,
2080				.type = QUIRK_MIDI_MIDIMAN,
2081				.data = & (const struct snd_usb_midi_endpoint_info) {
2082					.out_cables = 0x0001,
2083					.in_cables  = 0x0001
2084				}
2085			},
2086			{
2087				.ifnum = -1
2088			}
2089		}
2090	}
2091},
2092{
 
 
 
 
2093	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2030),
2094	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2095		/* .vendor_name = "M-Audio", */
2096		/* .product_name = "Fast Track C400", */
2097		.ifnum = QUIRK_ANY_INTERFACE,
2098		.type = QUIRK_COMPOSITE,
2099		.data = &(const struct snd_usb_audio_quirk[]) {
2100			{
2101				.ifnum = 1,
2102				.type = QUIRK_AUDIO_STANDARD_MIXER,
2103			},
2104			/* Playback */
2105			{
2106				.ifnum = 2,
2107				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2108				.data = &(const struct audioformat) {
2109					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2110					.channels = 6,
2111					.iface = 2,
2112					.altsetting = 1,
2113					.altset_idx = 1,
2114					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2115					.endpoint = 0x01,
2116					.ep_attr = 0x09,
2117					.rates = SNDRV_PCM_RATE_44100 |
2118						 SNDRV_PCM_RATE_48000 |
2119						 SNDRV_PCM_RATE_88200 |
2120						 SNDRV_PCM_RATE_96000,
2121					.rate_min = 44100,
2122					.rate_max = 96000,
2123					.nr_rates = 4,
2124					.rate_table = (unsigned int[]) {
2125							44100, 48000, 88200, 96000
2126					},
2127					.clock = 0x80,
2128				}
2129			},
2130			/* Capture */
2131			{
2132				.ifnum = 3,
2133				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2134				.data = &(const struct audioformat) {
2135					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2136					.channels = 4,
2137					.iface = 3,
2138					.altsetting = 1,
2139					.altset_idx = 1,
2140					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2141					.endpoint = 0x81,
2142					.ep_attr = 0x05,
2143					.rates = SNDRV_PCM_RATE_44100 |
2144						 SNDRV_PCM_RATE_48000 |
2145						 SNDRV_PCM_RATE_88200 |
2146						 SNDRV_PCM_RATE_96000,
2147					.rate_min = 44100,
2148					.rate_max = 96000,
2149					.nr_rates = 4,
2150					.rate_table = (unsigned int[]) {
2151						44100, 48000, 88200, 96000
2152					},
2153					.clock = 0x80,
2154				}
2155			},
2156			/* MIDI */
2157			{
2158				.ifnum = -1 /* Interface = 4 */
2159			}
2160		}
2161	}
2162},
2163{
2164	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2031),
2165	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2166		/* .vendor_name = "M-Audio", */
2167		/* .product_name = "Fast Track C600", */
2168		.ifnum = QUIRK_ANY_INTERFACE,
2169		.type = QUIRK_COMPOSITE,
2170		.data = &(const struct snd_usb_audio_quirk[]) {
2171			{
2172				.ifnum = 1,
2173				.type = QUIRK_AUDIO_STANDARD_MIXER,
2174			},
2175			/* Playback */
2176			{
2177				.ifnum = 2,
2178				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2179				.data = &(const struct audioformat) {
2180					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2181					.channels = 8,
2182					.iface = 2,
2183					.altsetting = 1,
2184					.altset_idx = 1,
2185					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2186					.endpoint = 0x01,
2187					.ep_attr = 0x09,
2188					.rates = SNDRV_PCM_RATE_44100 |
2189						 SNDRV_PCM_RATE_48000 |
2190						 SNDRV_PCM_RATE_88200 |
2191						 SNDRV_PCM_RATE_96000,
2192					.rate_min = 44100,
2193					.rate_max = 96000,
2194					.nr_rates = 4,
2195					.rate_table = (unsigned int[]) {
2196							44100, 48000, 88200, 96000
2197					},
2198					.clock = 0x80,
2199				}
2200			},
2201			/* Capture */
2202			{
2203				.ifnum = 3,
2204				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2205				.data = &(const struct audioformat) {
2206					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2207					.channels = 6,
2208					.iface = 3,
2209					.altsetting = 1,
2210					.altset_idx = 1,
2211					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2212					.endpoint = 0x81,
2213					.ep_attr = 0x05,
2214					.rates = SNDRV_PCM_RATE_44100 |
2215						 SNDRV_PCM_RATE_48000 |
2216						 SNDRV_PCM_RATE_88200 |
2217						 SNDRV_PCM_RATE_96000,
2218					.rate_min = 44100,
2219					.rate_max = 96000,
2220					.nr_rates = 4,
2221					.rate_table = (unsigned int[]) {
2222						44100, 48000, 88200, 96000
2223					},
2224					.clock = 0x80,
2225				}
2226			},
2227			/* MIDI */
2228			{
2229				.ifnum = -1 /* Interface = 4 */
2230			}
2231		}
2232	}
2233},
2234{
2235	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2080),
2236	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2237		/* .vendor_name = "M-Audio", */
2238		/* .product_name = "Fast Track Ultra", */
2239		.ifnum = QUIRK_ANY_INTERFACE,
2240		.type = QUIRK_COMPOSITE,
2241		.data = & (const struct snd_usb_audio_quirk[]) {
2242			{
2243				.ifnum = 0,
2244				.type = QUIRK_AUDIO_STANDARD_MIXER,
2245			},
2246			{
2247				.ifnum = 1,
2248				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2249				.data = & (const struct audioformat) {
2250					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2251					.channels = 8,
2252					.iface = 1,
2253					.altsetting = 1,
2254					.altset_idx = 1,
2255					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2256					.endpoint = 0x01,
2257					.ep_attr = 0x09,
2258					.rates = SNDRV_PCM_RATE_44100 |
2259						 SNDRV_PCM_RATE_48000 |
2260						 SNDRV_PCM_RATE_88200 |
2261						 SNDRV_PCM_RATE_96000,
2262					.rate_min = 44100,
2263					.rate_max = 96000,
2264					.nr_rates = 4,
2265					.rate_table = (unsigned int[]) {
2266						44100, 48000, 88200, 96000
2267					}
2268				}
2269			},
2270			{
2271				.ifnum = 2,
2272				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2273				.data = & (const struct audioformat) {
2274					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2275					.channels = 8,
2276					.iface = 2,
2277					.altsetting = 1,
2278					.altset_idx = 1,
2279					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2280					.endpoint = 0x81,
2281					.ep_attr = 0x05,
2282					.rates = SNDRV_PCM_RATE_44100 |
2283						 SNDRV_PCM_RATE_48000 |
2284						 SNDRV_PCM_RATE_88200 |
2285						 SNDRV_PCM_RATE_96000,
2286					.rate_min = 44100,
2287					.rate_max = 96000,
2288					.nr_rates = 4,
2289					.rate_table = (unsigned int[]) {
2290						44100, 48000, 88200, 96000
2291					}
2292				}
2293			},
2294			/* interface 3 (MIDI) is standard compliant */
2295			{
2296				.ifnum = -1
2297			}
2298		}
2299	}
2300},
2301{
2302	USB_DEVICE_VENDOR_SPEC(0x0763, 0x2081),
2303	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2304		/* .vendor_name = "M-Audio", */
2305		/* .product_name = "Fast Track Ultra 8R", */
2306		.ifnum = QUIRK_ANY_INTERFACE,
2307		.type = QUIRK_COMPOSITE,
2308		.data = & (const struct snd_usb_audio_quirk[]) {
2309			{
2310				.ifnum = 0,
2311				.type = QUIRK_AUDIO_STANDARD_MIXER,
2312			},
2313			{
2314				.ifnum = 1,
2315				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2316				.data = & (const struct audioformat) {
2317					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2318					.channels = 8,
2319					.iface = 1,
2320					.altsetting = 1,
2321					.altset_idx = 1,
2322					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2323					.endpoint = 0x01,
2324					.ep_attr = 0x09,
2325					.rates = SNDRV_PCM_RATE_44100 |
2326						 SNDRV_PCM_RATE_48000 |
2327						 SNDRV_PCM_RATE_88200 |
2328						 SNDRV_PCM_RATE_96000,
2329					.rate_min = 44100,
2330					.rate_max = 96000,
2331					.nr_rates = 4,
2332					.rate_table = (unsigned int[]) {
2333							44100, 48000, 88200, 96000
2334					}
2335				}
2336			},
2337			{
2338				.ifnum = 2,
2339				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2340				.data = & (const struct audioformat) {
2341					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2342					.channels = 8,
2343					.iface = 2,
2344					.altsetting = 1,
2345					.altset_idx = 1,
2346					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2347					.endpoint = 0x81,
2348					.ep_attr = 0x05,
2349					.rates = SNDRV_PCM_RATE_44100 |
2350						 SNDRV_PCM_RATE_48000 |
2351						 SNDRV_PCM_RATE_88200 |
2352						 SNDRV_PCM_RATE_96000,
2353					.rate_min = 44100,
2354					.rate_max = 96000,
2355					.nr_rates = 4,
2356					.rate_table = (unsigned int[]) {
2357						44100, 48000, 88200, 96000
2358					}
2359				}
2360			},
2361			/* interface 3 (MIDI) is standard compliant */
2362			{
2363				.ifnum = -1
2364			}
2365		}
2366	}
2367},
2368
2369/* Casio devices */
2370{
2371	USB_DEVICE(0x07cf, 0x6801),
2372	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2373		.vendor_name = "Casio",
2374		.product_name = "PL-40R",
2375		.ifnum = 0,
2376		.type = QUIRK_MIDI_YAMAHA
2377	}
2378},
2379{
2380	/* this ID is used by several devices without a product ID */
2381	USB_DEVICE(0x07cf, 0x6802),
2382	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2383		.vendor_name = "Casio",
2384		.product_name = "Keyboard",
2385		.ifnum = 0,
2386		.type = QUIRK_MIDI_YAMAHA
2387	}
2388},
2389
2390/* Mark of the Unicorn devices */
2391{
2392	/* thanks to Robert A. Lerche <ral 'at' msbit.com> */
2393	.match_flags = USB_DEVICE_ID_MATCH_VENDOR |
2394		       USB_DEVICE_ID_MATCH_PRODUCT |
2395		       USB_DEVICE_ID_MATCH_DEV_SUBCLASS,
2396	.idVendor = 0x07fd,
2397	.idProduct = 0x0001,
2398	.bDeviceSubClass = 2,
2399	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2400		.vendor_name = "MOTU",
2401		.product_name = "Fastlane",
2402		.ifnum = QUIRK_ANY_INTERFACE,
2403		.type = QUIRK_COMPOSITE,
2404		.data = & (const struct snd_usb_audio_quirk[]) {
2405			{
2406				.ifnum = 0,
2407				.type = QUIRK_MIDI_RAW_BYTES
2408			},
2409			{
2410				.ifnum = 1,
2411				.type = QUIRK_IGNORE_INTERFACE
2412			},
2413			{
2414				.ifnum = -1
2415			}
2416		}
2417	}
2418},
2419
2420/* Emagic devices */
2421{
2422	USB_DEVICE(0x086a, 0x0001),
2423	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2424		.vendor_name = "Emagic",
2425		/* .product_name = "Unitor8", */
2426		.ifnum = 2,
2427		.type = QUIRK_MIDI_EMAGIC,
2428		.data = & (const struct snd_usb_midi_endpoint_info) {
2429			.out_cables = 0x80ff,
2430			.in_cables  = 0x80ff
2431		}
2432	}
2433},
2434{
2435	USB_DEVICE(0x086a, 0x0002),
2436	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2437		.vendor_name = "Emagic",
2438		/* .product_name = "AMT8", */
2439		.ifnum = 2,
2440		.type = QUIRK_MIDI_EMAGIC,
2441		.data = & (const struct snd_usb_midi_endpoint_info) {
2442			.out_cables = 0x80ff,
2443			.in_cables  = 0x80ff
2444		}
2445	}
2446},
2447{
2448	USB_DEVICE(0x086a, 0x0003),
2449	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2450		.vendor_name = "Emagic",
2451		/* .product_name = "MT4", */
2452		.ifnum = 2,
2453		.type = QUIRK_MIDI_EMAGIC,
2454		.data = & (const struct snd_usb_midi_endpoint_info) {
2455			.out_cables = 0x800f,
2456			.in_cables  = 0x8003
2457		}
2458	}
2459},
2460
2461/* KORG devices */
2462{
2463	USB_DEVICE_VENDOR_SPEC(0x0944, 0x0200),
2464	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2465		.vendor_name = "KORG, Inc.",
2466		/* .product_name = "PANDORA PX5D", */
2467		.ifnum = 3,
2468		.type = QUIRK_MIDI_STANDARD_INTERFACE,
2469	}
2470},
2471
2472{
2473	USB_DEVICE_VENDOR_SPEC(0x0944, 0x0201),
2474	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2475		.vendor_name = "KORG, Inc.",
2476		/* .product_name = "ToneLab ST", */
2477		.ifnum = 3,
2478		.type = QUIRK_MIDI_STANDARD_INTERFACE,
 
 
 
 
 
 
 
 
2479	}
2480},
2481
2482/* AKAI devices */
2483{
2484	USB_DEVICE(0x09e8, 0x0062),
2485	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2486		.vendor_name = "AKAI",
2487		.product_name = "MPD16",
2488		.ifnum = 0,
2489		.type = QUIRK_MIDI_AKAI,
2490	}
2491},
2492
2493{
2494	/* Akai MPC Element */
2495	USB_DEVICE(0x09e8, 0x0021),
2496	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2497		.ifnum = QUIRK_ANY_INTERFACE,
2498		.type = QUIRK_COMPOSITE,
2499		.data = & (const struct snd_usb_audio_quirk[]) {
2500			{
2501				.ifnum = 0,
2502				.type = QUIRK_IGNORE_INTERFACE
2503			},
2504			{
2505				.ifnum = 1,
2506				.type = QUIRK_MIDI_STANDARD_INTERFACE
2507			},
2508			{
2509				.ifnum = -1
2510			}
2511		}
2512	}
2513},
2514
2515/* Steinberg devices */
2516{
2517	/* Steinberg MI2 */
2518	USB_DEVICE_VENDOR_SPEC(0x0a4e, 0x2040),
2519	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2520		.ifnum = QUIRK_ANY_INTERFACE,
2521		.type = QUIRK_COMPOSITE,
2522		.data = & (const struct snd_usb_audio_quirk[]) {
2523			{
2524				.ifnum = 0,
2525				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2526			},
2527			{
2528				.ifnum = 1,
2529				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2530			},
2531			{
2532				.ifnum = 2,
2533				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2534			},
2535			{
2536				.ifnum = 3,
2537				.type = QUIRK_MIDI_FIXED_ENDPOINT,
2538				.data = &(const struct snd_usb_midi_endpoint_info) {
2539					.out_cables = 0x0001,
2540					.in_cables  = 0x0001
2541				}
2542			},
2543			{
2544				.ifnum = -1
2545			}
2546		}
2547	}
2548},
2549{
2550	/* Steinberg MI4 */
2551	USB_DEVICE_VENDOR_SPEC(0x0a4e, 0x4040),
2552	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2553		.ifnum = QUIRK_ANY_INTERFACE,
2554		.type = QUIRK_COMPOSITE,
2555		.data = & (const struct snd_usb_audio_quirk[]) {
2556			{
2557				.ifnum = 0,
2558				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2559			},
2560			{
2561				.ifnum = 1,
2562				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2563			},
2564			{
2565				.ifnum = 2,
2566				.type = QUIRK_AUDIO_STANDARD_INTERFACE
2567			},
2568			{
2569				.ifnum = 3,
2570				.type = QUIRK_MIDI_FIXED_ENDPOINT,
2571				.data = &(const struct snd_usb_midi_endpoint_info) {
2572					.out_cables = 0x0001,
2573					.in_cables  = 0x0001
2574				}
2575			},
2576			{
2577				.ifnum = -1
2578			}
2579		}
2580	}
2581},
2582
2583/* TerraTec devices */
2584{
2585	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0012),
2586	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2587		.vendor_name = "TerraTec",
2588		.product_name = "PHASE 26",
2589		.ifnum = 3,
2590		.type = QUIRK_MIDI_STANDARD_INTERFACE
2591	}
2592},
2593{
2594	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0013),
2595	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2596		.vendor_name = "TerraTec",
2597		.product_name = "PHASE 26",
2598		.ifnum = 3,
2599		.type = QUIRK_MIDI_STANDARD_INTERFACE
2600	}
2601},
2602{
2603	USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0014),
2604	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2605		.vendor_name = "TerraTec",
2606		.product_name = "PHASE 26",
2607		.ifnum = 3,
2608		.type = QUIRK_MIDI_STANDARD_INTERFACE
2609	}
2610},
2611{
2612	USB_DEVICE(0x0ccd, 0x0028),
2613	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2614		.vendor_name = "TerraTec",
2615		.product_name = "Aureon5.1MkII",
2616		.ifnum = QUIRK_NO_INTERFACE
2617	}
2618},
2619{
2620	USB_DEVICE(0x0ccd, 0x0035),
2621	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2622		.vendor_name = "Miditech",
2623		.product_name = "Play'n Roll",
2624		.ifnum = 0,
2625		.type = QUIRK_MIDI_CME
2626	}
2627},
2628
2629/* Stanton/N2IT Final Scratch v1 device ('Scratchamp') */
2630{
2631	USB_DEVICE(0x103d, 0x0100),
2632		.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2633		.vendor_name = "Stanton",
2634		.product_name = "ScratchAmp",
2635		.ifnum = QUIRK_NO_INTERFACE
2636	}
2637},
2638{
2639	USB_DEVICE(0x103d, 0x0101),
2640		.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2641		.vendor_name = "Stanton",
2642		.product_name = "ScratchAmp",
2643		.ifnum = QUIRK_NO_INTERFACE
2644	}
2645},
2646
2647/* Novation EMS devices */
2648{
2649	USB_DEVICE_VENDOR_SPEC(0x1235, 0x0001),
2650	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2651		.vendor_name = "Novation",
2652		.product_name = "ReMOTE Audio/XStation",
2653		.ifnum = 4,
2654		.type = QUIRK_MIDI_NOVATION
2655	}
2656},
2657{
2658	USB_DEVICE_VENDOR_SPEC(0x1235, 0x0002),
2659	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2660		.vendor_name = "Novation",
2661		.product_name = "Speedio",
2662		.ifnum = 3,
2663		.type = QUIRK_MIDI_NOVATION
2664	}
2665},
2666{
2667	USB_DEVICE(0x1235, 0x000a),
2668	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2669		/* .vendor_name = "Novation", */
2670		/* .product_name = "Nocturn", */
2671		.ifnum = 0,
2672		.type = QUIRK_MIDI_RAW_BYTES
2673	}
2674},
2675{
2676	USB_DEVICE(0x1235, 0x000e),
2677	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2678		/* .vendor_name = "Novation", */
2679		/* .product_name = "Launchpad", */
2680		.ifnum = 0,
2681		.type = QUIRK_MIDI_RAW_BYTES
2682	}
2683},
2684{
2685	USB_DEVICE(0x1235, 0x0010),
2686	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2687		.vendor_name = "Focusrite",
2688		.product_name = "Saffire 6 USB",
2689		.ifnum = QUIRK_ANY_INTERFACE,
2690		.type = QUIRK_COMPOSITE,
2691		.data = (const struct snd_usb_audio_quirk[]) {
2692			{
2693				.ifnum = 0,
2694				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2695				.data = &(const struct audioformat) {
2696					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2697					.channels = 4,
2698					.iface = 0,
2699					.altsetting = 1,
2700					.altset_idx = 1,
2701					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2702					.endpoint = 0x01,
2703					.ep_attr = USB_ENDPOINT_XFER_ISOC,
 
 
2704					.rates = SNDRV_PCM_RATE_44100 |
2705						 SNDRV_PCM_RATE_48000,
2706					.rate_min = 44100,
2707					.rate_max = 48000,
2708					.nr_rates = 2,
2709					.rate_table = (unsigned int[]) {
2710						44100, 48000
2711					}
 
 
 
 
 
2712				}
2713			},
2714			{
2715				.ifnum = 1,
2716				.type = QUIRK_MIDI_RAW_BYTES
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2717			},
2718			{
2719				.ifnum = -1
2720			}
2721		}
2722	}
2723},
2724{
2725	USB_DEVICE(0x1235, 0x0018),
2726	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2727		.vendor_name = "Novation",
2728		.product_name = "Twitch",
2729		.ifnum = QUIRK_ANY_INTERFACE,
2730		.type = QUIRK_COMPOSITE,
2731		.data = (const struct snd_usb_audio_quirk[]) {
2732			{
2733				.ifnum = 0,
2734				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2735				.data = & (const struct audioformat) {
2736					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
2737					.channels = 4,
2738					.iface = 0,
2739					.altsetting = 1,
2740					.altset_idx = 1,
2741					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
2742					.endpoint = 0x01,
2743					.ep_attr = USB_ENDPOINT_XFER_ISOC,
2744					.rates = SNDRV_PCM_RATE_44100 |
2745						 SNDRV_PCM_RATE_48000,
2746					.rate_min = 44100,
2747					.rate_max = 48000,
2748					.nr_rates = 2,
2749					.rate_table = (unsigned int[]) {
2750						44100, 48000
2751					}
2752				}
2753			},
2754			{
2755				.ifnum = 1,
2756				.type = QUIRK_MIDI_RAW_BYTES
2757			},
2758			{
2759				.ifnum = -1
2760			}
2761		}
2762	}
2763},
2764{
2765	USB_DEVICE_VENDOR_SPEC(0x1235, 0x4661),
2766	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2767		.vendor_name = "Novation",
2768		.product_name = "ReMOTE25",
2769		.ifnum = 0,
2770		.type = QUIRK_MIDI_NOVATION
2771	}
2772},
2773
2774/* Access Music devices */
2775{
2776	/* VirusTI Desktop */
2777	USB_DEVICE_VENDOR_SPEC(0x133e, 0x0815),
2778	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2779		.ifnum = QUIRK_ANY_INTERFACE,
2780		.type = QUIRK_COMPOSITE,
2781		.data = &(const struct snd_usb_audio_quirk[]) {
2782			{
2783				.ifnum = 3,
2784				.type = QUIRK_MIDI_FIXED_ENDPOINT,
2785				.data = &(const struct snd_usb_midi_endpoint_info) {
2786					.out_cables = 0x0003,
2787					.in_cables  = 0x0003
2788				}
2789			},
2790			{
2791				.ifnum = 4,
2792				.type = QUIRK_IGNORE_INTERFACE
2793			},
2794			{
2795				.ifnum = -1
2796			}
2797		}
2798	}
2799},
2800
2801/* */
2802{
2803	/* aka. Serato Scratch Live DJ Box */
2804	USB_DEVICE(0x13e5, 0x0001),
2805	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2806		.vendor_name = "Rane",
2807		.product_name = "SL-1",
2808		.ifnum = QUIRK_NO_INTERFACE
2809	}
2810},
2811
2812/* Native Instruments MK2 series */
2813{
2814	/* Komplete Audio 6 */
2815	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2816	.idVendor = 0x17cc,
2817	.idProduct = 0x1000,
2818},
2819{
2820	/* Traktor Audio 6 */
2821	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2822	.idVendor = 0x17cc,
2823	.idProduct = 0x1010,
2824},
2825{
2826	/* Traktor Audio 10 */
2827	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
2828	.idVendor = 0x17cc,
2829	.idProduct = 0x1020,
2830},
2831
2832/* QinHeng devices */
2833{
2834	USB_DEVICE(0x1a86, 0x752d),
2835	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2836		.vendor_name = "QinHeng",
2837		.product_name = "CH345",
2838		.ifnum = 1,
2839		.type = QUIRK_MIDI_CH345
2840	}
2841},
2842
2843/* KeithMcMillen Stringport */
2844{
2845	USB_DEVICE(0x1f38, 0x0001),
2846	.bInterfaceClass = USB_CLASS_AUDIO,
2847},
2848
2849/* Miditech devices */
2850{
2851	USB_DEVICE(0x4752, 0x0011),
2852	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2853		.vendor_name = "Miditech",
2854		.product_name = "Midistart-2",
2855		.ifnum = 0,
2856		.type = QUIRK_MIDI_CME
2857	}
2858},
2859
2860/* Central Music devices */
2861{
2862	/* this ID used by both Miditech MidiStudio-2 and CME UF-x */
2863	USB_DEVICE(0x7104, 0x2202),
2864	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
2865		.ifnum = 0,
2866		.type = QUIRK_MIDI_CME
2867	}
2868},
2869
2870/*
2871 * Auvitek au0828 devices with audio interface.
2872 * This should be kept in sync with drivers/media/usb/au0828/au0828-cards.c
2873 * Please notice that some drivers are DVB only, and don't need to be
2874 * here. That's the case, for example, of DVICO_FUSIONHDTV7.
2875 */
2876
2877#define AU0828_DEVICE(vid, pid, vname, pname) { \
2878	USB_DEVICE_VENDOR_SPEC(vid, pid), \
2879	.match_flags = USB_DEVICE_ID_MATCH_DEVICE | \
2880		       USB_DEVICE_ID_MATCH_INT_CLASS | \
2881		       USB_DEVICE_ID_MATCH_INT_SUBCLASS, \
2882	.bInterfaceClass = USB_CLASS_AUDIO, \
2883	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL, \
2884	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) { \
2885		.vendor_name = vname, \
2886		.product_name = pname, \
2887		.ifnum = QUIRK_ANY_INTERFACE, \
2888		.type = QUIRK_AUDIO_ALIGN_TRANSFER, \
2889	} \
2890}
2891
2892AU0828_DEVICE(0x2040, 0x7200, "Hauppauge", "HVR-950Q"),
2893AU0828_DEVICE(0x2040, 0x7240, "Hauppauge", "HVR-850"),
2894AU0828_DEVICE(0x2040, 0x7210, "Hauppauge", "HVR-950Q"),
2895AU0828_DEVICE(0x2040, 0x7217, "Hauppauge", "HVR-950Q"),
2896AU0828_DEVICE(0x2040, 0x721b, "Hauppauge", "HVR-950Q"),
2897AU0828_DEVICE(0x2040, 0x721e, "Hauppauge", "HVR-950Q"),
2898AU0828_DEVICE(0x2040, 0x721f, "Hauppauge", "HVR-950Q"),
2899AU0828_DEVICE(0x2040, 0x7280, "Hauppauge", "HVR-950Q"),
2900AU0828_DEVICE(0x0fd9, 0x0008, "Hauppauge", "HVR-950Q"),
2901AU0828_DEVICE(0x2040, 0x7201, "Hauppauge", "HVR-950Q-MXL"),
2902AU0828_DEVICE(0x2040, 0x7211, "Hauppauge", "HVR-950Q-MXL"),
2903AU0828_DEVICE(0x2040, 0x7281, "Hauppauge", "HVR-950Q-MXL"),
2904AU0828_DEVICE(0x05e1, 0x0480, "Hauppauge", "Woodbury"),
2905AU0828_DEVICE(0x2040, 0x8200, "Hauppauge", "Woodbury"),
2906AU0828_DEVICE(0x2040, 0x7260, "Hauppauge", "HVR-950Q"),
2907AU0828_DEVICE(0x2040, 0x7213, "Hauppauge", "HVR-950Q"),
2908AU0828_DEVICE(0x2040, 0x7270, "Hauppauge", "HVR-950Q"),
2909
2910/* Syntek STK1160 */
2911{
2912	.match_flags = USB_DEVICE_ID_MATCH_DEVICE |
2913		       USB_DEVICE_ID_MATCH_INT_CLASS |
2914		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
2915	.idVendor = 0x05e1,
2916	.idProduct = 0x0408,
2917	.bInterfaceClass = USB_CLASS_AUDIO,
2918	.bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL,
2919	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2920		.vendor_name = "Syntek",
2921		.product_name = "STK1160",
2922		.ifnum = QUIRK_ANY_INTERFACE,
2923		.type = QUIRK_AUDIO_ALIGN_TRANSFER
2924	}
2925},
2926
2927/* Digidesign Mbox */
2928{
2929	/* Thanks to Clemens Ladisch <clemens@ladisch.de> */
2930	USB_DEVICE(0x0dba, 0x1000),
2931	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2932		.vendor_name = "Digidesign",
2933		.product_name = "MBox",
2934		.ifnum = QUIRK_ANY_INTERFACE,
2935		.type = QUIRK_COMPOSITE,
2936		.data = (const struct snd_usb_audio_quirk[]){
2937			{
2938				.ifnum = 0,
2939				.type = QUIRK_AUDIO_STANDARD_MIXER,
2940			},
2941			{
2942				.ifnum = 1,
2943				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2944				.data = &(const struct audioformat) {
2945					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2946					.channels = 2,
2947					.iface = 1,
2948					.altsetting = 1,
2949					.altset_idx = 1,
2950					.attributes = 0x4,
2951					.endpoint = 0x02,
2952					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2953						USB_ENDPOINT_SYNC_SYNC,
2954					.maxpacksize = 0x130,
2955					.rates = SNDRV_PCM_RATE_48000,
2956					.rate_min = 48000,
2957					.rate_max = 48000,
2958					.nr_rates = 1,
2959					.rate_table = (unsigned int[]) {
2960						48000
2961					}
2962				}
2963			},
2964			{
2965				.ifnum = 1,
2966				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
2967				.data = &(const struct audioformat) {
2968					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
2969					.channels = 2,
2970					.iface = 1,
2971					.altsetting = 1,
2972					.altset_idx = 1,
2973					.attributes = 0x4,
2974					.endpoint = 0x81,
 
2975					.ep_attr = USB_ENDPOINT_XFER_ISOC |
2976						USB_ENDPOINT_SYNC_ASYNC,
2977					.maxpacksize = 0x130,
2978					.rates = SNDRV_PCM_RATE_48000,
2979					.rate_min = 48000,
2980					.rate_max = 48000,
2981					.nr_rates = 1,
2982					.rate_table = (unsigned int[]) {
2983						48000
2984					}
2985				}
2986			},
2987			{
2988				.ifnum = -1
2989			}
2990		}
2991	}
2992},
2993
2994/* DIGIDESIGN MBOX 2 */
2995{
2996	USB_DEVICE(0x0dba, 0x3000),
2997	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
2998		.vendor_name = "Digidesign",
2999		.product_name = "Mbox 2",
3000		.ifnum = QUIRK_ANY_INTERFACE,
3001		.type = QUIRK_COMPOSITE,
3002		.data = (const struct snd_usb_audio_quirk[]) {
3003			{
3004				.ifnum = 0,
3005				.type = QUIRK_IGNORE_INTERFACE
3006			},
3007			{
3008				.ifnum = 1,
3009				.type = QUIRK_IGNORE_INTERFACE
3010			},
3011			{
3012				.ifnum = 2,
3013				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3014				.data = &(const struct audioformat) {
3015					.formats = SNDRV_PCM_FMTBIT_S24_3BE,
3016					.channels = 2,
3017					.iface = 2,
3018					.altsetting = 2,
3019					.altset_idx = 1,
3020					.attributes = 0x00,
3021					.endpoint = 0x03,
3022					.ep_attr = USB_ENDPOINT_SYNC_ASYNC,
3023					.rates = SNDRV_PCM_RATE_48000,
3024					.rate_min = 48000,
3025					.rate_max = 48000,
3026					.nr_rates = 1,
3027					.rate_table = (unsigned int[]) {
3028						48000
3029					}
3030				}
3031			},
 
3032			{
3033				.ifnum = 3,
3034				.type = QUIRK_IGNORE_INTERFACE
3035			},
3036			{
3037				.ifnum = 4,
3038				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3039				.data = &(const struct audioformat) {
3040				.formats = SNDRV_PCM_FMTBIT_S24_3BE,
3041					.channels = 2,
3042					.iface = 4,
3043					.altsetting = 2,
3044					.altset_idx = 1,
3045					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
3046					.endpoint = 0x85,
3047					.ep_attr = USB_ENDPOINT_SYNC_SYNC,
3048					.rates = SNDRV_PCM_RATE_48000,
3049					.rate_min = 48000,
3050					.rate_max = 48000,
3051					.nr_rates = 1,
3052					.rate_table = (unsigned int[]) {
3053						48000
3054					}
3055				}
3056			},
 
3057			{
3058				.ifnum = 5,
3059				.type = QUIRK_IGNORE_INTERFACE
3060			},
3061			{
3062				.ifnum = 6,
3063				.type = QUIRK_MIDI_MIDIMAN,
3064				.data = &(const struct snd_usb_midi_endpoint_info) {
3065					.out_ep =  0x02,
3066					.out_cables = 0x0001,
3067					.in_ep = 0x81,
3068					.in_interval = 0x01,
3069					.in_cables = 0x0001
3070				}
3071			},
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3072			{
3073				.ifnum = -1
3074			}
 
 
 
 
3075		}
3076	}
3077},
3078{
3079	/* Tascam US122 MKII - playback-only support */
3080	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,
3081	.idVendor = 0x0644,
3082	.idProduct = 0x8021,
3083	.bInterfaceClass = USB_CLASS_AUDIO,
3084	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3085		.vendor_name = "TASCAM",
3086		.product_name = "US122 MKII",
3087		.ifnum = QUIRK_ANY_INTERFACE,
3088		.type = QUIRK_COMPOSITE,
3089		.data = (const struct snd_usb_audio_quirk[]) {
3090			{
3091				.ifnum = 0,
3092				.type = QUIRK_IGNORE_INTERFACE
3093			},
3094			{
3095				.ifnum = 1,
3096				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3097				.data = &(const struct audioformat) {
3098					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3099					.channels = 2,
3100					.iface = 1,
3101					.altsetting = 1,
3102					.altset_idx = 1,
3103					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
3104					.endpoint = 0x02,
3105					.ep_attr = USB_ENDPOINT_XFER_ISOC,
3106					.rates = SNDRV_PCM_RATE_44100 |
3107						 SNDRV_PCM_RATE_48000 |
3108						 SNDRV_PCM_RATE_88200 |
3109						 SNDRV_PCM_RATE_96000,
3110					.rate_min = 44100,
3111					.rate_max = 96000,
3112					.nr_rates = 4,
3113					.rate_table = (unsigned int[]) {
3114						44100, 48000, 88200, 96000
3115					}
3116				}
3117			},
 
 
 
 
 
 
 
 
 
 
 
 
 
3118			{
3119				.ifnum = -1
3120			}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3121		}
3122	}
3123},
3124
3125/* Microsoft XboxLive Headset/Xbox Communicator */
3126{
3127	USB_DEVICE(0x045e, 0x0283),
3128	.bInterfaceClass = USB_CLASS_PER_INTERFACE,
3129	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3130		.vendor_name = "Microsoft",
3131		.product_name = "XboxLive Headset/Xbox Communicator",
3132		.ifnum = QUIRK_ANY_INTERFACE,
3133		.type = QUIRK_COMPOSITE,
3134		.data = &(const struct snd_usb_audio_quirk[]) {
3135			{
3136				/* playback */
3137				.ifnum = 0,
3138				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3139				.data = &(const struct audioformat) {
3140					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3141					.channels = 1,
3142					.iface = 0,
3143					.altsetting = 0,
3144					.altset_idx = 0,
3145					.attributes = 0,
3146					.endpoint = 0x04,
3147					.ep_attr = 0x05,
3148					.rates = SNDRV_PCM_RATE_CONTINUOUS,
3149					.rate_min = 22050,
3150					.rate_max = 22050
3151				}
3152			},
3153			{
3154				/* capture */
3155				.ifnum = 1,
3156				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3157				.data = &(const struct audioformat) {
3158					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3159					.channels = 1,
3160					.iface = 1,
3161					.altsetting = 0,
3162					.altset_idx = 0,
3163					.attributes = 0,
3164					.endpoint = 0x85,
3165					.ep_attr = 0x05,
3166					.rates = SNDRV_PCM_RATE_CONTINUOUS,
3167					.rate_min = 16000,
3168					.rate_max = 16000
3169				}
3170			},
3171			{
3172				.ifnum = -1
3173			}
3174		}
3175	}
3176},
3177
3178/* Reloop Play */
3179{
3180	USB_DEVICE(0x200c, 0x100b),
3181	.bInterfaceClass = USB_CLASS_PER_INTERFACE,
3182	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3183		.ifnum = QUIRK_ANY_INTERFACE,
3184		.type = QUIRK_COMPOSITE,
3185		.data = &(const struct snd_usb_audio_quirk[]) {
3186			{
3187				.ifnum = 0,
3188				.type = QUIRK_AUDIO_STANDARD_MIXER,
3189			},
3190			{
3191				.ifnum = 1,
3192				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3193				.data = &(const struct audioformat) {
3194					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
3195					.channels = 4,
3196					.iface = 1,
3197					.altsetting = 1,
3198					.altset_idx = 1,
3199					.attributes = UAC_EP_CS_ATTR_SAMPLE_RATE,
3200					.endpoint = 0x01,
3201					.ep_attr = USB_ENDPOINT_SYNC_ADAPTIVE,
3202					.rates = SNDRV_PCM_RATE_44100 |
3203						 SNDRV_PCM_RATE_48000,
3204					.rate_min = 44100,
3205					.rate_max = 48000,
3206					.nr_rates = 2,
3207					.rate_table = (unsigned int[]) {
3208						44100, 48000
3209					}
3210				}
3211			},
3212			{
3213				.ifnum = -1
3214			}
3215		}
3216	}
3217},
3218
3219{
3220	/*
3221	 * ZOOM R16/24 in audio interface mode.
3222	 * Playback requires an extra four byte LE length indicator
3223	 * at the start of each isochronous packet. This quirk is
3224	 * enabled in create_standard_audio_quirk().
3225	 */
3226	USB_DEVICE(0x1686, 0x00dd),
3227	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
3228		.ifnum = QUIRK_ANY_INTERFACE,
3229		.type = QUIRK_COMPOSITE,
3230		.data = (const struct snd_usb_audio_quirk[]) {
3231			{
3232				/* Playback  */
3233				.ifnum = 1,
3234				.type = QUIRK_AUDIO_STANDARD_INTERFACE,
3235			},
3236			{
3237				/* Capture */
3238				.ifnum = 2,
3239				.type = QUIRK_AUDIO_STANDARD_INTERFACE,
3240			},
3241			{
3242				/* Midi */
3243				.ifnum = 3,
3244				.type = QUIRK_MIDI_STANDARD_INTERFACE
3245			},
3246			{
3247				.ifnum = -1
3248			},
3249		}
3250	}
3251},
3252
3253{
3254	/*
3255	 * Some USB MIDI devices don't have an audio control interface,
3256	 * so we have to grab MIDI streaming interfaces here.
3257	 */
3258	.match_flags = USB_DEVICE_ID_MATCH_INT_CLASS |
3259		       USB_DEVICE_ID_MATCH_INT_SUBCLASS,
3260	.bInterfaceClass = USB_CLASS_AUDIO,
3261	.bInterfaceSubClass = USB_SUBCLASS_MIDISTREAMING,
3262	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
3263		.ifnum = QUIRK_ANY_INTERFACE,
3264		.type = QUIRK_MIDI_STANDARD_INTERFACE
3265	}
3266},
3267
 
3268{
3269	/*
3270	 * The original product_name is "USB Sound Device", however this name
3271	 * is also used by the CM106 based cards, so make it unique.
3272	 */
3273	USB_DEVICE(0x0d8c, 0x0103),
3274	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3275		.product_name = "Audio Advantage MicroII",
3276		.ifnum = QUIRK_NO_INTERFACE
3277	}
3278},
3279
 
 
 
 
3280{
3281	/*
3282	 * Nura's first gen headphones use Cambridge Silicon Radio's vendor
3283	 * ID, but it looks like the product ID actually is only for Nura.
3284	 * The capture interface does not work at all (even on Windows),
3285	 * and only the 48 kHz sample rate works for the playback interface.
3286	 */
3287	USB_DEVICE(0x0a12, 0x1243),
3288	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3289		.ifnum = QUIRK_ANY_INTERFACE,
3290		.type = QUIRK_COMPOSITE,
3291		.data = (const struct snd_usb_audio_quirk[]) {
3292			{
3293				.ifnum = 0,
3294				.type = QUIRK_AUDIO_STANDARD_MIXER,
3295			},
3296			/* Capture */
3297			{
3298				.ifnum = 1,
3299				.type = QUIRK_IGNORE_INTERFACE,
3300			},
3301			/* Playback */
3302			{
3303				.ifnum = 2,
3304				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3305				.data = &(const struct audioformat) {
3306					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3307					.channels = 2,
3308					.iface = 2,
3309					.altsetting = 1,
3310					.altset_idx = 1,
3311					.attributes = UAC_EP_CS_ATTR_FILL_MAX |
3312						UAC_EP_CS_ATTR_SAMPLE_RATE,
3313					.endpoint = 0x03,
3314					.ep_attr = USB_ENDPOINT_XFER_ISOC,
3315					.rates = SNDRV_PCM_RATE_48000,
3316					.rate_min = 48000,
3317					.rate_max = 48000,
3318					.nr_rates = 1,
3319					.rate_table = (unsigned int[]) {
3320						48000
3321					}
3322				}
3323			},
 
3324		}
3325	}
3326},
 
3327
3328{
3329	/*
3330	 * Bower's & Wilkins PX headphones only support the 48 kHz sample rate
3331	 * even though it advertises more. The capture interface doesn't work
3332	 * even on windows.
3333	 */
3334	USB_DEVICE(0x19b5, 0x0021),
3335	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
3336		.ifnum = QUIRK_ANY_INTERFACE,
3337		.type = QUIRK_COMPOSITE,
3338		.data = (const struct snd_usb_audio_quirk[]) {
3339			{
3340				.ifnum = 0,
3341				.type = QUIRK_AUDIO_STANDARD_MIXER,
3342			},
3343			/* Capture */
3344			{
3345				.ifnum = 1,
3346				.type = QUIRK_IGNORE_INTERFACE,
3347			},
3348			/* Playback */
3349			{
3350				.ifnum = 2,
3351				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
3352				.data = &(const struct audioformat) {
3353					.formats = SNDRV_PCM_FMTBIT_S16_LE,
3354					.channels = 2,
3355					.iface = 2,
3356					.altsetting = 1,
3357					.altset_idx = 1,
3358					.attributes = UAC_EP_CS_ATTR_FILL_MAX |
3359						UAC_EP_CS_ATTR_SAMPLE_RATE,
3360					.endpoint = 0x03,
3361					.ep_attr = USB_ENDPOINT_XFER_ISOC,
3362					.rates = SNDRV_PCM_RATE_48000,
3363					.rate_min = 48000,
3364					.rate_max = 48000,
3365					.nr_rates = 1,
3366					.rate_table = (unsigned int[]) {
3367						48000
3368					}
3369				}
3370			},
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3371		}
3372	}
3373},
3374
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3375#undef USB_DEVICE_VENDOR_SPEC