1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright (c) 2017 Ruslan Bilovol <ruslan.bilovol@gmail.com>
4 *
5 * This file holds USB constants and structures defined
6 * by the USB DEVICE CLASS DEFINITION FOR AUDIO DEVICES Release 3.0.
7 */
8
9#ifndef __LINUX_USB_AUDIO_V3_H
10#define __LINUX_USB_AUDIO_V3_H
11
12#include <linux/types.h>
13
14/*
15 * v1.0, v2.0 and v3.0 of this standard have many things in common. For the rest
16 * of the definitions, please refer to audio.h and audio-v2.h
17 */
18
19/* All High Capability descriptors have these 2 fields at the beginning */
20struct uac3_hc_descriptor_header {
21	__le16 wLength;
22	__u8 bDescriptorType;
23	__u8 bDescriptorSubtype;
24	__le16 wDescriptorID;
25} __attribute__ ((packed));
26
27/* 4.3.1 CLUSTER DESCRIPTOR HEADER */
28struct uac3_cluster_header_descriptor {
29	__le16 wLength;
30	__u8 bDescriptorType;
31	__u8 bDescriptorSubtype;
32	__le16 wDescriptorID;
33	__u8 bNrChannels;
34} __attribute__ ((packed));
35
36/* 4.3.2.1 SEGMENTS */
37struct uac3_cluster_segment_descriptor {
38	__le16 wLength;
39	__u8 bSegmentType;
40	/* __u8[0]; segment-specific data */
41} __attribute__ ((packed));
42
43/* 4.3.2.1.1 END SEGMENT */
44struct uac3_cluster_end_segment_descriptor {
45	__le16 wLength;
46	__u8 bSegmentType;		/* Constant END_SEGMENT */
47} __attribute__ ((packed));
48
49/* 4.3.2.1.3.1 INFORMATION SEGMENT */
50struct uac3_cluster_information_segment_descriptor {
51	__le16 wLength;
52	__u8 bSegmentType;
53	__u8 bChPurpose;
54	__u8 bChRelationship;
55	__u8 bChGroupID;
56} __attribute__ ((packed));
57
58/* 4.5.2 CLASS-SPECIFIC AC INTERFACE DESCRIPTOR */
59struct uac3_ac_header_descriptor {
60	__u8 bLength;			/* 10 */
61	__u8 bDescriptorType;		/* CS_INTERFACE descriptor type */
62	__u8 bDescriptorSubtype;	/* HEADER descriptor subtype */
63	__u8 bCategory;
64
65	/* includes Clock Source, Unit, Terminal, and Power Domain desc. */
66	__le16 wTotalLength;
67
68	__le32 bmControls;
69} __attribute__ ((packed));
70
71/* 4.5.2.1 INPUT TERMINAL DESCRIPTOR */
72struct uac3_input_terminal_descriptor {
73	__u8 bLength;
74	__u8 bDescriptorType;
75	__u8 bDescriptorSubtype;
76	__u8 bTerminalID;
77	__le16 wTerminalType;
78	__u8 bAssocTerminal;
79	__u8 bCSourceID;
80	__le32 bmControls;
81	__le16 wClusterDescrID;
82	__le16 wExTerminalDescrID;
83	__le16 wConnectorsDescrID;
84	__le16 wTerminalDescrStr;
85} __attribute__((packed));
86
87/* 4.5.2.2 OUTPUT TERMINAL DESCRIPTOR */
88struct uac3_output_terminal_descriptor {
89	__u8 bLength;
90	__u8 bDescriptorType;
91	__u8 bDescriptorSubtype;
92	__u8 bTerminalID;
93	__le16 wTerminalType;
94	__u8 bAssocTerminal;
95	__u8 bSourceID;
96	__u8 bCSourceID;
97	__le32 bmControls;
98	__le16 wExTerminalDescrID;
99	__le16 wConnectorsDescrID;
100	__le16 wTerminalDescrStr;
101} __attribute__((packed));
102
103/* 4.5.2.7 FEATURE UNIT DESCRIPTOR */
104struct uac3_feature_unit_descriptor {
105	__u8 bLength;
106	__u8 bDescriptorType;
107	__u8 bDescriptorSubtype;
108	__u8 bUnitID;
109	__u8 bSourceID;
110	/* bmaControls is actually u32,
111	 * but u8 is needed for the hybrid parser */
112	__u8 bmaControls[]; /* variable length */
113	/* wFeatureDescrStr omitted */
114} __attribute__((packed));
115
116#define UAC3_DT_FEATURE_UNIT_SIZE(ch)		(7 + ((ch) + 1) * 4)
117
118/* As above, but more useful for defining your own descriptors */
119#define DECLARE_UAC3_FEATURE_UNIT_DESCRIPTOR(ch)		\
120struct uac3_feature_unit_descriptor_##ch {			\
121	__u8 bLength;						\
122	__u8 bDescriptorType;					\
123	__u8 bDescriptorSubtype;				\
124	__u8 bUnitID;						\
125	__u8 bSourceID;						\
126	__le32 bmaControls[ch + 1];				\
127	__le16 wFeatureDescrStr;				\
128} __attribute__ ((packed))
129
130/* 4.5.2.12 CLOCK SOURCE DESCRIPTOR */
131struct uac3_clock_source_descriptor {
132	__u8 bLength;
133	__u8 bDescriptorType;
134	__u8 bDescriptorSubtype;
135	__u8 bClockID;
136	__u8 bmAttributes;
137	__le32 bmControls;
138	__u8 bReferenceTerminal;
139	__le16 wClockSourceStr;
140} __attribute__((packed));
141
142/* bmAttribute fields */
143#define UAC3_CLOCK_SOURCE_TYPE_EXT	0x0
144#define UAC3_CLOCK_SOURCE_TYPE_INT	0x1
145#define UAC3_CLOCK_SOURCE_ASYNC		(0 << 2)
146#define UAC3_CLOCK_SOURCE_SYNCED_TO_SOF	(1 << 1)
147
148/* 4.5.2.13 CLOCK SELECTOR DESCRIPTOR */
149struct uac3_clock_selector_descriptor {
150	__u8 bLength;
151	__u8 bDescriptorType;
152	__u8 bDescriptorSubtype;
153	__u8 bClockID;
154	__u8 bNrInPins;
155	__u8 baCSourceID[];
156	/* bmControls and wCSelectorDescrStr omitted */
157} __attribute__((packed));
158
159/* 4.5.2.14 CLOCK MULTIPLIER DESCRIPTOR */
160struct uac3_clock_multiplier_descriptor {
161	__u8 bLength;
162	__u8 bDescriptorType;
163	__u8 bDescriptorSubtype;
164	__u8 bClockID;
165	__u8 bCSourceID;
166	__le32 bmControls;
167	__le16 wCMultiplierDescrStr;
168} __attribute__((packed));
169
170/* 4.5.2.15 POWER DOMAIN DESCRIPTOR */
171struct uac3_power_domain_descriptor {
172	__u8 bLength;
173	__u8 bDescriptorType;
174	__u8 bDescriptorSubtype;
175	__u8 bPowerDomainID;
176	__le16 waRecoveryTime1;
177	__le16 waRecoveryTime2;
178	__u8 bNrEntities;
179	__u8 baEntityID[];
180	/* wPDomainDescrStr omitted */
181} __attribute__((packed));
182
183/* As above, but more useful for defining your own descriptors */
184#define DECLARE_UAC3_POWER_DOMAIN_DESCRIPTOR(n)			\
185struct uac3_power_domain_descriptor_##n {			\
186	__u8 bLength;						\
187	__u8 bDescriptorType;					\
188	__u8 bDescriptorSubtype;				\
189	__u8 bPowerDomainID;					\
190	__le16 waRecoveryTime1;					\
191	__le16 waRecoveryTime2;					\
192	__u8 bNrEntities;					\
193	__u8 baEntityID[n];					\
194	__le16 wPDomainDescrStr;					\
195} __attribute__ ((packed))
196
197/* 4.7.2 CLASS-SPECIFIC AS INTERFACE DESCRIPTOR */
198struct uac3_as_header_descriptor {
199	__u8 bLength;
200	__u8 bDescriptorType;
201	__u8 bDescriptorSubtype;
202	__u8 bTerminalLink;
203	__le32 bmControls;
204	__le16 wClusterDescrID;
205	__le64 bmFormats;
206	__u8 bSubslotSize;
207	__u8 bBitResolution;
208	__le16 bmAuxProtocols;
209	__u8 bControlSize;
210} __attribute__((packed));
211
212#define UAC3_FORMAT_TYPE_I_RAW_DATA	(1 << 6)
213
214/* 4.8.1.2 CLASS-SPECIFIC AS ISOCHRONOUS AUDIO DATA ENDPOINT DESCRIPTOR */
215struct uac3_iso_endpoint_descriptor {
216	__u8 bLength;
217	__u8 bDescriptorType;
218	__u8 bDescriptorSubtype;
219	__le32 bmControls;
220	__u8 bLockDelayUnits;
221	__le16 wLockDelay;
222} __attribute__((packed));
223
224/* 5.2.1.6.1 INSERTION CONTROL PARAMETER BLOCK */
225struct uac3_insertion_ctl_blk {
226	__u8 bSize;
227	__u8 bmConInserted;
228} __attribute__ ((packed));
229
230/* 6.1 INTERRUPT DATA MESSAGE */
231struct uac3_interrupt_data_msg {
232	__u8 bInfo;
233	__u8 bSourceType;
234	__le16 wValue;
235	__le16 wIndex;
236} __attribute__((packed));
237
238/* A.2 AUDIO AUDIO FUNCTION SUBCLASS CODES */
239#define UAC3_FUNCTION_SUBCLASS_UNDEFINED	0x00
240#define UAC3_FUNCTION_SUBCLASS_FULL_ADC_3_0	0x01
241/* BADD profiles */
242#define UAC3_FUNCTION_SUBCLASS_GENERIC_IO	0x20
243#define UAC3_FUNCTION_SUBCLASS_HEADPHONE	0x21
244#define UAC3_FUNCTION_SUBCLASS_SPEAKER		0x22
245#define UAC3_FUNCTION_SUBCLASS_MICROPHONE	0x23
246#define UAC3_FUNCTION_SUBCLASS_HEADSET		0x24
247#define UAC3_FUNCTION_SUBCLASS_HEADSET_ADAPTER	0x25
248#define UAC3_FUNCTION_SUBCLASS_SPEAKERPHONE	0x26
249
250/* A.7 AUDIO FUNCTION CATEGORY CODES */
251#define UAC3_FUNCTION_SUBCLASS_UNDEFINED	0x00
252#define UAC3_FUNCTION_DESKTOP_SPEAKER		0x01
253#define UAC3_FUNCTION_HOME_THEATER		0x02
254#define UAC3_FUNCTION_MICROPHONE		0x03
255#define UAC3_FUNCTION_HEADSET			0x04
256#define UAC3_FUNCTION_TELEPHONE			0x05
257#define UAC3_FUNCTION_CONVERTER			0x06
258#define UAC3_FUNCTION_SOUND_RECORDER		0x07
259#define UAC3_FUNCTION_IO_BOX			0x08
260#define UAC3_FUNCTION_MUSICAL_INSTRUMENT	0x09
261#define UAC3_FUNCTION_PRO_AUDIO			0x0a
262#define UAC3_FUNCTION_AUDIO_VIDEO		0x0b
263#define UAC3_FUNCTION_CONTROL_PANEL		0x0c
264#define UAC3_FUNCTION_HEADPHONE			0x0d
265#define UAC3_FUNCTION_GENERIC_SPEAKER		0x0e
266#define UAC3_FUNCTION_HEADSET_ADAPTER		0x0f
267#define UAC3_FUNCTION_SPEAKERPHONE		0x10
268#define UAC3_FUNCTION_OTHER			0xff
269
270/* A.8 AUDIO CLASS-SPECIFIC DESCRIPTOR TYPES */
271#define UAC3_CS_UNDEFINED		0x20
272#define UAC3_CS_DEVICE			0x21
273#define UAC3_CS_CONFIGURATION		0x22
274#define UAC3_CS_STRING			0x23
275#define UAC3_CS_INTERFACE		0x24
276#define UAC3_CS_ENDPOINT		0x25
277#define UAC3_CS_CLUSTER			0x26
278
279/* A.10 CLUSTER DESCRIPTOR SEGMENT TYPES */
280#define UAC3_SEGMENT_UNDEFINED		0x00
281#define UAC3_CLUSTER_DESCRIPTION	0x01
282#define UAC3_CLUSTER_VENDOR_DEFINED	0x1F
283#define UAC3_CHANNEL_INFORMATION	0x20
284#define UAC3_CHANNEL_AMBISONIC		0x21
285#define UAC3_CHANNEL_DESCRIPTION	0x22
286#define UAC3_CHANNEL_VENDOR_DEFINED	0xFE
287#define UAC3_END_SEGMENT		0xFF
288
289/* A.11 CHANNEL PURPOSE DEFINITIONS */
290#define UAC3_PURPOSE_UNDEFINED		0x00
291#define UAC3_PURPOSE_GENERIC_AUDIO	0x01
292#define UAC3_PURPOSE_VOICE		0x02
293#define UAC3_PURPOSE_SPEECH		0x03
294#define UAC3_PURPOSE_AMBIENT		0x04
295#define UAC3_PURPOSE_REFERENCE		0x05
296#define UAC3_PURPOSE_ULTRASONIC		0x06
297#define UAC3_PURPOSE_VIBROKINETIC	0x07
298#define UAC3_PURPOSE_NON_AUDIO		0xFF
299
300/* A.12 CHANNEL RELATIONSHIP DEFINITIONS */
301#define UAC3_CH_RELATIONSHIP_UNDEFINED	0x00
302#define UAC3_CH_MONO			0x01
303#define UAC3_CH_LEFT			0x02
304#define UAC3_CH_RIGHT			0x03
305#define UAC3_CH_ARRAY			0x04
306#define UAC3_CH_PATTERN_X		0x20
307#define UAC3_CH_PATTERN_Y		0x21
308#define UAC3_CH_PATTERN_A		0x22
309#define UAC3_CH_PATTERN_B		0x23
310#define UAC3_CH_PATTERN_M		0x24
311#define UAC3_CH_PATTERN_S		0x25
312#define UAC3_CH_FRONT_LEFT		0x80
313#define UAC3_CH_FRONT_RIGHT		0x81
314#define UAC3_CH_FRONT_CENTER		0x82
315#define UAC3_CH_FRONT_LEFT_OF_CENTER	0x83
316#define UAC3_CH_FRONT_RIGHT_OF_CENTER	0x84
317#define UAC3_CH_FRONT_WIDE_LEFT		0x85
318#define UAC3_CH_FRONT_WIDE_RIGHT	0x86
319#define UAC3_CH_SIDE_LEFT		0x87
320#define UAC3_CH_SIDE_RIGHT		0x88
321#define UAC3_CH_SURROUND_ARRAY_LEFT	0x89
322#define UAC3_CH_SURROUND_ARRAY_RIGHT	0x8A
323#define UAC3_CH_BACK_LEFT		0x8B
324#define UAC3_CH_BACK_RIGHT		0x8C
325#define UAC3_CH_BACK_CENTER		0x8D
326#define UAC3_CH_BACK_LEFT_OF_CENTER	0x8E
327#define UAC3_CH_BACK_RIGHT_OF_CENTER	0x8F
328#define UAC3_CH_BACK_WIDE_LEFT		0x90
329#define UAC3_CH_BACK_WIDE_RIGHT		0x91
330#define UAC3_CH_TOP_CENTER		0x92
331#define UAC3_CH_TOP_FRONT_LEFT		0x93
332#define UAC3_CH_TOP_FRONT_RIGHT		0x94
333#define UAC3_CH_TOP_FRONT_CENTER	0x95
334#define UAC3_CH_TOP_FRONT_LOC		0x96
335#define UAC3_CH_TOP_FRONT_ROC		0x97
336#define UAC3_CH_TOP_FRONT_WIDE_LEFT	0x98
337#define UAC3_CH_TOP_FRONT_WIDE_RIGHT	0x99
338#define UAC3_CH_TOP_SIDE_LEFT		0x9A
339#define UAC3_CH_TOP_SIDE_RIGHT		0x9B
340#define UAC3_CH_TOP_SURR_ARRAY_LEFT	0x9C
341#define UAC3_CH_TOP_SURR_ARRAY_RIGHT	0x9D
342#define UAC3_CH_TOP_BACK_LEFT		0x9E
343#define UAC3_CH_TOP_BACK_RIGHT		0x9F
344#define UAC3_CH_TOP_BACK_CENTER		0xA0
345#define UAC3_CH_TOP_BACK_LOC		0xA1
346#define UAC3_CH_TOP_BACK_ROC		0xA2
347#define UAC3_CH_TOP_BACK_WIDE_LEFT	0xA3
348#define UAC3_CH_TOP_BACK_WIDE_RIGHT	0xA4
349#define UAC3_CH_BOTTOM_CENTER		0xA5
350#define UAC3_CH_BOTTOM_FRONT_LEFT	0xA6
351#define UAC3_CH_BOTTOM_FRONT_RIGHT	0xA7
352#define UAC3_CH_BOTTOM_FRONT_CENTER	0xA8
353#define UAC3_CH_BOTTOM_FRONT_LOC	0xA9
354#define UAC3_CH_BOTTOM_FRONT_ROC	0xAA
355#define UAC3_CH_BOTTOM_FRONT_WIDE_LEFT	0xAB
356#define UAC3_CH_BOTTOM_FRONT_WIDE_RIGHT	0xAC
357#define UAC3_CH_BOTTOM_SIDE_LEFT	0xAD
358#define UAC3_CH_BOTTOM_SIDE_RIGHT	0xAE
359#define UAC3_CH_BOTTOM_SURR_ARRAY_LEFT	0xAF
360#define UAC3_CH_BOTTOM_SURR_ARRAY_RIGHT	0xB0
361#define UAC3_CH_BOTTOM_BACK_LEFT	0xB1
362#define UAC3_CH_BOTTOM_BACK_RIGHT	0xB2
363#define UAC3_CH_BOTTOM_BACK_CENTER	0xB3
364#define UAC3_CH_BOTTOM_BACK_LOC		0xB4
365#define UAC3_CH_BOTTOM_BACK_ROC		0xB5
366#define UAC3_CH_BOTTOM_BACK_WIDE_LEFT	0xB6
367#define UAC3_CH_BOTTOM_BACK_WIDE_RIGHT	0xB7
368#define UAC3_CH_LOW_FREQUENCY_EFFECTS	0xB8
369#define UAC3_CH_LFE_LEFT		0xB9
370#define UAC3_CH_LFE_RIGHT		0xBA
371#define UAC3_CH_HEADPHONE_LEFT		0xBB
372#define UAC3_CH_HEADPHONE_RIGHT		0xBC
373
374/* A.15 AUDIO CLASS-SPECIFIC AC INTERFACE DESCRIPTOR SUBTYPES */
375/* see audio.h for the rest, which is identical to v1 */
376#define UAC3_EXTENDED_TERMINAL		0x04
377#define UAC3_MIXER_UNIT			0x05
378#define UAC3_SELECTOR_UNIT		0x06
379#define UAC3_FEATURE_UNIT		0x07
380#define UAC3_EFFECT_UNIT		0x08
381#define UAC3_PROCESSING_UNIT		0x09
382#define UAC3_EXTENSION_UNIT		0x0a
383#define UAC3_CLOCK_SOURCE		0x0b
384#define UAC3_CLOCK_SELECTOR		0x0c
385#define UAC3_CLOCK_MULTIPLIER		0x0d
386#define UAC3_SAMPLE_RATE_CONVERTER	0x0e
387#define UAC3_CONNECTORS			0x0f
388#define UAC3_POWER_DOMAIN		0x10
389
390/* A.20 PROCESSING UNIT PROCESS TYPES */
391#define UAC3_PROCESS_UNDEFINED		0x00
392#define UAC3_PROCESS_UP_DOWNMIX		0x01
393#define UAC3_PROCESS_STEREO_EXTENDER	0x02
394#define UAC3_PROCESS_MULTI_FUNCTION	0x03
395
396/* A.22 AUDIO CLASS-SPECIFIC REQUEST CODES */
397/* see audio-v2.h for the rest, which is identical to v2 */
398#define UAC3_CS_REQ_INTEN			0x04
399#define UAC3_CS_REQ_STRING			0x05
400#define UAC3_CS_REQ_HIGH_CAPABILITY_DESCRIPTOR	0x06
401
402/* A.23.1 AUDIOCONTROL INTERFACE CONTROL SELECTORS */
403#define UAC3_AC_CONTROL_UNDEFINED		0x00
404#define UAC3_AC_ACTIVE_INTERFACE_CONTROL	0x01
405#define UAC3_AC_POWER_DOMAIN_CONTROL		0x02
406
407/* A.23.5 TERMINAL CONTROL SELECTORS */
408#define UAC3_TE_UNDEFINED			0x00
409#define UAC3_TE_INSERTION			0x01
410#define UAC3_TE_OVERLOAD			0x02
411#define UAC3_TE_UNDERFLOW			0x03
412#define UAC3_TE_OVERFLOW			0x04
413#define UAC3_TE_LATENCY 			0x05
414
415/* A.23.10 PROCESSING UNITS CONTROL SELECTROS */
416
417/* Up/Down Mixer */
418#define UAC3_UD_MODE_SELECT			0x01
419
420/* Stereo Extender */
421#define UAC3_EXT_WIDTH_CONTROL			0x01
422
423
424/* BADD predefined Unit/Terminal values */
425#define UAC3_BADD_IT_ID1	1  /* Input Terminal ID1: bTerminalID = 1 */
426#define UAC3_BADD_FU_ID2	2  /* Feature Unit ID2: bUnitID = 2 */
427#define UAC3_BADD_OT_ID3	3  /* Output Terminal ID3: bTerminalID = 3 */
428#define UAC3_BADD_IT_ID4	4  /* Input Terminal ID4: bTerminalID = 4 */
429#define UAC3_BADD_FU_ID5	5  /* Feature Unit ID5: bUnitID = 5 */
430#define UAC3_BADD_OT_ID6	6  /* Output Terminal ID6: bTerminalID = 6 */
431#define UAC3_BADD_FU_ID7	7  /* Feature Unit ID7: bUnitID = 7 */
432#define UAC3_BADD_MU_ID8	8  /* Mixer Unit ID8: bUnitID = 8 */
433#define UAC3_BADD_CS_ID9	9  /* Clock Source Entity ID9: bClockID = 9 */
434#define UAC3_BADD_PD_ID10	10 /* Power Domain ID10: bPowerDomainID = 10 */
435#define UAC3_BADD_PD_ID11	11 /* Power Domain ID11: bPowerDomainID = 11 */
436
437/* BADD wMaxPacketSize of AS endpoints */
438#define UAC3_BADD_EP_MAXPSIZE_SYNC_MONO_16		0x0060
439#define UAC3_BADD_EP_MAXPSIZE_ASYNC_MONO_16		0x0062
440#define UAC3_BADD_EP_MAXPSIZE_SYNC_MONO_24		0x0090
441#define UAC3_BADD_EP_MAXPSIZE_ASYNC_MONO_24		0x0093
442#define UAC3_BADD_EP_MAXPSIZE_SYNC_STEREO_16		0x00C0
443#define UAC3_BADD_EP_MAXPSIZE_ASYNC_STEREO_16		0x00C4
444#define UAC3_BADD_EP_MAXPSIZE_SYNC_STEREO_24		0x0120
445#define UAC3_BADD_EP_MAXPSIZE_ASYNC_STEREO_24		0x0126
446
447/* BADD sample rate is always fixed to 48kHz */
448#define UAC3_BADD_SAMPLING_RATE				48000
449
450/* BADD power domains recovery times in 50us increments */
451#define UAC3_BADD_PD_RECOVER_D1D0			0x0258	/* 30ms */
452#define UAC3_BADD_PD_RECOVER_D2D0			0x1770	/* 300ms */
453
454#endif /* __LINUX_USB_AUDIO_V3_H */
455