123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454 |
- // SPDX-License-Identifier: GPL-2.0+
- /*
- * Copyright (c) 2017 Ruslan Bilovol <ruslan.bilovol@gmail.com>
- *
- * This file holds USB constants and structures defined
- * by the USB DEVICE CLASS DEFINITION FOR AUDIO DEVICES Release 3.0.
- */
- #ifndef __LINUX_USB_AUDIO_V3_H
- #define __LINUX_USB_AUDIO_V3_H
- #include <linux/types.h>
- /*
- * v1.0, v2.0 and v3.0 of this standard have many things in common. For the rest
- * of the definitions, please refer to audio.h and audio-v2.h
- */
- /* All High Capability descriptors have these 2 fields at the beginning */
- struct uac3_hc_descriptor_header {
- __le16 wLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __le16 wDescriptorID;
- } __attribute__ ((packed));
- /* 4.3.1 CLUSTER DESCRIPTOR HEADER */
- struct uac3_cluster_header_descriptor {
- __le16 wLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __le16 wDescriptorID;
- __u8 bNrChannels;
- } __attribute__ ((packed));
- /* 4.3.2.1 SEGMENTS */
- struct uac3_cluster_segment_descriptor {
- __le16 wLength;
- __u8 bSegmentType;
- /* __u8[0]; segment-specific data */
- } __attribute__ ((packed));
- /* 4.3.2.1.1 END SEGMENT */
- struct uac3_cluster_end_segment_descriptor {
- __le16 wLength;
- __u8 bSegmentType; /* Constant END_SEGMENT */
- } __attribute__ ((packed));
- /* 4.3.2.1.3.1 INFORMATION SEGMENT */
- struct uac3_cluster_information_segment_descriptor {
- __le16 wLength;
- __u8 bSegmentType;
- __u8 bChPurpose;
- __u8 bChRelationship;
- __u8 bChGroupID;
- } __attribute__ ((packed));
- /* 4.5.2 CLASS-SPECIFIC AC INTERFACE DESCRIPTOR */
- struct uac3_ac_header_descriptor {
- __u8 bLength; /* 10 */
- __u8 bDescriptorType; /* CS_INTERFACE descriptor type */
- __u8 bDescriptorSubtype; /* HEADER descriptor subtype */
- __u8 bCategory;
- /* includes Clock Source, Unit, Terminal, and Power Domain desc. */
- __le16 wTotalLength;
- __le32 bmControls;
- } __attribute__ ((packed));
- /* 4.5.2.1 INPUT TERMINAL DESCRIPTOR */
- struct uac3_input_terminal_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bTerminalID;
- __le16 wTerminalType;
- __u8 bAssocTerminal;
- __u8 bCSourceID;
- __le32 bmControls;
- __le16 wClusterDescrID;
- __le16 wExTerminalDescrID;
- __le16 wConnectorsDescrID;
- __le16 wTerminalDescrStr;
- } __attribute__((packed));
- /* 4.5.2.2 OUTPUT TERMINAL DESCRIPTOR */
- struct uac3_output_terminal_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bTerminalID;
- __le16 wTerminalType;
- __u8 bAssocTerminal;
- __u8 bSourceID;
- __u8 bCSourceID;
- __le32 bmControls;
- __le16 wExTerminalDescrID;
- __le16 wConnectorsDescrID;
- __le16 wTerminalDescrStr;
- } __attribute__((packed));
- /* 4.5.2.7 FEATURE UNIT DESCRIPTOR */
- struct uac3_feature_unit_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bUnitID;
- __u8 bSourceID;
- /* bmaControls is actually u32,
- * but u8 is needed for the hybrid parser */
- __u8 bmaControls[0]; /* variable length */
- /* wFeatureDescrStr omitted */
- } __attribute__((packed));
- #define UAC3_DT_FEATURE_UNIT_SIZE(ch) (7 + ((ch) + 1) * 4)
- /* As above, but more useful for defining your own descriptors */
- #define DECLARE_UAC3_FEATURE_UNIT_DESCRIPTOR(ch) \
- struct uac3_feature_unit_descriptor_##ch { \
- __u8 bLength; \
- __u8 bDescriptorType; \
- __u8 bDescriptorSubtype; \
- __u8 bUnitID; \
- __u8 bSourceID; \
- __le32 bmaControls[ch + 1]; \
- __le16 wFeatureDescrStr; \
- } __attribute__ ((packed))
- /* 4.5.2.12 CLOCK SOURCE DESCRIPTOR */
- struct uac3_clock_source_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bClockID;
- __u8 bmAttributes;
- __le32 bmControls;
- __u8 bReferenceTerminal;
- __le16 wClockSourceStr;
- } __attribute__((packed));
- /* bmAttribute fields */
- #define UAC3_CLOCK_SOURCE_TYPE_EXT 0x0
- #define UAC3_CLOCK_SOURCE_TYPE_INT 0x1
- #define UAC3_CLOCK_SOURCE_ASYNC (0 << 2)
- #define UAC3_CLOCK_SOURCE_SYNCED_TO_SOF (1 << 1)
- /* 4.5.2.13 CLOCK SELECTOR DESCRIPTOR */
- struct uac3_clock_selector_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bClockID;
- __u8 bNrInPins;
- __u8 baCSourceID[];
- /* bmControls and wCSelectorDescrStr omitted */
- } __attribute__((packed));
- /* 4.5.2.14 CLOCK MULTIPLIER DESCRIPTOR */
- struct uac3_clock_multiplier_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bClockID;
- __u8 bCSourceID;
- __le32 bmControls;
- __le16 wCMultiplierDescrStr;
- } __attribute__((packed));
- /* 4.5.2.15 POWER DOMAIN DESCRIPTOR */
- struct uac3_power_domain_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bPowerDomainID;
- __le16 waRecoveryTime1;
- __le16 waRecoveryTime2;
- __u8 bNrEntities;
- __u8 baEntityID[];
- /* wPDomainDescrStr omitted */
- } __attribute__((packed));
- /* As above, but more useful for defining your own descriptors */
- #define DECLARE_UAC3_POWER_DOMAIN_DESCRIPTOR(n) \
- struct uac3_power_domain_descriptor_##n { \
- __u8 bLength; \
- __u8 bDescriptorType; \
- __u8 bDescriptorSubtype; \
- __u8 bPowerDomainID; \
- __le16 waRecoveryTime1; \
- __le16 waRecoveryTime2; \
- __u8 bNrEntities; \
- __u8 baEntityID[n]; \
- __le16 wPDomainDescrStr; \
- } __attribute__ ((packed))
- /* 4.7.2 CLASS-SPECIFIC AS INTERFACE DESCRIPTOR */
- struct uac3_as_header_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __u8 bTerminalLink;
- __le32 bmControls;
- __le16 wClusterDescrID;
- __le64 bmFormats;
- __u8 bSubslotSize;
- __u8 bBitResolution;
- __le16 bmAuxProtocols;
- __u8 bControlSize;
- } __attribute__((packed));
- #define UAC3_FORMAT_TYPE_I_RAW_DATA (1 << 6)
- /* 4.8.1.2 CLASS-SPECIFIC AS ISOCHRONOUS AUDIO DATA ENDPOINT DESCRIPTOR */
- struct uac3_iso_endpoint_descriptor {
- __u8 bLength;
- __u8 bDescriptorType;
- __u8 bDescriptorSubtype;
- __le32 bmControls;
- __u8 bLockDelayUnits;
- __le16 wLockDelay;
- } __attribute__((packed));
- /* 5.2.1.6.1 INSERTION CONTROL PARAMETER BLOCK */
- struct uac3_insertion_ctl_blk {
- __u8 bSize;
- __u8 bmConInserted;
- } __attribute__ ((packed));
- /* 6.1 INTERRUPT DATA MESSAGE */
- struct uac3_interrupt_data_msg {
- __u8 bInfo;
- __u8 bSourceType;
- __le16 wValue;
- __le16 wIndex;
- } __attribute__((packed));
- /* A.2 AUDIO AUDIO FUNCTION SUBCLASS CODES */
- #define UAC3_FUNCTION_SUBCLASS_UNDEFINED 0x00
- #define UAC3_FUNCTION_SUBCLASS_FULL_ADC_3_0 0x01
- /* BADD profiles */
- #define UAC3_FUNCTION_SUBCLASS_GENERIC_IO 0x20
- #define UAC3_FUNCTION_SUBCLASS_HEADPHONE 0x21
- #define UAC3_FUNCTION_SUBCLASS_SPEAKER 0x22
- #define UAC3_FUNCTION_SUBCLASS_MICROPHONE 0x23
- #define UAC3_FUNCTION_SUBCLASS_HEADSET 0x24
- #define UAC3_FUNCTION_SUBCLASS_HEADSET_ADAPTER 0x25
- #define UAC3_FUNCTION_SUBCLASS_SPEAKERPHONE 0x26
- /* A.7 AUDIO FUNCTION CATEGORY CODES */
- #define UAC3_FUNCTION_SUBCLASS_UNDEFINED 0x00
- #define UAC3_FUNCTION_DESKTOP_SPEAKER 0x01
- #define UAC3_FUNCTION_HOME_THEATER 0x02
- #define UAC3_FUNCTION_MICROPHONE 0x03
- #define UAC3_FUNCTION_HEADSET 0x04
- #define UAC3_FUNCTION_TELEPHONE 0x05
- #define UAC3_FUNCTION_CONVERTER 0x06
- #define UAC3_FUNCTION_SOUND_RECORDER 0x07
- #define UAC3_FUNCTION_IO_BOX 0x08
- #define UAC3_FUNCTION_MUSICAL_INSTRUMENT 0x09
- #define UAC3_FUNCTION_PRO_AUDIO 0x0a
- #define UAC3_FUNCTION_AUDIO_VIDEO 0x0b
- #define UAC3_FUNCTION_CONTROL_PANEL 0x0c
- #define UAC3_FUNCTION_HEADPHONE 0x0d
- #define UAC3_FUNCTION_GENERIC_SPEAKER 0x0e
- #define UAC3_FUNCTION_HEADSET_ADAPTER 0x0f
- #define UAC3_FUNCTION_SPEAKERPHONE 0x10
- #define UAC3_FUNCTION_OTHER 0xff
- /* A.8 AUDIO CLASS-SPECIFIC DESCRIPTOR TYPES */
- #define UAC3_CS_UNDEFINED 0x20
- #define UAC3_CS_DEVICE 0x21
- #define UAC3_CS_CONFIGURATION 0x22
- #define UAC3_CS_STRING 0x23
- #define UAC3_CS_INTERFACE 0x24
- #define UAC3_CS_ENDPOINT 0x25
- #define UAC3_CS_CLUSTER 0x26
- /* A.10 CLUSTER DESCRIPTOR SEGMENT TYPES */
- #define UAC3_SEGMENT_UNDEFINED 0x00
- #define UAC3_CLUSTER_DESCRIPTION 0x01
- #define UAC3_CLUSTER_VENDOR_DEFINED 0x1F
- #define UAC3_CHANNEL_INFORMATION 0x20
- #define UAC3_CHANNEL_AMBISONIC 0x21
- #define UAC3_CHANNEL_DESCRIPTION 0x22
- #define UAC3_CHANNEL_VENDOR_DEFINED 0xFE
- #define UAC3_END_SEGMENT 0xFF
- /* A.11 CHANNEL PURPOSE DEFINITIONS */
- #define UAC3_PURPOSE_UNDEFINED 0x00
- #define UAC3_PURPOSE_GENERIC_AUDIO 0x01
- #define UAC3_PURPOSE_VOICE 0x02
- #define UAC3_PURPOSE_SPEECH 0x03
- #define UAC3_PURPOSE_AMBIENT 0x04
- #define UAC3_PURPOSE_REFERENCE 0x05
- #define UAC3_PURPOSE_ULTRASONIC 0x06
- #define UAC3_PURPOSE_VIBROKINETIC 0x07
- #define UAC3_PURPOSE_NON_AUDIO 0xFF
- /* A.12 CHANNEL RELATIONSHIP DEFINITIONS */
- #define UAC3_CH_RELATIONSHIP_UNDEFINED 0x00
- #define UAC3_CH_MONO 0x01
- #define UAC3_CH_LEFT 0x02
- #define UAC3_CH_RIGHT 0x03
- #define UAC3_CH_ARRAY 0x04
- #define UAC3_CH_PATTERN_X 0x20
- #define UAC3_CH_PATTERN_Y 0x21
- #define UAC3_CH_PATTERN_A 0x22
- #define UAC3_CH_PATTERN_B 0x23
- #define UAC3_CH_PATTERN_M 0x24
- #define UAC3_CH_PATTERN_S 0x25
- #define UAC3_CH_FRONT_LEFT 0x80
- #define UAC3_CH_FRONT_RIGHT 0x81
- #define UAC3_CH_FRONT_CENTER 0x82
- #define UAC3_CH_FRONT_LEFT_OF_CENTER 0x83
- #define UAC3_CH_FRONT_RIGHT_OF_CENTER 0x84
- #define UAC3_CH_FRONT_WIDE_LEFT 0x85
- #define UAC3_CH_FRONT_WIDE_RIGHT 0x86
- #define UAC3_CH_SIDE_LEFT 0x87
- #define UAC3_CH_SIDE_RIGHT 0x88
- #define UAC3_CH_SURROUND_ARRAY_LEFT 0x89
- #define UAC3_CH_SURROUND_ARRAY_RIGHT 0x8A
- #define UAC3_CH_BACK_LEFT 0x8B
- #define UAC3_CH_BACK_RIGHT 0x8C
- #define UAC3_CH_BACK_CENTER 0x8D
- #define UAC3_CH_BACK_LEFT_OF_CENTER 0x8E
- #define UAC3_CH_BACK_RIGHT_OF_CENTER 0x8F
- #define UAC3_CH_BACK_WIDE_LEFT 0x90
- #define UAC3_CH_BACK_WIDE_RIGHT 0x91
- #define UAC3_CH_TOP_CENTER 0x92
- #define UAC3_CH_TOP_FRONT_LEFT 0x93
- #define UAC3_CH_TOP_FRONT_RIGHT 0x94
- #define UAC3_CH_TOP_FRONT_CENTER 0x95
- #define UAC3_CH_TOP_FRONT_LOC 0x96
- #define UAC3_CH_TOP_FRONT_ROC 0x97
- #define UAC3_CH_TOP_FRONT_WIDE_LEFT 0x98
- #define UAC3_CH_TOP_FRONT_WIDE_RIGHT 0x99
- #define UAC3_CH_TOP_SIDE_LEFT 0x9A
- #define UAC3_CH_TOP_SIDE_RIGHT 0x9B
- #define UAC3_CH_TOP_SURR_ARRAY_LEFT 0x9C
- #define UAC3_CH_TOP_SURR_ARRAY_RIGHT 0x9D
- #define UAC3_CH_TOP_BACK_LEFT 0x9E
- #define UAC3_CH_TOP_BACK_RIGHT 0x9F
- #define UAC3_CH_TOP_BACK_CENTER 0xA0
- #define UAC3_CH_TOP_BACK_LOC 0xA1
- #define UAC3_CH_TOP_BACK_ROC 0xA2
- #define UAC3_CH_TOP_BACK_WIDE_LEFT 0xA3
- #define UAC3_CH_TOP_BACK_WIDE_RIGHT 0xA4
- #define UAC3_CH_BOTTOM_CENTER 0xA5
- #define UAC3_CH_BOTTOM_FRONT_LEFT 0xA6
- #define UAC3_CH_BOTTOM_FRONT_RIGHT 0xA7
- #define UAC3_CH_BOTTOM_FRONT_CENTER 0xA8
- #define UAC3_CH_BOTTOM_FRONT_LOC 0xA9
- #define UAC3_CH_BOTTOM_FRONT_ROC 0xAA
- #define UAC3_CH_BOTTOM_FRONT_WIDE_LEFT 0xAB
- #define UAC3_CH_BOTTOM_FRONT_WIDE_RIGHT 0xAC
- #define UAC3_CH_BOTTOM_SIDE_LEFT 0xAD
- #define UAC3_CH_BOTTOM_SIDE_RIGHT 0xAE
- #define UAC3_CH_BOTTOM_SURR_ARRAY_LEFT 0xAF
- #define UAC3_CH_BOTTOM_SURR_ARRAY_RIGHT 0xB0
- #define UAC3_CH_BOTTOM_BACK_LEFT 0xB1
- #define UAC3_CH_BOTTOM_BACK_RIGHT 0xB2
- #define UAC3_CH_BOTTOM_BACK_CENTER 0xB3
- #define UAC3_CH_BOTTOM_BACK_LOC 0xB4
- #define UAC3_CH_BOTTOM_BACK_ROC 0xB5
- #define UAC3_CH_BOTTOM_BACK_WIDE_LEFT 0xB6
- #define UAC3_CH_BOTTOM_BACK_WIDE_RIGHT 0xB7
- #define UAC3_CH_LOW_FREQUENCY_EFFECTS 0xB8
- #define UAC3_CH_LFE_LEFT 0xB9
- #define UAC3_CH_LFE_RIGHT 0xBA
- #define UAC3_CH_HEADPHONE_LEFT 0xBB
- #define UAC3_CH_HEADPHONE_RIGHT 0xBC
- /* A.15 AUDIO CLASS-SPECIFIC AC INTERFACE DESCRIPTOR SUBTYPES */
- /* see audio.h for the rest, which is identical to v1 */
- #define UAC3_EXTENDED_TERMINAL 0x04
- #define UAC3_MIXER_UNIT 0x05
- #define UAC3_SELECTOR_UNIT 0x06
- #define UAC3_FEATURE_UNIT 0x07
- #define UAC3_EFFECT_UNIT 0x08
- #define UAC3_PROCESSING_UNIT 0x09
- #define UAC3_EXTENSION_UNIT 0x0a
- #define UAC3_CLOCK_SOURCE 0x0b
- #define UAC3_CLOCK_SELECTOR 0x0c
- #define UAC3_CLOCK_MULTIPLIER 0x0d
- #define UAC3_SAMPLE_RATE_CONVERTER 0x0e
- #define UAC3_CONNECTORS 0x0f
- #define UAC3_POWER_DOMAIN 0x10
- /* A.20 PROCESSING UNIT PROCESS TYPES */
- #define UAC3_PROCESS_UNDEFINED 0x00
- #define UAC3_PROCESS_UP_DOWNMIX 0x01
- #define UAC3_PROCESS_STEREO_EXTENDER 0x02
- #define UAC3_PROCESS_MULTI_FUNCTION 0x03
- /* A.22 AUDIO CLASS-SPECIFIC REQUEST CODES */
- /* see audio-v2.h for the rest, which is identical to v2 */
- #define UAC3_CS_REQ_INTEN 0x04
- #define UAC3_CS_REQ_STRING 0x05
- #define UAC3_CS_REQ_HIGH_CAPABILITY_DESCRIPTOR 0x06
- /* A.23.1 AUDIOCONTROL INTERFACE CONTROL SELECTORS */
- #define UAC3_AC_CONTROL_UNDEFINED 0x00
- #define UAC3_AC_ACTIVE_INTERFACE_CONTROL 0x01
- #define UAC3_AC_POWER_DOMAIN_CONTROL 0x02
- /* A.23.5 TERMINAL CONTROL SELECTORS */
- #define UAC3_TE_UNDEFINED 0x00
- #define UAC3_TE_INSERTION 0x01
- #define UAC3_TE_OVERLOAD 0x02
- #define UAC3_TE_UNDERFLOW 0x03
- #define UAC3_TE_OVERFLOW 0x04
- #define UAC3_TE_LATENCY 0x05
- /* A.23.10 PROCESSING UNITS CONTROL SELECTROS */
- /* Up/Down Mixer */
- #define UAC3_UD_MODE_SELECT 0x01
- /* Stereo Extender */
- #define UAC3_EXT_WIDTH_CONTROL 0x01
- /* BADD predefined Unit/Terminal values */
- #define UAC3_BADD_IT_ID1 1 /* Input Terminal ID1: bTerminalID = 1 */
- #define UAC3_BADD_FU_ID2 2 /* Feature Unit ID2: bUnitID = 2 */
- #define UAC3_BADD_OT_ID3 3 /* Output Terminal ID3: bTerminalID = 3 */
- #define UAC3_BADD_IT_ID4 4 /* Input Terminal ID4: bTerminalID = 4 */
- #define UAC3_BADD_FU_ID5 5 /* Feature Unit ID5: bUnitID = 5 */
- #define UAC3_BADD_OT_ID6 6 /* Output Terminal ID6: bTerminalID = 6 */
- #define UAC3_BADD_FU_ID7 7 /* Feature Unit ID7: bUnitID = 7 */
- #define UAC3_BADD_MU_ID8 8 /* Mixer Unit ID8: bUnitID = 8 */
- #define UAC3_BADD_CS_ID9 9 /* Clock Source Entity ID9: bClockID = 9 */
- #define UAC3_BADD_PD_ID10 10 /* Power Domain ID10: bPowerDomainID = 10 */
- #define UAC3_BADD_PD_ID11 11 /* Power Domain ID11: bPowerDomainID = 11 */
- /* BADD wMaxPacketSize of AS endpoints */
- #define UAC3_BADD_EP_MAXPSIZE_SYNC_MONO_16 0x0060
- #define UAC3_BADD_EP_MAXPSIZE_ASYNC_MONO_16 0x0062
- #define UAC3_BADD_EP_MAXPSIZE_SYNC_MONO_24 0x0090
- #define UAC3_BADD_EP_MAXPSIZE_ASYNC_MONO_24 0x0093
- #define UAC3_BADD_EP_MAXPSIZE_SYNC_STEREO_16 0x00C0
- #define UAC3_BADD_EP_MAXPSIZE_ASYNC_STEREO_16 0x00C4
- #define UAC3_BADD_EP_MAXPSIZE_SYNC_STEREO_24 0x0120
- #define UAC3_BADD_EP_MAXPSIZE_ASYNC_STEREO_24 0x0126
- /* BADD sample rate is always fixed to 48kHz */
- #define UAC3_BADD_SAMPLING_RATE 48000
- /* BADD power domains recovery times in 50us increments */
- #define UAC3_BADD_PD_RECOVER_D1D0 0x0258 /* 30ms */
- #define UAC3_BADD_PD_RECOVER_D2D0 0x1770 /* 300ms */
- #endif /* __LINUX_USB_AUDIO_V3_H */
|