2005-04-16 15:20:36 -07:00
/*
* ALSA USB Audio Driver
*
* Copyright ( c ) 2002 by Takashi Iwai < tiwai @ suse . de > ,
* Clemens Ladisch < clemens @ ladisch . de >
*
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
/*
* The contents of this file are part of the driver ' s id_table .
*
* In a perfect world , this file would be empty .
*/
/*
* Use this for devices where other interfaces are standard compliant ,
* to prevent the quirk being applied to those interfaces . ( To work with
* hotplugging , bDeviceClass must be set to USB_CLASS_PER_INTERFACE . )
*/
# define USB_DEVICE_VENDOR_SPEC(vend, prod) \
. match_flags = USB_DEVICE_ID_MATCH_VENDOR | \
USB_DEVICE_ID_MATCH_PRODUCT | \
USB_DEVICE_ID_MATCH_INT_CLASS , \
. idVendor = vend , \
. idProduct = prod , \
. bInterfaceClass = USB_CLASS_VENDOR_SPEC
2011-08-26 13:19:49 +02:00
/* FTDI devices */
{
USB_DEVICE ( 0x0403 , 0xb8d8 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "STARR LABS", */
/* .product_name = "Starr Labs MIDI USB device", */
. ifnum = 0 ,
. type = QUIRK_MIDI_FTDI
}
} ,
2013-01-03 12:59:07 +01:00
{
/* Creative BT-D1 */
USB_DEVICE ( 0x041e , 0x0005 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S16_LE ,
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. endpoint = 0x03 ,
. ep_attr = USB_ENDPOINT_XFER_ISOC ,
. attributes = 0 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 48000 ,
. rate_max = 48000 ,
}
}
} ,
2009-01-12 23:17:47 +01:00
/* Creative/Toshiba Multimedia Center SB-0500 */
{
USB_DEVICE ( 0x041e , 0x3048 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Toshiba " ,
. product_name = " SB-0500 " ,
. ifnum = QUIRK_NO_INTERFACE
}
} ,
2008-02-25 11:04:19 +01:00
/* Creative/E-Mu devices */
{
USB_DEVICE ( 0x041e , 0x3010 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Creative Labs " ,
. product_name = " Sound Blaster MP3+ " ,
. ifnum = QUIRK_NO_INTERFACE
}
} ,
{
/* E-Mu 0202 USB */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x041e ,
. idProduct = 0x3f02 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
} ,
{
/* E-Mu 0404 USB */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x041e ,
. idProduct = 0x3f04 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
} ,
2008-09-26 01:07:03 -04:00
{
/* E-Mu Tracker Pre */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x041e ,
. idProduct = 0x3f0a ,
. bInterfaceClass = USB_CLASS_AUDIO ,
} ,
2011-02-08 01:22:36 -05:00
{
/* E-Mu 0204 USB */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x041e ,
. idProduct = 0x3f19 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2008-09-26 01:07:03 -04:00
} ,
2008-02-25 11:04:19 +01:00
2012-12-15 05:30:33 +01:00
/*
* HP Wireless Audio
* When not ignored , causes instability issues for some users , forcing them to
* blacklist the entire module .
*/
{
USB_DEVICE ( 0x0424 , 0xb832 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Standard Microsystems Corp. " ,
. product_name = " HP Wireless Audio " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
/* Mixer */
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE ,
} ,
/* Playback */
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE ,
} ,
/* Capture */
{
. ifnum = 2 ,
. type = QUIRK_IGNORE_INTERFACE ,
} ,
/* HID Device, .ifnum = 3 */
{
. ifnum = - 1 ,
}
}
}
} ,
2007-05-07 09:27:05 +02:00
/*
* Logitech QuickCam : bDeviceClass is vendor - specific , so generic interface
* class matches do not take effect without an explicit ID match .
*/
2007-05-10 08:52:19 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x0850 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-05-10 08:52:19 +02:00
} ,
2007-07-09 10:42:35 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x08ae ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-07-09 10:42:35 +02:00
} ,
2007-07-10 13:03:57 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x08c6 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-07-10 13:03:57 +02:00
} ,
2007-05-07 09:27:05 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x08f0 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-05-07 09:27:05 +02:00
} ,
2007-10-22 11:57:17 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x08f5 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-10-22 11:57:17 +02:00
} ,
2007-05-07 09:27:05 +02:00
{
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. idVendor = 0x046d ,
. idProduct = 0x08f6 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL
2007-05-07 09:27:05 +02:00
} ,
2009-01-14 09:47:57 +01:00
{
USB_DEVICE ( 0x046d , 0x0990 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Logitech, Inc. " ,
. product_name = " QuickCam Pro 9000 " ,
. ifnum = QUIRK_NO_INTERFACE
}
} ,
2008-02-25 11:04:19 +01:00
2005-04-16 15:20:36 -07:00
/*
* Yamaha devices
*/
# define YAMAHA_DEVICE(id, name) { \
USB_DEVICE ( 0x0499 , id ) , \
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) { \
2005-04-16 15:20:36 -07:00
. vendor_name = " Yamaha " , \
. product_name = name , \
. ifnum = QUIRK_ANY_INTERFACE , \
. type = QUIRK_MIDI_YAMAHA \
} \
}
# define YAMAHA_INTERFACE(id, intf, name) { \
USB_DEVICE_VENDOR_SPEC ( 0x0499 , id ) , \
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) { \
2005-04-16 15:20:36 -07:00
. vendor_name = " Yamaha " , \
. product_name = name , \
. ifnum = intf , \
. type = QUIRK_MIDI_YAMAHA \
} \
}
YAMAHA_DEVICE ( 0x1000 , " UX256 " ) ,
YAMAHA_DEVICE ( 0x1001 , " MU1000 " ) ,
YAMAHA_DEVICE ( 0x1002 , " MU2000 " ) ,
YAMAHA_DEVICE ( 0x1003 , " MU500 " ) ,
YAMAHA_INTERFACE ( 0x1004 , 3 , " UW500 " ) ,
YAMAHA_DEVICE ( 0x1005 , " MOTIF6 " ) ,
YAMAHA_DEVICE ( 0x1006 , " MOTIF7 " ) ,
YAMAHA_DEVICE ( 0x1007 , " MOTIF8 " ) ,
YAMAHA_DEVICE ( 0x1008 , " UX96 " ) ,
YAMAHA_DEVICE ( 0x1009 , " UX16 " ) ,
YAMAHA_INTERFACE ( 0x100a , 3 , " EOS BX " ) ,
YAMAHA_DEVICE ( 0x100c , " UC-MX " ) ,
YAMAHA_DEVICE ( 0x100d , " UC-KX " ) ,
YAMAHA_DEVICE ( 0x100e , " S08 " ) ,
YAMAHA_DEVICE ( 0x100f , " CLP-150 " ) ,
YAMAHA_DEVICE ( 0x1010 , " CLP-170 " ) ,
YAMAHA_DEVICE ( 0x1011 , " P-250 " ) ,
YAMAHA_DEVICE ( 0x1012 , " TYROS " ) ,
YAMAHA_DEVICE ( 0x1013 , " PF-500 " ) ,
YAMAHA_DEVICE ( 0x1014 , " S90 " ) ,
YAMAHA_DEVICE ( 0x1015 , " MOTIF-R " ) ,
2006-03-15 12:24:19 +01:00
YAMAHA_DEVICE ( 0x1016 , " MDP-5 " ) ,
2005-04-16 15:20:36 -07:00
YAMAHA_DEVICE ( 0x1017 , " CVP-204 " ) ,
YAMAHA_DEVICE ( 0x1018 , " CVP-206 " ) ,
YAMAHA_DEVICE ( 0x1019 , " CVP-208 " ) ,
YAMAHA_DEVICE ( 0x101a , " CVP-210 " ) ,
YAMAHA_DEVICE ( 0x101b , " PSR-1100 " ) ,
YAMAHA_DEVICE ( 0x101c , " PSR-2100 " ) ,
YAMAHA_DEVICE ( 0x101d , " CLP-175 " ) ,
YAMAHA_DEVICE ( 0x101e , " PSR-K1 " ) ,
2006-03-15 12:24:19 +01:00
YAMAHA_DEVICE ( 0x101f , " EZ-J24 " ) ,
2005-04-16 15:20:36 -07:00
YAMAHA_DEVICE ( 0x1020 , " EZ-250i " ) ,
YAMAHA_DEVICE ( 0x1021 , " MOTIF ES 6 " ) ,
YAMAHA_DEVICE ( 0x1022 , " MOTIF ES 7 " ) ,
YAMAHA_DEVICE ( 0x1023 , " MOTIF ES 8 " ) ,
YAMAHA_DEVICE ( 0x1024 , " CVP-301 " ) ,
YAMAHA_DEVICE ( 0x1025 , " CVP-303 " ) ,
YAMAHA_DEVICE ( 0x1026 , " CVP-305 " ) ,
YAMAHA_DEVICE ( 0x1027 , " CVP-307 " ) ,
YAMAHA_DEVICE ( 0x1028 , " CVP-309 " ) ,
YAMAHA_DEVICE ( 0x1029 , " CVP-309GP " ) ,
YAMAHA_DEVICE ( 0x102a , " PSR-1500 " ) ,
YAMAHA_DEVICE ( 0x102b , " PSR-3000 " ) ,
YAMAHA_DEVICE ( 0x102e , " ELS-01/01C " ) ,
YAMAHA_DEVICE ( 0x1030 , " PSR-295/293 " ) ,
YAMAHA_DEVICE ( 0x1031 , " DGX-205/203 " ) ,
YAMAHA_DEVICE ( 0x1032 , " DGX-305 " ) ,
YAMAHA_DEVICE ( 0x1033 , " DGX-505 " ) ,
YAMAHA_DEVICE ( 0x1034 , NULL ) ,
YAMAHA_DEVICE ( 0x1035 , NULL ) ,
YAMAHA_DEVICE ( 0x1036 , NULL ) ,
YAMAHA_DEVICE ( 0x1037 , NULL ) ,
YAMAHA_DEVICE ( 0x1038 , NULL ) ,
YAMAHA_DEVICE ( 0x1039 , NULL ) ,
YAMAHA_DEVICE ( 0x103a , NULL ) ,
YAMAHA_DEVICE ( 0x103b , NULL ) ,
YAMAHA_DEVICE ( 0x103c , NULL ) ,
2005-07-01 16:19:39 +02:00
YAMAHA_DEVICE ( 0x103d , NULL ) ,
2005-09-20 09:06:36 +02:00
YAMAHA_DEVICE ( 0x103e , NULL ) ,
YAMAHA_DEVICE ( 0x103f , NULL ) ,
YAMAHA_DEVICE ( 0x1040 , NULL ) ,
YAMAHA_DEVICE ( 0x1041 , NULL ) ,
2006-07-21 10:46:18 +02:00
YAMAHA_DEVICE ( 0x1042 , NULL ) ,
YAMAHA_DEVICE ( 0x1043 , NULL ) ,
YAMAHA_DEVICE ( 0x1044 , NULL ) ,
YAMAHA_DEVICE ( 0x1045 , NULL ) ,
2008-07-10 11:01:06 +02:00
YAMAHA_INTERFACE ( 0x104e , 0 , NULL ) ,
2008-07-10 11:05:42 +02:00
YAMAHA_DEVICE ( 0x104f , NULL ) ,
YAMAHA_DEVICE ( 0x1050 , NULL ) ,
YAMAHA_DEVICE ( 0x1051 , NULL ) ,
YAMAHA_DEVICE ( 0x1052 , NULL ) ,
2010-10-04 13:09:12 +02:00
YAMAHA_INTERFACE ( 0x1053 , 0 , NULL ) ,
YAMAHA_INTERFACE ( 0x1054 , 0 , NULL ) ,
YAMAHA_DEVICE ( 0x1055 , NULL ) ,
YAMAHA_DEVICE ( 0x1056 , NULL ) ,
YAMAHA_DEVICE ( 0x1057 , NULL ) ,
YAMAHA_DEVICE ( 0x1058 , NULL ) ,
YAMAHA_DEVICE ( 0x1059 , NULL ) ,
YAMAHA_DEVICE ( 0x105a , NULL ) ,
YAMAHA_DEVICE ( 0x105b , NULL ) ,
YAMAHA_DEVICE ( 0x105c , NULL ) ,
YAMAHA_DEVICE ( 0x105d , NULL ) ,
2011-12-19 23:09:15 +01:00
{
USB_DEVICE ( 0x0499 , 0x1503 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Yamaha", */
/* .product_name = "MOX6/MOX8", */
. ifnum = QUIRK_ANY_INTERFACE ,
2013-04-24 21:19:19 -04:00
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_YAMAHA
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0499 , 0x1507 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Yamaha", */
/* .product_name = "THR10", */
. ifnum = QUIRK_ANY_INTERFACE ,
2013-04-24 21:19:20 -04:00
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_YAMAHA
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0499 , 0x150a ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Yamaha", */
/* .product_name = "THR5A", */
. ifnum = QUIRK_ANY_INTERFACE ,
2013-04-24 21:19:21 -04:00
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_YAMAHA
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0499 , 0x150c ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Yamaha", */
/* .product_name = "THR10C", */
. ifnum = QUIRK_ANY_INTERFACE ,
2011-12-19 23:09:15 +01:00
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_YAMAHA
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
YAMAHA_DEVICE ( 0x2000 , " DGP-7 " ) ,
YAMAHA_DEVICE ( 0x2001 , " DGP-5 " ) ,
YAMAHA_DEVICE ( 0x2002 , NULL ) ,
2010-10-04 13:09:12 +02:00
YAMAHA_DEVICE ( 0x2003 , NULL ) ,
2005-04-16 15:20:36 -07:00
YAMAHA_DEVICE ( 0x5000 , " CS1D " ) ,
YAMAHA_DEVICE ( 0x5001 , " DSP1D " ) ,
YAMAHA_DEVICE ( 0x5002 , " DME32 " ) ,
YAMAHA_DEVICE ( 0x5003 , " DM2000 " ) ,
YAMAHA_DEVICE ( 0x5004 , " 02R96 " ) ,
YAMAHA_DEVICE ( 0x5005 , " ACU16-C " ) ,
YAMAHA_DEVICE ( 0x5006 , " NHB32-C " ) ,
YAMAHA_DEVICE ( 0x5007 , " DM1000 " ) ,
YAMAHA_DEVICE ( 0x5008 , " 01V96 " ) ,
YAMAHA_DEVICE ( 0x5009 , " SPX2000 " ) ,
YAMAHA_DEVICE ( 0x500a , " PM5D " ) ,
YAMAHA_DEVICE ( 0x500b , " DME64N " ) ,
YAMAHA_DEVICE ( 0x500c , " DME24N " ) ,
YAMAHA_DEVICE ( 0x500d , NULL ) ,
YAMAHA_DEVICE ( 0x500e , NULL ) ,
2006-07-21 10:46:18 +02:00
YAMAHA_DEVICE ( 0x500f , NULL ) ,
2005-04-16 15:20:36 -07:00
YAMAHA_DEVICE ( 0x7000 , " DTX " ) ,
YAMAHA_DEVICE ( 0x7010 , " UB99 " ) ,
# undef YAMAHA_DEVICE
# undef YAMAHA_INTERFACE
/*
* Roland / RolandED / Edirol / BOSS devices
*/
{
USB_DEVICE ( 0x0582 , 0x0000 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " UA-100 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S16_LE ,
2005-04-16 15:20:36 -07:00
. channels = 4 ,
. iface = 0 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = 0 ,
. endpoint = 0x01 ,
. ep_attr = 0x09 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S16_LE ,
2005-04-16 15:20:36 -07:00
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
2010-02-22 23:49:13 +01:00
. attributes = UAC_EP_CS_ATTR_FILL_MAX ,
2005-04-16 15:20:36 -07:00
. endpoint = 0x81 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0007 ,
. in_cables = 0x0007
}
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0002 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-4 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x000f ,
. in_cables = 0x000f
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0003 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " SC-8850 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x003f ,
. in_cables = 0x003f
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0004 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " U-8 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0005 ,
. in_cables = 0x0005
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
2006-01-19 08:25:19 +01:00
/* Has ID 0x0099 when not in "Advanced Driver" mode.
* The UM - 2 EX has only one input , but we cannot detect this . */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0005 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-2 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0007 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " SC-8820 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0013 ,
. in_cables = 0x0013
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0008 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " PC-300 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
2006-01-19 08:25:19 +01:00
/* has ID 0x009d when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0009 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-1 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x000b ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " SK-500 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0013 ,
. in_cables = 0x0013
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
/* thanks to Emiliano Grilli <emillo@libero.it>
* for helping researching this data */
USB_DEVICE ( 0x0582 , 0x000c ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " SC-D70 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
2005-04-16 15:20:36 -07:00
. channels = 2 ,
. iface = 0 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = 0 ,
. endpoint = 0x01 ,
. ep_attr = 0x01 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
2005-04-16 15:20:36 -07:00
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = 0 ,
. endpoint = 0x81 ,
. ep_attr = 0x01 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0007 ,
. in_cables = 0x0007
}
} ,
{
. ifnum = - 1
}
}
}
} ,
{ /*
* This quirk is for the " Advanced Driver " mode of the Edirol UA - 5.
* If the advanced mode switch at the back of the unit is off , the
* UA - 5 has ID 0x0582 / 0x0011 and is standard compliant ( no quirks ) ,
* but offers only 16 - bit PCM .
* In advanced mode , the UA - 5 will output S24_3LE samples ( two
* channels ) at the rate indicated on the front switch , including
* the 96 kHz sample rate .
*/
USB_DEVICE ( 0x0582 , 0x0010 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UA-5 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0013 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0012 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " XV-5050 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0015 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0014 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-880 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x01ff ,
. in_cables = 0x01ff
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0017 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0016 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " SD-90 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
2011-01-10 16:30:54 +01:00
. type = QUIRK_AUDIO_STANDARD_INTERFACE
2005-05-17 09:14:27 +02:00
} ,
{
. ifnum = 1 ,
2011-01-10 16:30:54 +01:00
. type = QUIRK_AUDIO_STANDARD_INTERFACE
2005-05-17 09:14:27 +02:00
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x000f ,
. in_cables = 0x000f
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x001c when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x001b ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " MMP-2 " ,
2005-05-17 09:14:27 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-05-17 09:14:27 +02:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-05-17 09:14:27 +02:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x001e when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x001d ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " V-SYNTH " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0024 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0023 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-550 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x003f ,
. in_cables = 0x003f
}
}
} ,
{
/*
* This quirk is for the " Advanced Driver " mode . If off , the UA - 20
* has ID 0x0026 and is standard compliant , but has only 16 - bit PCM
* and no MIDI .
*/
USB_DEVICE ( 0x0582 , 0x0025 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UA-20 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-11-21 16:40:00 +01:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
2005-04-16 15:20:36 -07:00
{
. ifnum = 1 ,
2005-11-21 16:40:00 +01:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
2005-11-21 16:40:00 +01:00
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = 0 ,
. endpoint = 0x01 ,
. ep_attr = 0x01 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 2 ,
2005-11-21 16:40:00 +01:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:15 +01:00
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
2005-11-21 16:40:00 +01:00
. channels = 2 ,
. iface = 2 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = 0 ,
. endpoint = 0x82 ,
. ep_attr = 0x01 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 44100 ,
. rate_max = 44100 ,
}
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 3 ,
2005-11-21 16:40:00 +01:00
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = - 1
}
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0028 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0027 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " SD-20 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x002a when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0029 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " SD-80 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x000f ,
. in_cables = 0x000f
}
}
} ,
{ /*
* This quirk is for the " Advanced " modes of the Edirol UA - 700.
* If the sample format switch is not in an advanced setting , the
* UA - 700 has ID 0x0582 / 0x002c and is standard compliant ( no quirks ) ,
* but offers only 16 - bit PCM and no MIDI .
*/
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x002b ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UA-700 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 1 ,
2008-10-04 16:27:36 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 2 ,
2008-10-04 16:27:36 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 3 ,
2008-10-07 20:54:18 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = - 1
}
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x002e when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x002d ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " XV-2020 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0030 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x002f ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " VariOS " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0007 ,
. in_cables = 0x0007
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0034 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0033 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " PCR " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
2005-09-21 16:33:49 +02:00
/* TODO: add Roland M-1000 support */
2005-04-16 15:20:36 -07:00
{
2005-09-21 16:33:49 +02:00
/*
* Has ID 0x0038 when not in " Advanced Driver " mode ;
* later revisions use IDs 0x0054 and 0x00a2 .
*/
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0037 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " Digital Piano " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-04-06 09:47:02 +02:00
/*
* This quirk is for the " Advanced Driver " mode . If off , the GS - 10
* has ID 0x003c and is standard compliant , but has only 16 - bit PCM
* and no MIDI .
*/
2005-04-16 15:20:36 -07:00
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x003b ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " BOSS " ,
. product_name = " GS-10 " ,
2005-04-06 09:47:02 +02:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-06 09:47:02 +02:00
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
2005-04-16 15:20:36 -07:00
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0041 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0040 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " GI-20 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0043 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0042 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " RS-70 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2007-12-19 14:25:24 +01:00
{
/* has ID 0x0049 when not in "Advanced Driver" mode */
USB_DEVICE ( 0x0582 , 0x0047 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "EDIROL", */
/* .product_name = "UR-80", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
/* in the 96 kHz modes, only interface 1 is there */
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
{
2005-09-21 16:33:49 +02:00
/* has ID 0x004a when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0048 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2007-12-19 14:25:24 +01:00
/* .vendor_name = "EDIROL", */
/* .product_name = "UR-80", */
2005-04-16 15:20:36 -07:00
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
2005-09-21 16:33:49 +02:00
/* TODO: add Edirol M-100FX support */
2007-02-09 20:52:55 +01:00
{
/* has ID 0x004e when not in "Advanced Driver" mode */
USB_DEVICE ( 0x0582 , 0x004c ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " PCR-A " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
{
2005-09-21 16:33:49 +02:00
/* has ID 0x004f when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x004d ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " PCR-A " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
{
/*
* This quirk is for the " Advanced Driver " mode . If off , the UA - 3F X
* is standard compliant , but has only 16 - bit PCM .
*/
USB_DEVICE ( 0x0582 , 0x0050 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UA-3FX " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x0052 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UM-1SX " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
2007-07-09 10:39:44 +02:00
{
USB_DEVICE ( 0x0582 , 0x0060 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " EXR Series " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
2010-08-30 16:32:43 +02:00
{
/* has ID 0x0066 when not in "Advanced Driver" mode */
USB_DEVICE ( 0x0582 , 0x0064 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "EDIROL", */
/* .product_name = "PCR-1", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0067 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0065 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2010-08-30 16:32:43 +02:00
/* .vendor_name = "EDIROL", */
/* .product_name = "PCR-1", */
2005-04-16 15:20:36 -07:00
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0003
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x006b when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x006a ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " SP-606 " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x006e when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x006d ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Roland " ,
. product_name = " FANTOM-X " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{ /*
* This quirk is for the " Advanced " modes of the Edirol UA - 25.
* If the switch is not in an advanced setting , the UA - 25 has
* ID 0x0582 / 0x0073 and is standard compliant ( no quirks ) , but
* offers only 16 - bit PCM at 44.1 kHz and no MIDI .
*/
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x0074 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " EDIROL " ,
. product_name = " UA-25 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 0 ,
2008-10-04 16:27:36 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 1 ,
2008-10-04 16:27:36 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 2 ,
2008-10-07 20:54:18 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = - 1
}
}
}
} ,
{
2005-09-21 16:33:49 +02:00
/* has ID 0x0076 when not in "Advanced Driver" mode */
2005-04-16 15:20:36 -07:00
USB_DEVICE ( 0x0582 , 0x0075 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " BOSS " ,
. product_name = " DR-880 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2005-09-19 12:24:00 +02:00
{
2005-09-21 16:33:49 +02:00
/* has ID 0x007b when not in "Advanced Driver" mode */
2005-09-19 12:24:00 +02:00
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x007a ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-09-19 12:24:00 +02:00
. vendor_name = " Roland " ,
2005-09-21 16:33:49 +02:00
/* "RD" or "RD-700SX"? */
2005-09-19 12:24:00 +02:00
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-09-19 12:24:00 +02:00
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
}
} ,
2006-01-18 08:53:32 +01:00
{
/* has ID 0x0081 when not in "Advanced Driver" mode */
USB_DEVICE ( 0x0582 , 0x0080 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " G-70 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2006-01-18 15:44:53 +01:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
2006-01-18 08:53:32 +01:00
}
}
} ,
2006-01-10 18:56:23 +01:00
/* TODO: add Roland V-SYNTH XT support */
/* TODO: add BOSS GT-PRO support */
2006-01-16 08:03:52 +01:00
{
/* has ID 0x008c when not in "Advanced Driver" mode */
USB_DEVICE ( 0x0582 , 0x008b ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " PC-50 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2006-01-10 18:56:23 +01:00
/* TODO: add Edirol PC-80 support */
2007-08-10 15:07:06 +02:00
{
USB_DEVICE ( 0x0582 , 0x0096 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " UA-1EX " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2006-01-10 18:56:23 +01:00
{
USB_DEVICE ( 0x0582 , 0x009a ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " UM-3EX " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x000f ,
. in_cables = 0x000f
}
}
2008-10-04 16:27:36 +02:00
} ,
{
/*
* This quirk is for the " Advanced Driver " mode . If off , the UA - 4F X
* is standard compliant , but has only 16 - bit PCM and no MIDI .
*/
USB_DEVICE ( 0x0582 , 0x00a3 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " UA-4FX " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_EDIROL_UAXX
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_EDIROL_UAXX
} ,
{
. ifnum = 2 ,
2008-10-07 20:54:18 +02:00
. type = QUIRK_AUDIO_EDIROL_UAXX
2008-10-04 16:27:36 +02:00
} ,
{
. ifnum = - 1
}
}
}
2006-01-10 18:56:23 +01:00
} ,
/* TODO: add Edirol MD-P1 support */
2008-02-25 11:04:19 +01:00
{
USB_DEVICE ( 0x582 , 0x00a6 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " Juno-G " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2007-07-03 08:04:25 +02:00
{
/* Roland SH-201 */
USB_DEVICE ( 0x0582 , 0x00ad ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " SH-201 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-10-21 10:29:17 +01:00
{
/* Advanced mode of the Roland VG-99, with MIDI and 24-bit PCM at 44.1
* kHz . In standard mode , the device has ID 05 82 : 00 b3 , and offers
* 16 - bit PCM at 44.1 kHz with no MIDI .
*/
USB_DEVICE ( 0x0582 , 0x00b2 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " VG-99 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2008-05-19 16:21:33 +02:00
{
/* Roland SonicCell */
USB_DEVICE ( 0x0582 , 0x00c2 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " SonicCell " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
2009-06-01 10:59:51 +02:00
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
{
/* Edirol M-16DX */
/* FIXME: This quirk gives a good-working capture stream but the
* playback seems problematic because of lacking of sync
* with capture stream . It needs to sync with the capture
* clock . As now , you ' ll get frequent sound distortions
* via the playback .
*/
USB_DEVICE ( 0x0582 , 0x00c4 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
2008-05-19 16:21:33 +02:00
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2008-07-28 10:19:39 +02:00
{
/* BOSS GT-10 */
USB_DEVICE ( 0x0582 , 0x00da ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2008-10-20 16:07:45 +02:00
{
/* Advanced modes of the Edirol UA-25EX.
* For the standard mode , UA - 25 EX has ID 05 82 : 00e7 , which
* offers only 16 - bit PCM at 44.1 kHz and no MIDI .
*/
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x00e6 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " EDIROL " ,
. product_name = " UA-25EX " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_EDIROL_UAXX
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_EDIROL_UAXX
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_EDIROL_UAXX
} ,
{
. ifnum = - 1
}
}
}
} ,
2009-11-19 14:34:33 +01:00
{
/* has ID 0x00ea when not in Advanced Driver mode */
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x00e9 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Roland", */
/* .product_name = "UA-1G", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2011-02-17 14:26:51 +01:00
{
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x0104 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Roland", */
/* .product_name = "UM-1G", */
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2012-02-04 20:51:43 +01:00
{
/* Edirol UM-3G */
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x0108 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = 0 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
2011-03-21 20:15:08 +00:00
{
/* Boss JS-8 Jam Station */
USB_DEVICE ( 0x0582 , 0x0109 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "BOSS", */
/* .product_name = "JS-8", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2010-08-30 16:42:17 +02:00
{
/* has ID 0x0110 when not in Advanced Driver mode */
USB_DEVICE_VENDOR_SPEC ( 0x0582 , 0x010f ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Roland", */
/* .product_name = "A-PRO", */
2013-01-31 21:14:33 +01:00
. ifnum = 0 ,
2010-08-30 16:42:17 +02:00
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
2011-11-28 19:41:27 -05:00
{
/* Roland GAIA SH-01 */
USB_DEVICE ( 0x0582 , 0x0111 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Roland " ,
. product_name = " GAIA " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2010-08-30 16:45:38 +02:00
{
USB_DEVICE ( 0x0582 , 0x0113 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "BOSS", */
/* .product_name = "ME-25", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2011-05-18 11:28:43 +02:00
{
USB_DEVICE ( 0x0582 , 0x0127 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Roland", */
/* .product_name = "GR-55", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2011-09-16 08:31:45 +02:00
{
/* Added support for Roland UM-ONE which differs from UM-1 */
USB_DEVICE ( 0x0582 , 0x012a ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "ROLAND", */
/* .product_name = "UM-ONE", */
. ifnum = 0 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0003
}
}
} ,
2011-07-21 19:00:57 +02:00
{
USB_DEVICE ( 0x0582 , 0x011e ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "BOSS", */
/* .product_name = "BR-800", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2011-08-09 23:39:13 -05:00
{
USB_DEVICE ( 0x0582 , 0x0130 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "BOSS", */
/* .product_name = "MICRO BR-80", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
2012-06-23 17:30:47 +02:00
. ifnum = 3 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE ( 0x0582 , 0x014d ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "BOSS", */
/* .product_name = "GT-100", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
2011-08-09 23:39:13 -05:00
. ifnum = 3 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2008-05-19 16:21:33 +02:00
2005-10-05 13:23:19 +02:00
/* Guillemot devices */
{
/*
* This is for the " Windows Edition " where the external MIDI ports are
* the only MIDI ports ; the control data is reported through HID
* interfaces . The " Macintosh Edition " has ID 0xd002 and uses standard
* compliant USB MIDI ports for external MIDI and controls .
*/
USB_DEVICE_VENDOR_SPEC ( 0x06f8 , 0xb000 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-10-05 13:23:19 +02:00
. vendor_name = " Hercules " ,
. product_name = " DJ Console (WE) " ,
. ifnum = 4 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-10-05 13:23:19 +02:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
2005-04-16 15:20:36 -07:00
/* Midiman/M-Audio devices */
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1002 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 2x2 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1011 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 1x1 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1015 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " Keystation " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1021 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 4x4 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x000f ,
. in_cables = 0x000f
}
}
} ,
{
/*
* For hardware revision 1.05 ; in the later revisions ( 1.10 and
* 1.21 ) , 0x1031 is the ID for the device without firmware .
* Thanks to Olaf Giesbrecht < Olaf_Giesbrecht @ yahoo . de >
*/
USB_DEVICE_VER ( 0x0763 , 0x1031 , 0x0100 , 0x0109 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 8x8 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x01ff ,
. in_cables = 0x01ff
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1033 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 8x8 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x01ff ,
. in_cables = 0x01ff
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x1041 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " MidiSport 2x4 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x000f ,
. in_cables = 0x0003
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2001 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " Quattro " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
/*
* Interfaces 0 - 2 are " Windows-compatible " , 16 - bit only ,
* and share endpoints with the other interfaces .
* Ignore them . The other interfaces can do 24 bits ,
* but captured samples are big - endian ( see usbaudio . c ) .
*/
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 4 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 5 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 6 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 7 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 8 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 9 ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2003 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " AudioPhile " ,
. ifnum = 6 ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2008 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " Ozone " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x200d ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " M-Audio " ,
. product_name = " OmniStudio " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 4 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 5 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 6 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 7 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 8 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 9 ,
. type = QUIRK_MIDI_MIDIMAN ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2007-09-17 09:33:17 +02:00
{
USB_DEVICE ( 0x0763 , 0x2019 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "M-Audio", */
/* .product_name = "Ozone Academic", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 3 ,
. type = QUIRK_MIDI_MIDIMAN ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0001 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-11-28 23:55:38 +01:00
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2030 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "M-Audio", */
/* .product_name = "Fast Track C400", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_MIXER ,
} ,
/* Playback */
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 6 ,
. iface = 2 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = 0x09 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
} ,
2013-01-13 23:02:02 +01:00
. clock = 0x80 ,
2012-11-28 23:55:38 +01:00
}
} ,
/* Capture */
{
. ifnum = 3 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 4 ,
. iface = 3 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x81 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
} ,
2013-01-13 23:02:02 +01:00
. clock = 0x80 ,
2012-11-28 23:55:38 +01:00
}
} ,
/* MIDI */
{
. ifnum = - 1 /* Interface = 4 */
}
}
}
} ,
2013-02-09 12:56:35 -05:00
{
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2031 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "M-Audio", */
/* .product_name = "Fast Track C600", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_MIXER ,
} ,
/* Playback */
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 8 ,
. iface = 2 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = 0x09 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
} ,
. clock = 0x80 ,
}
} ,
/* Capture */
{
. ifnum = 3 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 6 ,
. iface = 3 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x81 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
} ,
. clock = 0x80 ,
}
} ,
/* MIDI */
{
. ifnum = - 1 /* Interface = 4 */
}
}
}
} ,
2010-03-25 11:29:14 +01:00
{
2011-05-18 11:28:45 +02:00
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2080 ) ,
2010-03-25 11:29:14 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "M-Audio", */
2010-09-02 12:58:25 +02:00
/* .product_name = "Fast Track Ultra", */
2010-03-25 11:29:14 +01:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
2011-05-25 09:09:03 +02:00
. type = QUIRK_AUDIO_STANDARD_MIXER ,
2010-03-25 11:29:14 +01:00
} ,
{
. ifnum = 1 ,
2010-09-02 12:58:25 +02:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 8 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = 0x09 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
}
}
2010-03-25 11:29:14 +01:00
} ,
{
. ifnum = 2 ,
2010-09-02 12:58:25 +02:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 8 ,
. iface = 2 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x81 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
}
}
2010-03-25 11:29:14 +01:00
} ,
/* interface 3 (MIDI) is standard compliant */
{
. ifnum = - 1
}
}
}
} ,
{
2011-05-18 11:28:45 +02:00
USB_DEVICE_VENDOR_SPEC ( 0x0763 , 0x2081 ) ,
2010-03-25 11:29:14 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "M-Audio", */
/* .product_name = "Fast Track Ultra 8R", */
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
2011-05-25 09:09:03 +02:00
. type = QUIRK_AUDIO_STANDARD_MIXER ,
2010-03-25 11:29:14 +01:00
} ,
{
. ifnum = 1 ,
2010-09-02 12:58:25 +02:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 8 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = 0x09 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
}
}
2010-03-25 11:29:14 +01:00
} ,
{
. ifnum = 2 ,
2010-09-02 12:58:25 +02:00
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 8 ,
. iface = 2 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x81 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
}
}
2010-03-25 11:29:14 +01:00
} ,
/* interface 3 (MIDI) is standard compliant */
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
2006-03-09 07:55:55 +01:00
/* Casio devices */
2006-03-16 08:15:25 +01:00
{
USB_DEVICE ( 0x07cf , 0x6801 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Casio " ,
. product_name = " PL-40R " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_YAMAHA
}
} ,
2006-03-09 07:55:55 +01:00
{
2006-03-09 08:17:08 +01:00
/* this ID is used by several devices without a product ID */
2006-03-09 07:55:55 +01:00
USB_DEVICE ( 0x07cf , 0x6802 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Casio " ,
2006-03-09 08:17:08 +01:00
. product_name = " Keyboard " ,
2006-03-09 07:55:55 +01:00
. ifnum = 0 ,
. type = QUIRK_MIDI_YAMAHA
}
} ,
2005-04-16 15:20:36 -07:00
/* Mark of the Unicorn devices */
{
/* thanks to Robert A. Lerche <ral 'at' msbit.com> */
2005-07-04 09:21:45 +02:00
. match_flags = USB_DEVICE_ID_MATCH_VENDOR |
USB_DEVICE_ID_MATCH_PRODUCT |
USB_DEVICE_ID_MATCH_DEV_SUBCLASS ,
. idVendor = 0x07fd ,
. idProduct = 0x0001 ,
. bDeviceSubClass = 2 ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " MOTU " ,
. product_name = " Fastlane " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
2005-04-16 15:20:36 -07:00
{
. ifnum = 0 ,
2010-10-22 18:20:48 +02:00
. type = QUIRK_MIDI_RAW_BYTES
2005-04-16 15:20:36 -07:00
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
/* Emagic devices */
{
USB_DEVICE ( 0x086a , 0x0001 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Emagic " ,
/* .product_name = "Unitor8", */
. ifnum = 2 ,
. type = QUIRK_MIDI_EMAGIC ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x80ff ,
. in_cables = 0x80ff
}
}
} ,
{
USB_DEVICE ( 0x086a , 0x0002 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Emagic " ,
/* .product_name = "AMT8", */
. ifnum = 2 ,
. type = QUIRK_MIDI_EMAGIC ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x80ff ,
. in_cables = 0x80ff
}
}
} ,
{
USB_DEVICE ( 0x086a , 0x0003 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Emagic " ,
/* .product_name = "MT4", */
. ifnum = 2 ,
. type = QUIRK_MIDI_EMAGIC ,
2005-11-17 15:08:02 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
2005-04-16 15:20:36 -07:00
. out_cables = 0x800f ,
. in_cables = 0x8003
}
}
} ,
2011-05-18 11:28:42 +02:00
/* KORG devices */
{
USB_DEVICE_VENDOR_SPEC ( 0x0944 , 0x0200 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " KORG, Inc. " ,
/* .product_name = "PANDORA PX5D", */
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE ,
2011-12-05 20:27:46 +01:00
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0944 , 0x0201 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " KORG, Inc. " ,
/* .product_name = "ToneLab ST", */
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE ,
2011-05-18 11:28:42 +02:00
}
} ,
2010-05-20 20:31:10 +01:00
/* AKAI devices */
{
USB_DEVICE ( 0x09e8 , 0x0062 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " AKAI " ,
. product_name = " MPD16 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_AKAI ,
}
} ,
2005-09-26 08:55:01 +02:00
/* TerraTec devices */
{
USB_DEVICE_VENDOR_SPEC ( 0x0ccd , 0x0012 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-09-26 08:55:01 +02:00
. vendor_name = " TerraTec " ,
. product_name = " PHASE 26 " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
2005-04-16 15:20:36 -07:00
{
USB_DEVICE_VENDOR_SPEC ( 0x0ccd , 0x0013 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2006-04-13 10:16:08 +02:00
. vendor_name = " TerraTec " ,
. product_name = " PHASE 26 " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x0ccd , 0x0014 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-09-26 08:55:01 +02:00
. vendor_name = " TerraTec " ,
2005-04-16 15:20:36 -07:00
. product_name = " PHASE 26 " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
2009-06-01 10:48:54 +02:00
{
2009-06-02 19:21:17 +02:00
USB_DEVICE ( 0x0ccd , 0x0028 ) ,
2009-06-01 10:48:54 +02:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " TerraTec " ,
2009-06-14 12:16:17 +02:00
. product_name = " Aureon5.1MkII " ,
2009-06-01 10:48:54 +02:00
. ifnum = QUIRK_NO_INTERFACE
}
} ,
2006-02-08 12:38:23 +01:00
{
USB_DEVICE ( 0x0ccd , 0x0035 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Miditech " ,
. product_name = " Play'n Roll " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_CME
}
} ,
2005-04-16 15:20:36 -07:00
2007-08-10 08:01:54 +02:00
/* Stanton/N2IT Final Scratch v1 device ('Scratchamp') */
{
USB_DEVICE ( 0x103d , 0x0100 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Stanton " ,
. product_name = " ScratchAmp " ,
. ifnum = QUIRK_NO_INTERFACE
}
} ,
{
USB_DEVICE ( 0x103d , 0x0101 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Stanton " ,
. product_name = " ScratchAmp " ,
. ifnum = QUIRK_NO_INTERFACE
}
} ,
2005-04-16 15:20:36 -07:00
/* Novation EMS devices */
{
USB_DEVICE_VENDOR_SPEC ( 0x1235 , 0x0001 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Novation " ,
. product_name = " ReMOTE Audio/XStation " ,
. ifnum = 4 ,
. type = QUIRK_MIDI_NOVATION
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x1235 , 0x0002 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Novation " ,
. product_name = " Speedio " ,
. ifnum = 3 ,
. type = QUIRK_MIDI_NOVATION
}
} ,
2010-10-22 18:20:48 +02:00
{
USB_DEVICE ( 0x1235 , 0x000e ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
/* .vendor_name = "Novation", */
/* .product_name = "Launchpad", */
. ifnum = 0 ,
. type = QUIRK_MIDI_RAW_BYTES
}
} ,
2013-03-17 11:07:53 +00:00
{
USB_DEVICE ( 0x1235 , 0x0018 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Novation " ,
. product_name = " Twitch " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 4 ,
. iface = 0 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = USB_ENDPOINT_XFER_ISOC ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 ,
. rate_min = 44100 ,
. rate_max = 48000 ,
. nr_rates = 2 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000
}
}
} ,
{
. ifnum = 1 ,
. type = QUIRK_MIDI_RAW_BYTES
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
{
USB_DEVICE_VENDOR_SPEC ( 0x1235 , 0x4661 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. vendor_name = " Novation " ,
. product_name = " ReMOTE25 " ,
. ifnum = 0 ,
. type = QUIRK_MIDI_NOVATION
}
} ,
2010-02-16 08:55:08 +01:00
/* Access Music devices */
{
/* VirusTI Desktop */
USB_DEVICE_VENDOR_SPEC ( 0x133e , 0x0815 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 3 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0003 ,
. in_cables = 0x0003
}
} ,
{
. ifnum = 4 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2007-09-03 08:20:09 +02:00
/* */
2007-08-29 17:38:14 +02:00
{
2007-09-03 08:20:09 +02:00
/* aka. Serato Scratch Live DJ Box */
2007-08-29 17:38:14 +02:00
USB_DEVICE ( 0x13e5 , 0x0001 ) ,
2007-09-03 08:20:09 +02:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Rane " ,
. product_name = " SL-1 " ,
. ifnum = QUIRK_NO_INTERFACE
2007-08-29 17:38:14 +02:00
}
} ,
2011-02-11 11:08:06 +00:00
/* Native Instruments MK2 series */
2011-04-11 17:56:32 +02:00
{
2011-05-18 11:28:41 +02:00
/* Komplete Audio 6 */
2011-04-11 17:56:32 +02:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x17cc ,
. idProduct = 0x1000 ,
} ,
2011-02-11 11:08:06 +00:00
{
/* Traktor Audio 6 */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x17cc ,
. idProduct = 0x1010 ,
} ,
{
/* Traktor Audio 10 */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x17cc ,
. idProduct = 0x1020 ,
} ,
2011-08-04 12:25:56 -07:00
/* KeithMcMillen Stringport */
{
USB_DEVICE ( 0x1f38 , 0x0001 ) ,
. bInterfaceClass = USB_CLASS_AUDIO ,
} ,
2006-02-07 17:11:06 +01:00
/* Miditech devices */
2005-07-25 16:17:29 +02:00
{
USB_DEVICE ( 0x4752 , 0x0011 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-07-25 16:17:29 +02:00
. vendor_name = " Miditech " ,
. product_name = " Midistart-2 " ,
. ifnum = 0 ,
2006-02-07 17:11:06 +01:00
. type = QUIRK_MIDI_CME
2005-07-25 16:17:29 +02:00
}
} ,
2006-02-07 17:11:06 +01:00
/* Central Music devices */
2005-07-25 16:17:29 +02:00
{
2006-02-07 17:11:06 +01:00
/* this ID used by both Miditech MidiStudio-2 and CME UF-x */
2005-07-25 16:17:29 +02:00
USB_DEVICE ( 0x7104 , 0x2202 ) ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-07-25 16:17:29 +02:00
. ifnum = 0 ,
2006-02-07 17:11:06 +01:00
. type = QUIRK_MIDI_CME
2005-07-25 16:17:29 +02:00
}
} ,
2009-12-27 12:19:59 -05:00
/* Hauppauge HVR-950Q and HVR-850 */
{
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x7200 ) ,
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x7240 ) ,
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-850 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x7210 ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x7217 ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x721b ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x721e ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x721f ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x2040 , 0x7280 ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
. product_name = " HVR-950Q " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
{
2010-08-01 09:53:37 -04:00
USB_DEVICE_VENDOR_SPEC ( 0x0fd9 , 0x0008 ) ,
2009-12-27 12:19:59 -05:00
. match_flags = USB_DEVICE_ID_MATCH_DEVICE |
USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL ,
2009-12-27 12:19:59 -05:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Hauppauge " ,
2010-08-01 09:53:37 -04:00
. product_name = " HVR-950Q " ,
2009-12-27 12:19:59 -05:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_AUDIO_ALIGN_TRANSFER ,
}
} ,
2010-02-17 12:12:52 -06:00
/* Digidesign Mbox */
{
/* Thanks to Clemens Ladisch <clemens@ladisch.de> */
USB_DEVICE ( 0x0dba , 0x1000 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Digidesign " ,
. product_name = " MBox " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE ,
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
2010-03-04 19:46:16 +01:00
. formats = SNDRV_PCM_FMTBIT_S24_3BE ,
2010-02-17 12:12:52 -06:00
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
2010-02-22 23:49:13 +01:00
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
2010-02-17 12:12:52 -06:00
. endpoint = 0x02 ,
. ep_attr = 0x01 ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 ,
. rate_min = 44100 ,
. rate_max = 48000 ,
. nr_rates = 2 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000
}
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-12-19 11:27:22 +01:00
/* DIGIDESIGN MBOX 2 */
{
USB_DEVICE ( 0x0dba , 0x3000 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Digidesign " ,
. product_name = " Mbox 2 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3BE ,
. channels = 2 ,
. iface = 2 ,
. altsetting = 2 ,
. altset_idx = 1 ,
. attributes = 0x00 ,
. endpoint = 0x03 ,
. ep_attr = USB_ENDPOINT_SYNC_ASYNC ,
. rates = SNDRV_PCM_RATE_48000 ,
. rate_min = 48000 ,
. rate_max = 48000 ,
. nr_rates = 1 ,
. rate_table = ( unsigned int [ ] ) {
48000
}
}
} ,
{
. ifnum = 3 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 4 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3BE ,
. channels = 2 ,
. iface = 4 ,
. altsetting = 2 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x85 ,
. ep_attr = USB_ENDPOINT_SYNC_SYNC ,
. rates = SNDRV_PCM_RATE_48000 ,
. rate_min = 48000 ,
. rate_max = 48000 ,
. nr_rates = 1 ,
. rate_table = ( unsigned int [ ] ) {
48000
}
}
} ,
{
. ifnum = 5 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 6 ,
2013-01-04 09:51:44 +01:00
. type = QUIRK_MIDI_MIDIMAN ,
2012-12-19 11:27:22 +01:00
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_ep = 0x02 ,
. out_cables = 0x0001 ,
. in_ep = 0x81 ,
. in_interval = 0x01 ,
. in_cables = 0x0001
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-09-24 14:25:04 +02:00
{
/* Tascam US122 MKII - playback-only support */
. match_flags = USB_DEVICE_ID_MATCH_DEVICE ,
. idVendor = 0x0644 ,
. idProduct = 0x8021 ,
. bInterfaceClass = USB_CLASS_AUDIO ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " TASCAM " ,
. product_name = " US122 MKII " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 2 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x02 ,
. ep_attr = USB_ENDPOINT_XFER_ISOC ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 |
SNDRV_PCM_RATE_88200 |
SNDRV_PCM_RATE_96000 ,
. rate_min = 44100 ,
. rate_max = 96000 ,
. nr_rates = 4 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000 , 88200 , 96000
}
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2010-02-17 12:12:52 -06:00
2012-09-03 10:12:40 +02:00
/* Microsoft XboxLive Headset/Xbox Communicator */
{
USB_DEVICE ( 0x045e , 0x0283 ) ,
. bInterfaceClass = USB_CLASS_PER_INTERFACE ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Microsoft " ,
. product_name = " XboxLive Headset/Xbox Communicator " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
/* playback */
. ifnum = 0 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S16_LE ,
. channels = 1 ,
. iface = 0 ,
. altsetting = 0 ,
. altset_idx = 0 ,
. attributes = 0 ,
. endpoint = 0x04 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 22050 ,
. rate_max = 22050
}
} ,
{
/* capture */
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S16_LE ,
. channels = 1 ,
. iface = 1 ,
. altsetting = 0 ,
. altset_idx = 0 ,
. attributes = 0 ,
. endpoint = 0x85 ,
. ep_attr = 0x05 ,
. rates = SNDRV_PCM_RATE_CONTINUOUS ,
. rate_min = 16000 ,
. rate_max = 16000
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-10-21 18:29:12 +02:00
/* Reloop Play */
{
USB_DEVICE ( 0x200c , 0x100b ) ,
. bInterfaceClass = USB_CLASS_PER_INTERFACE ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
. ifnum = 0 ,
. type = QUIRK_AUDIO_STANDARD_MIXER ,
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_FIXED_ENDPOINT ,
. data = & ( const struct audioformat ) {
. formats = SNDRV_PCM_FMTBIT_S24_3LE ,
. channels = 4 ,
. iface = 1 ,
. altsetting = 1 ,
. altset_idx = 1 ,
. attributes = UAC_EP_CS_ATTR_SAMPLE_RATE ,
. endpoint = 0x01 ,
. ep_attr = USB_ENDPOINT_SYNC_ADAPTIVE ,
. rates = SNDRV_PCM_RATE_44100 |
SNDRV_PCM_RATE_48000 ,
. rate_min = 44100 ,
. rate_max = 48000 ,
. nr_rates = 2 ,
. rate_table = ( unsigned int [ ] ) {
44100 , 48000
}
}
} ,
{
. ifnum = - 1
}
}
}
} ,
2012-11-13 19:38:03 +11:00
{
/*
* Focusrite Scarlett 18 i6
*
* Avoid mixer creation , which otherwise fails because some of
* the interface descriptor subtypes for interface 0 are
* unknown . That should be fixed or worked - around but this at
* least allows the device to be used successfully with a DAW
* and an external mixer . See comments below about other
* ignored interfaces .
*/
USB_DEVICE ( 0x1235 , 0x8004 ) ,
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
. vendor_name = " Focusrite " ,
. product_name = " Scarlett 18i6 " ,
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_COMPOSITE ,
. data = & ( const struct snd_usb_audio_quirk [ ] ) {
{
/* InterfaceSubClass 1 (Control Device) */
. ifnum = 0 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 1 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
. ifnum = 2 ,
. type = QUIRK_AUDIO_STANDARD_INTERFACE
} ,
{
/* InterfaceSubClass 1 (Control Device) */
. ifnum = 3 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = 4 ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
} ,
{
/* InterfaceSubClass 1 (Device Firmware Update) */
. ifnum = 5 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. ifnum = - 1
}
}
}
} ,
2005-04-16 15:20:36 -07:00
{
/*
* Some USB MIDI devices don ' t have an audio control interface ,
* so we have to grab MIDI streaming interfaces here .
*/
. match_flags = USB_DEVICE_ID_MATCH_INT_CLASS |
USB_DEVICE_ID_MATCH_INT_SUBCLASS ,
. bInterfaceClass = USB_CLASS_AUDIO ,
2010-02-22 23:49:13 +01:00
. bInterfaceSubClass = USB_SUBCLASS_MIDISTREAMING ,
2005-11-17 15:08:02 +01:00
. driver_info = ( unsigned long ) & ( const struct snd_usb_audio_quirk ) {
2005-04-16 15:20:36 -07:00
. ifnum = QUIRK_ANY_INTERFACE ,
. type = QUIRK_MIDI_STANDARD_INTERFACE
}
} ,
# undef USB_DEVICE_VENDOR_SPEC