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
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 ,
} ,
2008-02-25 11:04:19 +01:00
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 ) ,
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 ,
. 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
}
}
} ,
{
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
}
}
}
} ,
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
}
}
}
} ,
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", */
. ifnum = 1 ,
. type = QUIRK_MIDI_FIXED_ENDPOINT ,
. data = & ( const struct snd_usb_midi_endpoint_info ) {
. out_cables = 0x0003 ,
. in_cables = 0x0007
}
}
} ,
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
}
}
}
} ,
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
}
}
}
} ,
2010-03-25 11:29:14 +01:00
{
USB_DEVICE ( 0x0763 , 0x2080 ) ,
. 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 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. 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
}
}
}
} ,
{
USB_DEVICE ( 0x0763 , 0x2081 ) ,
. 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 ,
. type = QUIRK_IGNORE_INTERFACE
} ,
{
. 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
}
}
} ,
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
}
} ,
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
}
} ,
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 ,
. maxpacksize = 0x130 ,
. 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
}
}
}
} ,
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