⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 usbquirks.h

📁 linux 内核源代码
💻 H
📖 第 1 页 / 共 4 页
字号:
/* * 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/* * Logitech QuickCam: bDeviceClass is vendor-specific, so generic interface * class matches do not take effect without an explicit ID match. */{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},{	.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,	.bInterfaceSubClass = USB_SUBCLASS_AUDIO_CONTROL},/* E-Mu devices */{	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,	.idVendor = 0x041e,	.idProduct = 0x3f02,	.bInterfaceClass = USB_CLASS_AUDIO,},{	.match_flags = USB_DEVICE_ID_MATCH_DEVICE,	.idVendor = 0x041e,	.idProduct = 0x3f04,	.bInterfaceClass = USB_CLASS_AUDIO,},/* * Yamaha devices */#define YAMAHA_DEVICE(id, name) { \	USB_DEVICE(0x0499, id), \	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \		.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), \	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) { \		.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"),YAMAHA_DEVICE(0x1016, "MDP-5"),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"),YAMAHA_DEVICE(0x101f, "EZ-J24"),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),YAMAHA_DEVICE(0x103d, NULL),YAMAHA_DEVICE(0x103e, NULL),YAMAHA_DEVICE(0x103f, NULL),YAMAHA_DEVICE(0x1040, NULL),YAMAHA_DEVICE(0x1041, NULL),YAMAHA_DEVICE(0x1042, NULL),YAMAHA_DEVICE(0x1043, NULL),YAMAHA_DEVICE(0x1044, NULL),YAMAHA_DEVICE(0x1045, NULL),YAMAHA_DEVICE(0x2000, "DGP-7"),YAMAHA_DEVICE(0x2001, "DGP-5"),YAMAHA_DEVICE(0x2002, NULL),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),YAMAHA_DEVICE(0x500f, NULL),YAMAHA_DEVICE(0x7000, "DTX"),YAMAHA_DEVICE(0x7010, "UB99"),#undef YAMAHA_DEVICE#undef YAMAHA_INTERFACE/* * Roland/RolandED/Edirol/BOSS devices */{	USB_DEVICE(0x0582, 0x0000),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "Roland",		.product_name = "UA-100",		.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) {					.format = SNDRV_PCM_FORMAT_S16_LE,					.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) {					.format = SNDRV_PCM_FORMAT_S16_LE,					.channels = 2,					.iface = 1,					.altsetting = 1,					.altset_idx = 1,					.attributes = EP_CS_ATTR_FILL_MAX,					.endpoint = 0x81,					.ep_attr = 0x05,					.rates = SNDRV_PCM_RATE_CONTINUOUS,					.rate_min = 44100,					.rate_max = 44100,				}			},			{				.ifnum = 2,				.type = QUIRK_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x0007,					.in_cables  = 0x0007				}			},			{				.ifnum = -1			}		}	}},{	USB_DEVICE(0x0582, 0x0002),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "EDIROL",		.product_name = "UM-4",		.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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x000f,					.in_cables  = 0x000f				}			},			{				.ifnum = -1			}		}	}},{	USB_DEVICE(0x0582, 0x0003),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "Roland",		.product_name = "SC-8850",		.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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x003f,					.in_cables  = 0x003f				}			},			{				.ifnum = -1			}		}	}},{	USB_DEVICE(0x0582, 0x0004),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "Roland",		.product_name = "U-8",		.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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x0005,					.in_cables  = 0x0005				}			},			{				.ifnum = -1			}		}	}},{	/* Has ID 0x0099 when not in "Advanced Driver" mode.	 * The UM-2EX has only one input, but we cannot detect this. */	USB_DEVICE(0x0582, 0x0005),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "EDIROL",		.product_name = "UM-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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x0003,					.in_cables  = 0x0003				}			},			{				.ifnum = -1			}		}	}},{	USB_DEVICE(0x0582, 0x0007),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "Roland",		.product_name = "SC-8820",		.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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x0013,					.in_cables  = 0x0013				}			},			{				.ifnum = -1			}		}	}},{	USB_DEVICE(0x0582, 0x0008),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "Roland",		.product_name = "PC-300",		.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_MIDI_FIXED_ENDPOINT,				.data = & (const struct snd_usb_midi_endpoint_info) {					.out_cables = 0x0001,					.in_cables  = 0x0001				}			},			{				.ifnum = -1			}		}	}},{	/* has ID 0x009d when not in "Advanced Driver" mode */	USB_DEVICE(0x0582, 0x0009),	.driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {		.vendor_name = "EDIROL",		.product_name = "UM-1",

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -