2  * ALSA USB Audio Driver
 
   4  * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>,
 
   5  *                       Clemens Ladisch <clemens@ladisch.de>
 
   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.
 
  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.
 
  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
 
  24  * The contents of this file are part of the driver's id_table.
 
  26  * In a perfect world, this file would be empty.
 
  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.)
 
  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, \
 
  40         .bInterfaceClass = USB_CLASS_VENDOR_SPEC
 
  46 #define YAMAHA_DEVICE(id, name) { \
 
  47         USB_DEVICE(0x0499, id), \
 
  48         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \
 
  49                 .vendor_name = "Yamaha", \
 
  50                 .product_name = name, \
 
  51                 .ifnum = QUIRK_ANY_INTERFACE, \
 
  52                 .type = QUIRK_MIDI_YAMAHA \
 
  55 #define YAMAHA_INTERFACE(id, intf, name) { \
 
  56         USB_DEVICE_VENDOR_SPEC(0x0499, id), \
 
  57         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \
 
  58                 .vendor_name = "Yamaha", \
 
  59                 .product_name = name, \
 
  61                 .type = QUIRK_MIDI_YAMAHA \
 
  64 YAMAHA_DEVICE(0x1000, "UX256"),
 
  65 YAMAHA_DEVICE(0x1001, "MU1000"),
 
  66 YAMAHA_DEVICE(0x1002, "MU2000"),
 
  67 YAMAHA_DEVICE(0x1003, "MU500"),
 
  68 YAMAHA_INTERFACE(0x1004, 3, "UW500"),
 
  69 YAMAHA_DEVICE(0x1005, "MOTIF6"),
 
  70 YAMAHA_DEVICE(0x1006, "MOTIF7"),
 
  71 YAMAHA_DEVICE(0x1007, "MOTIF8"),
 
  72 YAMAHA_DEVICE(0x1008, "UX96"),
 
  73 YAMAHA_DEVICE(0x1009, "UX16"),
 
  74 YAMAHA_INTERFACE(0x100a, 3, "EOS BX"),
 
  75 YAMAHA_DEVICE(0x100c, "UC-MX"),
 
  76 YAMAHA_DEVICE(0x100d, "UC-KX"),
 
  77 YAMAHA_DEVICE(0x100e, "S08"),
 
  78 YAMAHA_DEVICE(0x100f, "CLP-150"),
 
  79 YAMAHA_DEVICE(0x1010, "CLP-170"),
 
  80 YAMAHA_DEVICE(0x1011, "P-250"),
 
  81 YAMAHA_DEVICE(0x1012, "TYROS"),
 
  82 YAMAHA_DEVICE(0x1013, "PF-500"),
 
  83 YAMAHA_DEVICE(0x1014, "S90"),
 
  84 YAMAHA_DEVICE(0x1015, "MOTIF-R"),
 
  85 YAMAHA_DEVICE(0x1017, "CVP-204"),
 
  86 YAMAHA_DEVICE(0x1018, "CVP-206"),
 
  87 YAMAHA_DEVICE(0x1019, "CVP-208"),
 
  88 YAMAHA_DEVICE(0x101a, "CVP-210"),
 
  89 YAMAHA_DEVICE(0x101b, "PSR-1100"),
 
  90 YAMAHA_DEVICE(0x101c, "PSR-2100"),
 
  91 YAMAHA_DEVICE(0x101d, "CLP-175"),
 
  92 YAMAHA_DEVICE(0x101e, "PSR-K1"),
 
  93 YAMAHA_DEVICE(0x1020, "EZ-250i"),
 
  94 YAMAHA_DEVICE(0x1021, "MOTIF ES 6"),
 
  95 YAMAHA_DEVICE(0x1022, "MOTIF ES 7"),
 
  96 YAMAHA_DEVICE(0x1023, "MOTIF ES 8"),
 
  97 YAMAHA_DEVICE(0x1024, "CVP-301"),
 
  98 YAMAHA_DEVICE(0x1025, "CVP-303"),
 
  99 YAMAHA_DEVICE(0x1026, "CVP-305"),
 
 100 YAMAHA_DEVICE(0x1027, "CVP-307"),
 
 101 YAMAHA_DEVICE(0x1028, "CVP-309"),
 
 102 YAMAHA_DEVICE(0x1029, "CVP-309GP"),
 
 103 YAMAHA_DEVICE(0x102a, "PSR-1500"),
 
 104 YAMAHA_DEVICE(0x102b, "PSR-3000"),
 
 105 YAMAHA_DEVICE(0x102e, "ELS-01/01C"),
 
 106 YAMAHA_DEVICE(0x1030, "PSR-295/293"),
 
 107 YAMAHA_DEVICE(0x1031, "DGX-205/203"),
 
 108 YAMAHA_DEVICE(0x1032, "DGX-305"),
 
 109 YAMAHA_DEVICE(0x1033, "DGX-505"),
 
 110 YAMAHA_DEVICE(0x1034, NULL),
 
 111 YAMAHA_DEVICE(0x1035, NULL),
 
 112 YAMAHA_DEVICE(0x1036, NULL),
 
 113 YAMAHA_DEVICE(0x1037, NULL),
 
 114 YAMAHA_DEVICE(0x1038, NULL),
 
 115 YAMAHA_DEVICE(0x1039, NULL),
 
 116 YAMAHA_DEVICE(0x103a, NULL),
 
 117 YAMAHA_DEVICE(0x103b, NULL),
 
 118 YAMAHA_DEVICE(0x103c, NULL),
 
 119 YAMAHA_DEVICE(0x103d, NULL),
 
 120 YAMAHA_DEVICE(0x103e, NULL),
 
 121 YAMAHA_DEVICE(0x103f, NULL),
 
 122 YAMAHA_DEVICE(0x1040, NULL),
 
 123 YAMAHA_DEVICE(0x1041, NULL),
 
 124 YAMAHA_DEVICE(0x2000, "DGP-7"),
 
 125 YAMAHA_DEVICE(0x2001, "DGP-5"),
 
 126 YAMAHA_DEVICE(0x2002, NULL),
 
 127 YAMAHA_DEVICE(0x5000, "CS1D"),
 
 128 YAMAHA_DEVICE(0x5001, "DSP1D"),
 
 129 YAMAHA_DEVICE(0x5002, "DME32"),
 
 130 YAMAHA_DEVICE(0x5003, "DM2000"),
 
 131 YAMAHA_DEVICE(0x5004, "02R96"),
 
 132 YAMAHA_DEVICE(0x5005, "ACU16-C"),
 
 133 YAMAHA_DEVICE(0x5006, "NHB32-C"),
 
 134 YAMAHA_DEVICE(0x5007, "DM1000"),
 
 135 YAMAHA_DEVICE(0x5008, "01V96"),
 
 136 YAMAHA_DEVICE(0x5009, "SPX2000"),
 
 137 YAMAHA_DEVICE(0x500a, "PM5D"),
 
 138 YAMAHA_DEVICE(0x500b, "DME64N"),
 
 139 YAMAHA_DEVICE(0x500c, "DME24N"),
 
 140 YAMAHA_DEVICE(0x500d, NULL),
 
 141 YAMAHA_DEVICE(0x500e, NULL),
 
 142 YAMAHA_DEVICE(0x7000, "DTX"),
 
 143 YAMAHA_DEVICE(0x7010, "UB99"),
 
 145 #undef YAMAHA_INTERFACE
 
 148  * Roland/RolandED/Edirol/BOSS devices
 
 151         USB_DEVICE(0x0582, 0x0000),
 
 152         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 153                 .vendor_name = "Roland",
 
 154                 .product_name = "UA-100",
 
 155                 .ifnum = QUIRK_ANY_INTERFACE,
 
 156                 .type = QUIRK_COMPOSITE,
 
 157                 .data = (const struct snd_usb_audio_quirk[]) {
 
 160                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 161                                 .data = & (const struct audioformat) {
 
 162                                         .format = SNDRV_PCM_FORMAT_S16_LE,
 
 170                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 177                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 178                                 .data = & (const struct audioformat) {
 
 179                                         .format = SNDRV_PCM_FORMAT_S16_LE,
 
 184                                         .attributes = EP_CS_ATTR_FILL_MAX,
 
 187                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 194                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 195                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 196                                         .out_cables = 0x0007,
 
 207         USB_DEVICE(0x0582, 0x0002),
 
 208         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 209                 .vendor_name = "EDIROL",
 
 210                 .product_name = "UM-4",
 
 211                 .ifnum = QUIRK_ANY_INTERFACE,
 
 212                 .type = QUIRK_COMPOSITE,
 
 213                 .data = (const struct snd_usb_audio_quirk[]) {
 
 216                                 .type = QUIRK_IGNORE_INTERFACE
 
 220                                 .type = QUIRK_IGNORE_INTERFACE
 
 224                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 225                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 226                                         .out_cables = 0x000f,
 
 237         USB_DEVICE(0x0582, 0x0003),
 
 238         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 239                 .vendor_name = "Roland",
 
 240                 .product_name = "SC-8850",
 
 241                 .ifnum = QUIRK_ANY_INTERFACE,
 
 242                 .type = QUIRK_COMPOSITE,
 
 243                 .data = (const struct snd_usb_audio_quirk[]) {
 
 246                                 .type = QUIRK_IGNORE_INTERFACE
 
 250                                 .type = QUIRK_IGNORE_INTERFACE
 
 254                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 255                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 256                                         .out_cables = 0x003f,
 
 267         USB_DEVICE(0x0582, 0x0004),
 
 268         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 269                 .vendor_name = "Roland",
 
 270                 .product_name = "U-8",
 
 271                 .ifnum = QUIRK_ANY_INTERFACE,
 
 272                 .type = QUIRK_COMPOSITE,
 
 273                 .data = (const struct snd_usb_audio_quirk[]) {
 
 276                                 .type = QUIRK_IGNORE_INTERFACE
 
 280                                 .type = QUIRK_IGNORE_INTERFACE
 
 284                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 285                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 286                                         .out_cables = 0x0005,
 
 297         /* a later revision uses ID 0x0099 */
 
 298         USB_DEVICE(0x0582, 0x0005),
 
 299         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 300                 .vendor_name = "EDIROL",
 
 301                 .product_name = "UM-2",
 
 302                 .ifnum = QUIRK_ANY_INTERFACE,
 
 303                 .type = QUIRK_COMPOSITE,
 
 304                 .data = (const struct snd_usb_audio_quirk[]) {
 
 307                                 .type = QUIRK_IGNORE_INTERFACE
 
 311                                 .type = QUIRK_IGNORE_INTERFACE
 
 315                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 316                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 317                                         .out_cables = 0x0003,
 
 328         USB_DEVICE(0x0582, 0x0007),
 
 329         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 330                 .vendor_name = "Roland",
 
 331                 .product_name = "SC-8820",
 
 332                 .ifnum = QUIRK_ANY_INTERFACE,
 
 333                 .type = QUIRK_COMPOSITE,
 
 334                 .data = (const struct snd_usb_audio_quirk[]) {
 
 337                                 .type = QUIRK_IGNORE_INTERFACE
 
 341                                 .type = QUIRK_IGNORE_INTERFACE
 
 345                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 346                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 347                                         .out_cables = 0x0013,
 
 358         USB_DEVICE(0x0582, 0x0008),
 
 359         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 360                 .vendor_name = "Roland",
 
 361                 .product_name = "PC-300",
 
 362                 .ifnum = QUIRK_ANY_INTERFACE,
 
 363                 .type = QUIRK_COMPOSITE,
 
 364                 .data = (const struct snd_usb_audio_quirk[]) {
 
 367                                 .type = QUIRK_IGNORE_INTERFACE
 
 371                                 .type = QUIRK_IGNORE_INTERFACE
 
 375                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 376                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 377                                         .out_cables = 0x0001,
 
 388         /* a later revision uses ID 0x009d */
 
 389         USB_DEVICE(0x0582, 0x0009),
 
 390         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 391                 .vendor_name = "EDIROL",
 
 392                 .product_name = "UM-1",
 
 393                 .ifnum = QUIRK_ANY_INTERFACE,
 
 394                 .type = QUIRK_COMPOSITE,
 
 395                 .data = (const struct snd_usb_audio_quirk[]) {
 
 398                                 .type = QUIRK_IGNORE_INTERFACE
 
 402                                 .type = QUIRK_IGNORE_INTERFACE
 
 406                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 407                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 408                                         .out_cables = 0x0001,
 
 419         USB_DEVICE(0x0582, 0x000b),
 
 420         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 421                 .vendor_name = "Roland",
 
 422                 .product_name = "SK-500",
 
 423                 .ifnum = QUIRK_ANY_INTERFACE,
 
 424                 .type = QUIRK_COMPOSITE,
 
 425                 .data = (const struct snd_usb_audio_quirk[]) {
 
 428                                 .type = QUIRK_IGNORE_INTERFACE
 
 432                                 .type = QUIRK_IGNORE_INTERFACE
 
 436                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 437                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 438                                         .out_cables = 0x0013,
 
 449         /* thanks to Emiliano Grilli <emillo@libero.it>
 
 450          * for helping researching this data */
 
 451         USB_DEVICE(0x0582, 0x000c),
 
 452         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 453                 .vendor_name = "Roland",
 
 454                 .product_name = "SC-D70",
 
 455                 .ifnum = QUIRK_ANY_INTERFACE,
 
 456                 .type = QUIRK_COMPOSITE,
 
 457                 .data = (const struct snd_usb_audio_quirk[]) {
 
 460                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 461                                 .data = & (const struct audioformat) {
 
 462                                         .format = SNDRV_PCM_FORMAT_S24_3LE,
 
 470                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 477                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 478                                 .data = & (const struct audioformat) {
 
 479                                         .format = SNDRV_PCM_FORMAT_S24_3LE,
 
 487                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 494                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 495                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 496                                         .out_cables = 0x0007,
 
 507          * This quirk is for the "Advanced Driver" mode of the Edirol UA-5.
 
 508          * If the advanced mode switch at the back of the unit is off, the
 
 509          * UA-5 has ID 0x0582/0x0011 and is standard compliant (no quirks),
 
 510          * but offers only 16-bit PCM.
 
 511          * In advanced mode, the UA-5 will output S24_3LE samples (two
 
 512          * channels) at the rate indicated on the front switch, including
 
 513          * the 96kHz sample rate.
 
 515         USB_DEVICE(0x0582, 0x0010),
 
 516         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 517                 .vendor_name = "EDIROL",
 
 518                 .product_name = "UA-5",
 
 519                 .ifnum = QUIRK_ANY_INTERFACE,
 
 520                 .type = QUIRK_COMPOSITE,
 
 521                 .data = (const struct snd_usb_audio_quirk[]) {
 
 524                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 528                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 537         /* has ID 0x0013 when not in "Advanced Driver" mode */
 
 538         USB_DEVICE(0x0582, 0x0012),
 
 539         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 540                 .vendor_name = "Roland",
 
 541                 .product_name = "XV-5050",
 
 543                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 544                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 545                         .out_cables = 0x0001,
 
 551         /* has ID 0x0015 when not in "Advanced Driver" mode */
 
 552         USB_DEVICE(0x0582, 0x0014),
 
 553         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 554                 .vendor_name = "EDIROL",
 
 555                 .product_name = "UM-880",
 
 557                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 558                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 559                         .out_cables = 0x01ff,
 
 565         /* has ID 0x0017 when not in "Advanced Driver" mode */
 
 566         USB_DEVICE(0x0582, 0x0016),
 
 567         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 568                 .vendor_name = "EDIROL",
 
 569                 .product_name = "SD-90",
 
 570                 .ifnum = QUIRK_ANY_INTERFACE,
 
 571                 .type = QUIRK_COMPOSITE,
 
 572                 .data = (const struct snd_usb_audio_quirk[]) {
 
 575                                 .type = QUIRK_IGNORE_INTERFACE
 
 579                                 .type = QUIRK_IGNORE_INTERFACE
 
 583                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 584                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 585                                         .out_cables = 0x000f,
 
 596         /* has ID 0x001c when not in "Advanced Driver" mode */
 
 597         USB_DEVICE(0x0582, 0x001b),
 
 598         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 599                 .vendor_name = "Roland",
 
 600                 .product_name = "MMP-2",
 
 601                 .ifnum = QUIRK_ANY_INTERFACE,
 
 602                 .type = QUIRK_COMPOSITE,
 
 603                 .data = (const struct snd_usb_audio_quirk[]) {
 
 606                                 .type = QUIRK_IGNORE_INTERFACE
 
 610                                 .type = QUIRK_IGNORE_INTERFACE
 
 614                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 615                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 616                                         .out_cables = 0x0001,
 
 627         /* has ID 0x001e when not in "Advanced Driver" mode */
 
 628         USB_DEVICE(0x0582, 0x001d),
 
 629         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 630                 .vendor_name = "Roland",
 
 631                 .product_name = "V-SYNTH",
 
 633                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 634                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 635                         .out_cables = 0x0001,
 
 641         /* has ID 0x0024 when not in "Advanced Driver" mode */
 
 642         USB_DEVICE(0x0582, 0x0023),
 
 643         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 644                 .vendor_name = "EDIROL",
 
 645                 .product_name = "UM-550",
 
 647                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 648                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 649                         .out_cables = 0x003f,
 
 656          * This quirk is for the "Advanced Driver" mode. If off, the UA-20
 
 657          * has ID 0x0026 and is standard compliant, but has only 16-bit PCM
 
 660         USB_DEVICE(0x0582, 0x0025),
 
 661         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 662                 .vendor_name = "EDIROL",
 
 663                 .product_name = "UA-20",
 
 664                 .ifnum = QUIRK_ANY_INTERFACE,
 
 665                 .type = QUIRK_COMPOSITE,
 
 666                 .data = (const struct snd_usb_audio_quirk[]) {
 
 669                                 .type = QUIRK_IGNORE_INTERFACE
 
 673                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 674                                 .data = & (const struct audioformat) {
 
 675                                         .format = SNDRV_PCM_FORMAT_S24_3LE,
 
 683                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 690                                 .type = QUIRK_AUDIO_FIXED_ENDPOINT,
 
 691                                 .data = & (const struct audioformat) {
 
 692                                         .format = SNDRV_PCM_FORMAT_S24_3LE,
 
 700                                         .rates = SNDRV_PCM_RATE_CONTINUOUS,
 
 707                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 708                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 709                                         .out_cables = 0x0001,
 
 720         /* has ID 0x0028 when not in "Advanced Driver" mode */
 
 721         USB_DEVICE(0x0582, 0x0027),
 
 722         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 723                 .vendor_name = "EDIROL",
 
 724                 .product_name = "SD-20",
 
 726                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 727                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 728                         .out_cables = 0x0003,
 
 734         /* has ID 0x002a when not in "Advanced Driver" mode */
 
 735         USB_DEVICE(0x0582, 0x0029),
 
 736         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 737                 .vendor_name = "EDIROL",
 
 738                 .product_name = "SD-80",
 
 740                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 741                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 742                         .out_cables = 0x000f,
 
 748          * This quirk is for the "Advanced" modes of the Edirol UA-700.
 
 749          * If the sample format switch is not in an advanced setting, the
 
 750          * UA-700 has ID 0x0582/0x002c and is standard compliant (no quirks),
 
 751          * but offers only 16-bit PCM and no MIDI.
 
 753         USB_DEVICE_VENDOR_SPEC(0x0582, 0x002b),
 
 754         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 755                 .vendor_name = "EDIROL",
 
 756                 .product_name = "UA-700",
 
 757                 .ifnum = QUIRK_ANY_INTERFACE,
 
 758                 .type = QUIRK_COMPOSITE,
 
 759                 .data = (const struct snd_usb_audio_quirk[]) {
 
 762                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
 766                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
 770                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
 779         /* has ID 0x002e when not in "Advanced Driver" mode */
 
 780         USB_DEVICE(0x0582, 0x002d),
 
 781         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 782                 .vendor_name = "Roland",
 
 783                 .product_name = "XV-2020",
 
 785                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 786                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 787                         .out_cables = 0x0001,
 
 793         /* has ID 0x0030 when not in "Advanced Driver" mode */
 
 794         USB_DEVICE(0x0582, 0x002f),
 
 795         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 796                 .vendor_name = "Roland",
 
 797                 .product_name = "VariOS",
 
 799                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 800                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 801                         .out_cables = 0x0007,
 
 807         /* has ID 0x0034 when not in "Advanced Driver" mode */
 
 808         USB_DEVICE(0x0582, 0x0033),
 
 809         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 810                 .vendor_name = "EDIROL",
 
 811                 .product_name = "PCR",
 
 813                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 814                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 815                         .out_cables = 0x0003,
 
 820         /* TODO: add Roland M-1000 support */
 
 823          * Has ID 0x0038 when not in "Advanced Driver" mode;
 
 824          * later revisions use IDs 0x0054 and 0x00a2.
 
 826         USB_DEVICE(0x0582, 0x0037),
 
 827         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 828                 .vendor_name = "Roland",
 
 829                 .product_name = "Digital Piano",
 
 831                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 832                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 833                         .out_cables = 0x0001,
 
 840          * This quirk is for the "Advanced Driver" mode.  If off, the GS-10
 
 841          * has ID 0x003c and is standard compliant, but has only 16-bit PCM
 
 844         USB_DEVICE_VENDOR_SPEC(0x0582, 0x003b),
 
 845         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 846                 .vendor_name = "BOSS",
 
 847                 .product_name = "GS-10",
 
 848                 .ifnum = QUIRK_ANY_INTERFACE,
 
 849                 .type = QUIRK_COMPOSITE,
 
 850                 .data = & (const struct snd_usb_audio_quirk[]) {
 
 853                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 857                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 861                                 .type = QUIRK_MIDI_STANDARD_INTERFACE
 
 870         /* has ID 0x0041 when not in "Advanced Driver" mode */
 
 871         USB_DEVICE(0x0582, 0x0040),
 
 872         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 873                 .vendor_name = "Roland",
 
 874                 .product_name = "GI-20",
 
 876                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 877                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 878                         .out_cables = 0x0001,
 
 884         /* has ID 0x0043 when not in "Advanced Driver" mode */
 
 885         USB_DEVICE(0x0582, 0x0042),
 
 886         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 887                 .vendor_name = "Roland",
 
 888                 .product_name = "RS-70",
 
 890                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 891                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 892                         .out_cables = 0x0001,
 
 898         USB_DEVICE(0x0582, 0x0044),
 
 899         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 900                 .vendor_name = "Roland",
 
 901                 .product_name = "UA-1000",
 
 902                 .ifnum = QUIRK_ANY_INTERFACE,
 
 903                 .type = QUIRK_COMPOSITE,
 
 904                 .data = (const struct snd_usb_audio_quirk[]) {
 
 907                                 .type = QUIRK_AUDIO_EDIROL_UA1000
 
 911                                 .type = QUIRK_AUDIO_EDIROL_UA1000
 
 915                                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 916                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 917                                         .out_cables = 0x0003,
 
 928         /* has ID 0x004a when not in "Advanced Driver" mode */
 
 929         USB_DEVICE(0x0582, 0x0048),
 
 930         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 931                 .vendor_name = "EDIROL",
 
 932                 .product_name = "UR-80",
 
 934                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 935                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 936                         .out_cables = 0x0003,
 
 941         /* TODO: add Edirol M-100FX support */
 
 943         /* has ID 0x004f when not in "Advanced Driver" mode */
 
 944         USB_DEVICE(0x0582, 0x004d),
 
 945         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 946                 .vendor_name = "EDIROL",
 
 947                 .product_name = "PCR-A",
 
 949                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
 950                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
 951                         .out_cables = 0x0003,
 
 958          * This quirk is for the "Advanced Driver" mode. If off, the UA-3FX
 
 959          * is standard compliant, but has only 16-bit PCM.
 
 961         USB_DEVICE(0x0582, 0x0050),
 
 962         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 963                 .vendor_name = "EDIROL",
 
 964                 .product_name = "UA-3FX",
 
 965                 .ifnum = QUIRK_ANY_INTERFACE,
 
 966                 .type = QUIRK_COMPOSITE,
 
 967                 .data = (const struct snd_usb_audio_quirk[]) {
 
 970                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 974                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
 983         USB_DEVICE(0x0582, 0x0052),
 
 984         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 985                 .vendor_name = "EDIROL",
 
 986                 .product_name = "UM-1SX",
 
 988                 .type = QUIRK_MIDI_STANDARD_INTERFACE
 
 991         /* TODO: add Roland EXR support */
 
 993         /* has ID 0x0067 when not in "Advanced Driver" mode */
 
 994         USB_DEVICE(0x0582, 0x0065),
 
 995         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
 996                 .vendor_name = "EDIROL",
 
 997                 .product_name = "PCR-1",
 
 999                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1000                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1001                         .out_cables = 0x0001,
 
1007         /* has ID 0x006b when not in "Advanced Driver" mode */
 
1008         USB_DEVICE_VENDOR_SPEC(0x0582, 0x006a),
 
1009         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1010                 .vendor_name = "Roland",
 
1011                 .product_name = "SP-606",
 
1013                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1014                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1015                         .out_cables = 0x0001,
 
1021         /* has ID 0x006e when not in "Advanced Driver" mode */
 
1022         USB_DEVICE(0x0582, 0x006d),
 
1023         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1024                 .vendor_name = "Roland",
 
1025                 .product_name = "FANTOM-X",
 
1027                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1028                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1029                         .out_cables = 0x0001,
 
1035          * This quirk is for the "Advanced" modes of the Edirol UA-25.
 
1036          * If the switch is not in an advanced setting, the UA-25 has
 
1037          * ID 0x0582/0x0073 and is standard compliant (no quirks), but
 
1038          * offers only 16-bit PCM at 44.1 kHz and no MIDI.
 
1040         USB_DEVICE_VENDOR_SPEC(0x0582, 0x0074),
 
1041         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1042                 .vendor_name = "EDIROL",
 
1043                 .product_name = "UA-25",
 
1044                 .ifnum = QUIRK_ANY_INTERFACE,
 
1045                 .type = QUIRK_COMPOSITE,
 
1046                 .data = (const struct snd_usb_audio_quirk[]) {
 
1049                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
1053                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
1057                                 .type = QUIRK_AUDIO_EDIROL_UA700_UA25
 
1066         /* has ID 0x0076 when not in "Advanced Driver" mode */
 
1067         USB_DEVICE(0x0582, 0x0075),
 
1068         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1069                 .vendor_name = "BOSS",
 
1070                 .product_name = "DR-880",
 
1072                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1073                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1074                         .out_cables = 0x0001,
 
1080         /* has ID 0x007b when not in "Advanced Driver" mode */
 
1081         USB_DEVICE_VENDOR_SPEC(0x0582, 0x007a),
 
1082         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1083                 .vendor_name = "Roland",
 
1084                 /* "RD" or "RD-700SX"? */
 
1086                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1087                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1088                         .out_cables = 0x0003,
 
1093         /* TODO: add Edirol UA-101 support */
 
1094         /* TODO: add Roland G-70 support */
 
1095         /* TODO: add Roland V-SYNTH XT support */
 
1096         /* TODO: add BOSS GT-PRO support */
 
1098         /* has ID 0x008c when not in "Advanced Driver" mode */
 
1099         USB_DEVICE(0x0582, 0x008b),
 
1100         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1101                 .vendor_name = "EDIROL",
 
1102                 .product_name = "PC-50",
 
1104                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1105                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1106                         .out_cables = 0x0001,
 
1111         /* TODO: add Edirol PC-80 support */
 
1112         /* TODO: add Edirol UA-1EX support */
 
1114         USB_DEVICE(0x0582, 0x009a),
 
1115         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1116                 .vendor_name = "EDIROL",
 
1117                 .product_name = "UM-3EX",
 
1119                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1120                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1121                         .out_cables = 0x000f,
 
1126         /* TODO: add Edirol MD-P1 support */
 
1128 /* Guillemot devices */
 
1131          * This is for the "Windows Edition" where the external MIDI ports are
 
1132          * the only MIDI ports; the control data is reported through HID
 
1133          * interfaces.  The "Macintosh Edition" has ID 0xd002 and uses standard
 
1134          * compliant USB MIDI ports for external MIDI and controls.
 
1136         USB_DEVICE_VENDOR_SPEC(0x06f8, 0xb000),
 
1137         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1138                 .vendor_name = "Hercules",
 
1139                 .product_name = "DJ Console (WE)",
 
1141                 .type = QUIRK_MIDI_FIXED_ENDPOINT,
 
1142                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1143                         .out_cables = 0x0001,
 
1149 /* Midiman/M-Audio devices */
 
1151         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1002),
 
1152         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1153                 .vendor_name = "M-Audio",
 
1154                 .product_name = "MidiSport 2x2",
 
1155                 .ifnum = QUIRK_ANY_INTERFACE,
 
1156                 .type = QUIRK_MIDI_MIDIMAN,
 
1157                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1158                         .out_cables = 0x0003,
 
1164         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1011),
 
1165         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1166                 .vendor_name = "M-Audio",
 
1167                 .product_name = "MidiSport 1x1",
 
1168                 .ifnum = QUIRK_ANY_INTERFACE,
 
1169                 .type = QUIRK_MIDI_MIDIMAN,
 
1170                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1171                         .out_cables = 0x0001,
 
1177         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1015),
 
1178         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1179                 .vendor_name = "M-Audio",
 
1180                 .product_name = "Keystation",
 
1181                 .ifnum = QUIRK_ANY_INTERFACE,
 
1182                 .type = QUIRK_MIDI_MIDIMAN,
 
1183                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1184                         .out_cables = 0x0001,
 
1190         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1021),
 
1191         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1192                 .vendor_name = "M-Audio",
 
1193                 .product_name = "MidiSport 4x4",
 
1194                 .ifnum = QUIRK_ANY_INTERFACE,
 
1195                 .type = QUIRK_MIDI_MIDIMAN,
 
1196                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1197                         .out_cables = 0x000f,
 
1204          * For hardware revision 1.05; in the later revisions (1.10 and
 
1205          * 1.21), 0x1031 is the ID for the device without firmware.
 
1206          * Thanks to Olaf Giesbrecht <Olaf_Giesbrecht@yahoo.de>
 
1208         USB_DEVICE_VER(0x0763, 0x1031, 0x0100, 0x0109),
 
1209         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1210                 .vendor_name = "M-Audio",
 
1211                 .product_name = "MidiSport 8x8",
 
1212                 .ifnum = QUIRK_ANY_INTERFACE,
 
1213                 .type = QUIRK_MIDI_MIDIMAN,
 
1214                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1215                         .out_cables = 0x01ff,
 
1221         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1033),
 
1222         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1223                 .vendor_name = "M-Audio",
 
1224                 .product_name = "MidiSport 8x8",
 
1225                 .ifnum = QUIRK_ANY_INTERFACE,
 
1226                 .type = QUIRK_MIDI_MIDIMAN,
 
1227                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1228                         .out_cables = 0x01ff,
 
1234         USB_DEVICE_VENDOR_SPEC(0x0763, 0x1041),
 
1235         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1236                 .vendor_name = "M-Audio",
 
1237                 .product_name = "MidiSport 2x4",
 
1238                 .ifnum = QUIRK_ANY_INTERFACE,
 
1239                 .type = QUIRK_MIDI_MIDIMAN,
 
1240                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1241                         .out_cables = 0x000f,
 
1247         USB_DEVICE_VENDOR_SPEC(0x0763, 0x2001),
 
1248         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1249                 .vendor_name = "M-Audio",
 
1250                 .product_name = "Quattro",
 
1251                 .ifnum = QUIRK_ANY_INTERFACE,
 
1252                 .type = QUIRK_COMPOSITE,
 
1253                 .data = & (const struct snd_usb_audio_quirk[]) {
 
1255                          * Interfaces 0-2 are "Windows-compatible", 16-bit only,
 
1256                          * and share endpoints with the other interfaces.
 
1257                          * Ignore them.  The other interfaces can do 24 bits,
 
1258                          * but captured samples are big-endian (see usbaudio.c).
 
1262                                 .type = QUIRK_IGNORE_INTERFACE
 
1266                                 .type = QUIRK_IGNORE_INTERFACE
 
1270                                 .type = QUIRK_IGNORE_INTERFACE
 
1274                                 .type = QUIRK_IGNORE_INTERFACE
 
1278                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1282                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1286                                 .type = QUIRK_IGNORE_INTERFACE
 
1290                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1294                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1298                                 .type = QUIRK_MIDI_MIDIMAN,
 
1299                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1300                                         .out_cables = 0x0001,
 
1311         USB_DEVICE_VENDOR_SPEC(0x0763, 0x2003),
 
1312         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1313                 .vendor_name = "M-Audio",
 
1314                 .product_name = "AudioPhile",
 
1316                 .type = QUIRK_MIDI_MIDIMAN,
 
1317                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1318                         .out_cables = 0x0001,
 
1324         USB_DEVICE_VENDOR_SPEC(0x0763, 0x2008),
 
1325         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1326                 .vendor_name = "M-Audio",
 
1327                 .product_name = "Ozone",
 
1329                 .type = QUIRK_MIDI_MIDIMAN,
 
1330                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1331                         .out_cables = 0x0001,
 
1337         USB_DEVICE_VENDOR_SPEC(0x0763, 0x200d),
 
1338         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1339                 .vendor_name = "M-Audio",
 
1340                 .product_name = "OmniStudio",
 
1341                 .ifnum = QUIRK_ANY_INTERFACE,
 
1342                 .type = QUIRK_COMPOSITE,
 
1343                 .data = & (const struct snd_usb_audio_quirk[]) {
 
1346                                 .type = QUIRK_IGNORE_INTERFACE
 
1350                                 .type = QUIRK_IGNORE_INTERFACE
 
1354                                 .type = QUIRK_IGNORE_INTERFACE
 
1358                                 .type = QUIRK_IGNORE_INTERFACE
 
1362                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1366                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1370                                 .type = QUIRK_IGNORE_INTERFACE
 
1374                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1378                                 .type = QUIRK_AUDIO_STANDARD_INTERFACE
 
1382                                 .type = QUIRK_MIDI_MIDIMAN,
 
1383                                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1384                                         .out_cables = 0x0001,
 
1395 /* Mark of the Unicorn devices */
 
1397         /* thanks to Robert A. Lerche <ral 'at' msbit.com> */
 
1398         .match_flags = USB_DEVICE_ID_MATCH_VENDOR |
 
1399                        USB_DEVICE_ID_MATCH_PRODUCT |
 
1400                        USB_DEVICE_ID_MATCH_DEV_SUBCLASS,
 
1402         .idProduct = 0x0001,
 
1403         .bDeviceSubClass = 2,
 
1404         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1405                 .vendor_name = "MOTU",
 
1406                 .product_name = "Fastlane",
 
1407                 .ifnum = QUIRK_ANY_INTERFACE,
 
1408                 .type = QUIRK_COMPOSITE,
 
1409                 .data = & (const struct snd_usb_audio_quirk[]) {
 
1412                                 .type = QUIRK_MIDI_RAW
 
1416                                 .type = QUIRK_IGNORE_INTERFACE
 
1426         /* Creative Sound Blaster MP3+ */
 
1427         USB_DEVICE(0x041e, 0x3010),
 
1428         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1429                 .vendor_name = "Creative Labs",
 
1430                 .product_name = "Sound Blaster MP3+",
 
1431                 .ifnum = QUIRK_NO_INTERFACE
 
1436 /* Emagic devices */
 
1438         USB_DEVICE(0x086a, 0x0001),
 
1439         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1440                 .vendor_name = "Emagic",
 
1441                 /* .product_name = "Unitor8", */
 
1443                 .type = QUIRK_MIDI_EMAGIC,
 
1444                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1445                         .out_cables = 0x80ff,
 
1451         USB_DEVICE(0x086a, 0x0002),
 
1452         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1453                 .vendor_name = "Emagic",
 
1454                 /* .product_name = "AMT8", */
 
1456                 .type = QUIRK_MIDI_EMAGIC,
 
1457                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1458                         .out_cables = 0x80ff,
 
1464         USB_DEVICE(0x086a, 0x0003),
 
1465         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1466                 .vendor_name = "Emagic",
 
1467                 /* .product_name = "MT4", */
 
1469                 .type = QUIRK_MIDI_EMAGIC,
 
1470                 .data = & (const struct snd_usb_midi_endpoint_info) {
 
1471                         .out_cables = 0x800f,
 
1477 /* TerraTec devices */
 
1479         USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0012),
 
1480         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1481                 .vendor_name = "TerraTec",
 
1482                 .product_name = "PHASE 26",
 
1484                 .type = QUIRK_MIDI_STANDARD_INTERFACE
 
1488         USB_DEVICE_VENDOR_SPEC(0x0ccd, 0x0013),
 
1489         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1490                 .vendor_name = "TerraTec",
 
1491                 .product_name = "PHASE 26",
 
1493                 .type = QUIRK_MIDI_STANDARD_INTERFACE
 
1497 /* Novation EMS devices */
 
1499         USB_DEVICE_VENDOR_SPEC(0x1235, 0x0001),
 
1500         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1501                 .vendor_name = "Novation",
 
1502                 .product_name = "ReMOTE Audio/XStation",
 
1504                 .type = QUIRK_MIDI_NOVATION
 
1508         USB_DEVICE_VENDOR_SPEC(0x1235, 0x0002),
 
1509         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1510                 .vendor_name = "Novation",
 
1511                 .product_name = "Speedio",
 
1513                 .type = QUIRK_MIDI_NOVATION
 
1517         USB_DEVICE_VENDOR_SPEC(0x1235, 0x4661),
 
1518         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1519                 .vendor_name = "Novation",
 
1520                 .product_name = "ReMOTE25",
 
1522                 .type = QUIRK_MIDI_NOVATION
 
1527         USB_DEVICE(0x4752, 0x0011),
 
1528         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1529                 .vendor_name = "Miditech",
 
1530                 .product_name = "Midistart-2",
 
1532                 .type = QUIRK_MIDI_MIDITECH
 
1536         USB_DEVICE(0x7104, 0x2202),
 
1537         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1538                 .vendor_name = "Miditech",
 
1539                 .product_name = "MidiStudio-2",
 
1541                 .type = QUIRK_MIDI_MIDITECH
 
1547          * Some USB MIDI devices don't have an audio control interface,
 
1548          * so we have to grab MIDI streaming interfaces here.
 
1550         .match_flags = USB_DEVICE_ID_MATCH_INT_CLASS |
 
1551                        USB_DEVICE_ID_MATCH_INT_SUBCLASS,
 
1552         .bInterfaceClass = USB_CLASS_AUDIO,
 
1553         .bInterfaceSubClass = USB_SUBCLASS_MIDI_STREAMING,
 
1554         .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
 
1555                 .ifnum = QUIRK_ANY_INTERFACE,
 
1556                 .type = QUIRK_MIDI_STANDARD_INTERFACE
 
1560 #undef USB_DEVICE_VENDOR_SPEC