blob: 42c299cbf63aefbae36d2c42679d7ba9ebd0a930 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __USBAUDIO_H
2#define __USBAUDIO_H
3/*
4 * (Tentative) USB Audio Driver for ALSA
5 *
6 * Copyright (c) 2002 by Takashi Iwai <tiwai@suse.de>
7 *
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 */
23
Linus Torvalds1da177e2005-04-16 15:20:36 -070024/* maximum number of endpoints per interface */
25#define MIDI_MAX_ENDPOINTS 2
26
Clemens Ladisch27d10f52005-05-02 08:51:26 +020027/* handling of USB vendor/product ID pairs as 32-bit numbers */
28#define USB_ID(vendor, product) (((vendor) << 16) | (product))
29#define USB_ID_VENDOR(id) ((id) >> 16)
30#define USB_ID_PRODUCT(id) ((u16)(id))
31
Linus Torvalds1da177e2005-04-16 15:20:36 -070032/*
33 */
34
Linus Torvalds1da177e2005-04-16 15:20:36 -070035struct snd_usb_audio {
36 int index;
37 struct usb_device *dev;
Takashi Iwai86e07d32005-11-17 15:08:02 +010038 struct snd_card *card;
Clemens Ladisch27d10f52005-05-02 08:51:26 +020039 u32 usb_id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 int shutdown;
John S. Gruber98e89f62009-12-27 12:19:58 -050041 unsigned int txfr_quirk:1; /* Subframe boundaries on transfers */
Linus Torvalds1da177e2005-04-16 15:20:36 -070042 int num_interfaces;
Oliver Neukumf85bf292007-12-14 14:42:41 +010043 int num_suspended_intf;
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
Daniel Mack53ee98f2010-02-22 23:49:11 +010045 /* for audio class v2 */
46 int clock_id;
47
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 struct list_head pcm_list; /* list of pcm streams */
49 int pcm_devs;
50
51 struct list_head midi_list; /* list of midi interfaces */
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
Clemens Ladisch84957a82005-04-29 16:23:13 +020053 struct list_head mixer_list; /* list of mixer interfaces */
Linus Torvalds1da177e2005-04-16 15:20:36 -070054};
55
56/*
57 * Information about devices with broken descriptors
58 */
59
60/* special values for .ifnum */
61#define QUIRK_NO_INTERFACE -2
62#define QUIRK_ANY_INTERFACE -1
63
Clemens Ladisch854af952005-07-25 16:19:10 +020064enum quirk_type {
65 QUIRK_IGNORE_INTERFACE,
66 QUIRK_COMPOSITE,
67 QUIRK_MIDI_STANDARD_INTERFACE,
68 QUIRK_MIDI_FIXED_ENDPOINT,
69 QUIRK_MIDI_YAMAHA,
70 QUIRK_MIDI_MIDIMAN,
71 QUIRK_MIDI_NOVATION,
Clemens Ladisch55de5ef2009-05-27 10:49:30 +020072 QUIRK_MIDI_FASTLANE,
Clemens Ladisch854af952005-07-25 16:19:10 +020073 QUIRK_MIDI_EMAGIC,
Clemens Ladischcc7a59b2006-02-07 17:11:06 +010074 QUIRK_MIDI_CME,
Karsten Wiese030a07e2008-07-30 15:13:29 +020075 QUIRK_MIDI_US122L,
Clemens Ladisch854af952005-07-25 16:19:10 +020076 QUIRK_AUDIO_STANDARD_INTERFACE,
77 QUIRK_AUDIO_FIXED_ENDPOINT,
Pedro Lopez-Cabanillas310e0dc2008-10-04 16:27:36 +020078 QUIRK_AUDIO_EDIROL_UAXX,
John S. Gruber52a7a582009-12-27 12:19:59 -050079 QUIRK_AUDIO_ALIGN_TRANSFER,
Clemens Ladisch854af952005-07-25 16:19:10 +020080
81 QUIRK_TYPE_COUNT
82};
Linus Torvalds1da177e2005-04-16 15:20:36 -070083
Linus Torvalds1da177e2005-04-16 15:20:36 -070084struct snd_usb_audio_quirk {
85 const char *vendor_name;
86 const char *product_name;
87 int16_t ifnum;
Clemens Ladisch854af952005-07-25 16:19:10 +020088 uint16_t type;
Linus Torvalds1da177e2005-04-16 15:20:36 -070089 const void *data;
90};
91
92/* data for QUIRK_MIDI_FIXED_ENDPOINT */
93struct snd_usb_midi_endpoint_info {
94 int8_t out_ep; /* ep number, 0 autodetect */
95 uint8_t out_interval; /* interval for interrupt endpoints */
96 int8_t in_ep;
97 uint8_t in_interval;
98 uint16_t out_cables; /* bitmask */
99 uint16_t in_cables; /* bitmask */
100};
101
102/* for QUIRK_MIDI_YAMAHA, data is NULL */
103
104/* for QUIRK_MIDI_MIDIMAN, data points to a snd_usb_midi_endpoint_info
105 * structure (out_cables and in_cables only) */
106
107/* for QUIRK_COMPOSITE, data points to an array of snd_usb_audio_quirk
108 * structures, terminated with .ifnum = -1 */
109
110/* for QUIRK_AUDIO_FIXED_ENDPOINT, data points to an audioformat structure */
111
112/* for QUIRK_AUDIO/MIDI_STANDARD_INTERFACE, data is NULL */
113
Clemens Ladische584bc32010-03-01 16:20:37 +0100114/* for QUIRK_AUDIO_EDIROL_UAXX, data is NULL */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115
116/* for QUIRK_IGNORE_INTERFACE, data is NULL */
117
Clemens Ladisch6155aff2005-07-04 09:20:42 +0200118/* for QUIRK_MIDI_NOVATION and _RAW, data is NULL */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700119
120/* for QUIRK_MIDI_EMAGIC, data points to a snd_usb_midi_endpoint_info
121 * structure (out_cables and in_cables only) */
122
Clemens Ladischcc7a59b2006-02-07 17:11:06 +0100123/* for QUIRK_MIDI_CME, data is NULL */
Clemens Ladischf38275f2005-07-25 16:17:29 +0200124
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125/*
126 */
127
Sergiy Kovalchuk7d2b4512009-12-27 09:13:41 -0800128/*E-mu USB samplerate control quirk*/
129enum {
130 EMU_QUIRK_SR_44100HZ = 0,
131 EMU_QUIRK_SR_48000HZ,
132 EMU_QUIRK_SR_88200HZ,
133 EMU_QUIRK_SR_96000HZ,
134 EMU_QUIRK_SR_176400HZ,
135 EMU_QUIRK_SR_192000HZ
136};
137
Julian Anastasovf4950882009-11-06 23:44:53 +0200138#define combine_word(s) ((*(s)) | ((unsigned int)(s)[1] << 8))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139#define combine_triple(s) (combine_word(s) | ((unsigned int)(s)[2] << 16))
140#define combine_quad(s) (combine_triple(s) | ((unsigned int)(s)[3] << 24))
141
142unsigned int snd_usb_combine_bytes(unsigned char *bytes, int size);
143
144void *snd_usb_find_desc(void *descstart, int desclen, void *after, u8 dtype);
145void *snd_usb_find_csint_desc(void *descstart, int desclen, void *after, u8 dsubtype);
146
Takashi Iwai86e07d32005-11-17 15:08:02 +0100147int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe,
148 __u8 request, __u8 requesttype, __u16 value, __u16 index,
149 void *data, __u16 size, int timeout);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150
Takashi Iwai7a9b8062008-08-13 15:40:53 +0200151int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif,
152 int ignore_error);
Clemens Ladisch84957a82005-04-29 16:23:13 +0200153void snd_usb_mixer_disconnect(struct list_head *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700154
Clemens Ladischd82af9f2009-11-16 12:23:46 +0100155int snd_usbmidi_create(struct snd_card *card,
156 struct usb_interface *iface,
157 struct list_head *midi_list,
158 const struct snd_usb_audio_quirk *quirk);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159void snd_usbmidi_input_stop(struct list_head* p);
160void snd_usbmidi_input_start(struct list_head* p);
Clemens Ladischee733392005-04-25 10:34:13 +0200161void snd_usbmidi_disconnect(struct list_head *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700162
Sergiy Kovalchuk7d2b4512009-12-27 09:13:41 -0800163void snd_emuusb_set_samplerate(struct snd_usb_audio *chip,
164 unsigned char samplerate_id);
165
Linus Torvalds1da177e2005-04-16 15:20:36 -0700166/*
167 * retrieve usb_interface descriptor from the host interface
168 * (conditional for compatibility with the older API)
169 */
170#ifndef get_iface_desc
171#define get_iface_desc(iface) (&(iface)->desc)
172#define get_endpoint(alt,ep) (&(alt)->endpoint[ep].desc)
173#define get_ep_desc(ep) (&(ep)->desc)
174#define get_cfg_desc(cfg) (&(cfg)->desc)
175#endif
176
Linus Torvalds1da177e2005-04-16 15:20:36 -0700177#ifndef snd_usb_get_speed
178#define snd_usb_get_speed(dev) ((dev)->speed)
179#endif
180
181#endif /* __USBAUDIO_H */