/* * Copyright (c) 2015 - 2016, Freescale Semiconductor, Inc. * Copyright 2016 NXP * All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #ifndef __USB_DEVICE_AUDIO_H__ #define __USB_DEVICE_AUDIO_H__ /*! * @addtogroup usb_device_audio_drv * @{ */ /******************************************************************************* * Definitions ******************************************************************************/ /*! * @name USB Audio class codes * @{ */ /*! @brief Audio device class code */ #define USB_DEVICE_CONFIG_AUDIO_CLASS_CODE (0x01U) /*! @brief Audio device subclass code */ #define USB_DEVICE_AUDIO_STREAM_SUBCLASS (0x02U) #define USB_DEVICE_AUDIO_CONTROL_SUBCLASS (0x01U) /*! @brief Audio device class-specific descriptor type */ #define USB_DESCRIPTOR_TYPE_AUDIO_CS_INTERFACE (0x24U) #define USB_DESCRIPTOR_TYPE_AUDIO_CS_ENDPOINT (0x25U) /*! @brief Audio device class-specific control interface descriptor subtype */ #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_HEADER (0x01U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_INPUT_TERMINAL (0x02U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_OUTPUT_TERMINAL (0x03U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_MIXER_UNIT (0x04U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_SELECTOR_UNIT (0x05U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_FEATURE_UNIT (0x06U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_EFFECT_UNIT (0x07U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_PROCESSING_UNIT_AUDIO20 (0x08U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_EXTENSION_UNIT_AUDIO20 (0x09U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_CLOCK_SOURCE_UNIT (0x0AU) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_CLOCK_SELECTOR_UNIT (0x0BU) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_CLOCK_MULTIPLIER_UNIT (0x0CU) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_SAMPLE_RATE_CONVERTER_UNIT (0x0DU) #else #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_PROCESSING_UNIT (0x07U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_CONTROL_EXTENSION_UNIT (0x08U) #endif /*! @brief Audio device class-specific control interface effect unit effect type */ #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DESCRIPTOR_AUDIO_CONTROL_EFFECT_UNIT_UNDEFINED_TYPE (0x00U) #define USB_DESCRIPTOR_AUDIO_CONTROL_EFFECT_UNIT_PARAM_EQ_SECTION_EFFECT_TYPE (0x01U) #define USB_DESCRIPTOR_AUDIO_CONTROL_EFFECT_UNIT_REVERBERATION_EFFECT_TYPE (0x02U) #define USB_DESCRIPTOR_AUDIO_CONTROL_EFFECT_UNIT_MOD_DELAY_EFFECT_TYPE (0x03U) #define USB_DESCRIPTOR_AUDIO_CONTROL_EFFECT_UNIT_DYN_RANGE_COMP_EFFECT_TYPE (0x04U) #endif /*! @brief Audio device class-specific control interface processing unit process type */ #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_UPDOWNMIX_PROCESS_TYPE (0x01U) #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_DOLBY_PROLOGIC_PROCESS_TYPE (0x02U) #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_STEREO_EXTENDER_PROCESS_TYPE (0x03U) #if (!USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* used by usb audio 1.0 */ #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_REVERBERATION_PROCESS_TYPE (0x04U) #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_CHORUS_PROCESS_TYPE (0x05U) #define USB_DESCRIPTOR_AUDIO_CONTROL_PROCESSING_UNIT_DYN_RANGE_COMP_PROCESS_TYPE (0x06U) #endif /*! @brief Audio device class-specific stream interface descriptor subtype */ #define USB_DESCRIPTOR_SUBTYPE_AUDIO_STREAMING_AS_GENERAL (0x01U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_STREAMING_FORMAT_TYPE (0x02U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_STREAMING_ENCODER (0x03U) #define USB_DESCRIPTOR_SUBTYPE_AUDIO_STREAMING_DECODER (0x04U) #else #define USB_DESCRIPTOR_SUBTYPE_AUDIO_STREAMING_FORMAT_SPECIFIC (0x03U) #endif /*! @brief Audio device Format Type Codes */ #define USB_AUDIO_FORMAT_TYPE_UNDEFINED (0x00U) #define USB_AUDIO_FORMAT_TYPE_I (0x01U) #define USB_AUDIO_FORMAT_TYPE_II (0x02U) #define USB_AUDIO_FORMAT_TYPE_III (0x03U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_AUDIO_FORMAT_TYPE_IV (0x04U) #define USB_AUDIO_FORMAT_EXT_FORMAT_TYPE_I (0x81U) #define USB_AUDIO_FORMAT_EXT_FORMAT_TYPE_II (0x82U) #define USB_AUDIO_FORMAT_EXT_FORMAT_TYPE_III (0x83U) #endif /*! @brief Audio device class-specific stream interface Encoder/Decoder Type Codes */ #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_UNDEFINED (0x00U) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_OTHER_ENCODER (0x01U) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_MPEG_ENCODER (0x02U) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_AC3_ENCODER (0x03U) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_WMA_ENCODER (0x04U) #define USB_DESCRIPTOR_AUDIO_STREAM_ENCODER_DTS_ENCODER (0x05U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_UNDEFINED (0x00U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_OTHER_DECODER (0x01U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_MPEG_DECODER (0x02U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_AC3_DECODER (0x03U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_WMA_DECODER (0x04U) #define USB_DESCRIPTOR_AUDIO_STREAM_DECODER_DTS_DECODER (0x05U) #endif /*! @brief Commands for USB device AUDIO Class specific request codes */ #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_CUR_REQUEST (0x01U) #define USB_DEVICE_AUDIO_RANGE_REQUEST (0x02U) #define USB_DEVICE_AUDIO_MEM_REQUEST (0x03U) #else #define USB_DEVICE_AUDIO_SET_CUR_REQUEST (0x01U) #define USB_DEVICE_AUDIO_GET_CUR_REQUEST (0x81U) #define USB_DEVICE_AUDIO_SET_MIN_REQUEST (0x02U) #define USB_DEVICE_AUDIO_GET_MIN_REQUEST (0x82U) #define USB_DEVICE_AUDIO_SET_MAX_REQUEST (0x03U) #define USB_DEVICE_AUDIO_GET_MAX_REQUEST (0x83U) #define USB_DEVICE_AUDIO_SET_RES_REQUEST (0x04U) #define USB_DEVICE_AUDIO_GET_RES_REQUEST (0x84U) #define USB_DEVICE_AUDIO_SET_MEM_REQUEST (0x05U) #define USB_DEVICE_AUDIO_GET_MEM_REQUEST (0x85U) #endif /*! @brief Commands for USB device AUDIO control feature unit control selector */ #define USB_DEVICE_AUDIO_FU_MUTE_CONTROL_SELECTOR (0x01U) #define USB_DEVICE_AUDIO_FU_VOLUME_CONTROL_SELECTOR (0x02U) #define USB_DEVICE_AUDIO_FU_BASS_CONTROL_SELECTOR (0x03U) #define USB_DEVICE_AUDIO_FU_MID_CONTROL_SELECTOR (0x04U) #define USB_DEVICE_AUDIO_FU_TREBLE_CONTROL_SELECTOR (0x05U) #define USB_DEVICE_AUDIO_FU_GRAPHIC_EQUALIZER_CONTROL_SELECTOR (0x06U) #define USB_DEVICE_AUDIO_FU_AUTOMATIC_GAIN_CONTROL_SELECTOR (0x07U) #define USB_DEVICE_AUDIO_FU_DELAY_CONTROL_SELECTOR (0x08U) #define USB_DEVICE_AUDIO_FU_BASS_BOOST_CONTROL_SELECTOR (0x09U) #define USB_DEVICE_AUDIO_FU_LOUDNESS_CONTROL_SELECTOR (0x0AU) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_FU_INPUT_GAIN_CONTROL_SELECTOR (0x0BU) #define USB_DEVICE_AUDIO_FU_INPUT_GAIN_PAD_CONTROL_SELECTOR (0x0CU) #define USB_DEVICE_AUDIO_FU_PHASE_INVERTER_CONTROL_SELECTOR (0x0DU) #define USB_DEVICE_AUDIO_FU_UNDERFLOW_CONTROL_SELECTOR (0x0EU) #define USB_DEVICE_AUDIO_FU_OVERFLOW_CONTROL_SELECTOR (0x0FU) #define USB_DEVICE_AUDIO_FU_LATENCY_CONTROL_SELECTOR (0x10U) #endif #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /*! @brief Commands for USB device AUDIO control Parametric Equalizer Section Effect Unit Control Selectors */ #define USB_DEVICE_AUDIO_EU_PE_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_EU_PE_CENTERFREQ_CONTROL (0x02U) #define USB_DEVICE_AUDIO_EU_PE_QFACTOR_CONTROL (0x03U) #define USB_DEVICE_AUDIO_EU_PE_GAIN_CONTROL (0x04U) #define USB_DEVICE_AUDIO_EU_PE_UNDERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_EU_PE_OVERFLOW_CONTROL (0x06U) #define USB_DEVICE_AUDIO_EU_PE_LATENCY_CONTROL (0x07U) /*! @brief Commands for USB device AUDIO control Reverberation Effect Unit Control Selectors Control Selectors */ #define USB_DEVICE_AUDIO_EU_RV_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_EU_RV_TYPE_CONTROL (0x02U) #define USB_DEVICE_AUDIO_EU_RV_LEVEL_CONTROL (0x03U) #define USB_DEVICE_AUDIO_EU_RV_TIME_CONTROL (0x04U) #define USB_DEVICE_AUDIO_EU_RV_FEEDBACK_CONTROL (0x05U) #define USB_DEVICE_AUDIO_EU_RV_PREDELAY_CONTROL (0x06U) #define USB_DEVICE_AUDIO_EU_RV_DENSITY_CONTROL (0x07U) #define USB_DEVICE_AUDIO_EU_RV_RV_HIFREQ_ROLLOFF_CONTROL (0x08U) #define USB_DEVICE_AUDIO_EU_RV_UNDERFLOW_CONTROL (0x09U) #define USB_DEVICE_AUDIO_EU_RV_OVERFLOW_CONTROL (0x0AU) #define USB_DEVICE_AUDIO_EU_RV_LATENCY_CONTROL (0x0BU) /*! @brief Commands for USB device AUDIO control Modulation Delay Effect Unit Control Selectors */ #define USB_DEVICE_AUDIO_EU_MD_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_EU_MD_BALANCE_CONTROL (0x02U) #define USB_DEVICE_AUDIO_EU_MD_RATE_CONTROL (0x03U) #define USB_DEVICE_AUDIO_EU_MD_DEPTH_CONTROL (0x04U) #define USB_DEVICE_AUDIO_EU_MD_TIME_CONTROL (0x05U) #define USB_DEVICE_AUDIO_EU_MD_FEEDBACK_CONTROL (0x06U) #define USB_DEVICE_AUDIO_EU_MD_UNDERFLOW_CONTROL (0x07U) #define USB_DEVICE_AUDIO_EU_MD_OVERFLOW_CONTROL (0x08U) #define USB_DEVICE_AUDIO_EU_MD_LATENCY_CONTROL (0x09U) /*! @brief Commands for USB device AUDIO control Dynamic Range Compressor Effect Unit Control Selectors */ #define USB_DEVICE_AUDIO_EU_DR_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_EU_DR_COMPRESSION_RATE_CONTROL (0x02U) #define USB_DEVICE_AUDIO_EU_DR_MAXAMPL_CONTROL (0x03U) #define USB_DEVICE_AUDIO_EU_DR_THRESHOLD_CONTROL (0x04U) #define USB_DEVICE_AUDIO_EU_DR_ATTACK_TIME_CONTROL (0x05U) #define USB_DEVICE_AUDIO_EU_DR_RELEASE_TIME_CONTROL (0x06U) #define USB_DEVICE_AUDIO_EU_DR_UNDERFLOW_CONTROL (0x07U) #define USB_DEVICE_AUDIO_EU_DR_OVERFLOW_CONTROL (0x08U) #define USB_DEVICE_AUDIO_EU_DR_LATENCY_CONTROL (0x09U) #endif /*! @brief Commands for USB device AUDIO control Up/Down-mix Processing Unit Control Selectors */ #define USB_DEVICE_AUDIO_PU_UD_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_UD_MODE_SELECT_CONTROL (0x02U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_PU_UD_CLUSTER_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_UD_UNDERFLOW_CONTROL (0x04U) #define USB_DEVICE_AUDIO_PU_UD_OVERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_PU_UD_LATENCY_CONTROL (0x06U) #endif /*! @brief Commands for USB device AUDIO control Dolby Prologic Processing Unit Control Selectors */ #define USB_DEVICE_AUDIO_PU_DP_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_DP_MODE_SELECT_CONTROL (0x02U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_PU_DP_CLUSTER_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_DP_UNDERFLOW_CONTROL (0x04U) #define USB_DEVICE_AUDIO_PU_DP_OVERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_PU_DP_LATENCY_CONTROL (0x06U) #endif /*! @brief Commands for USB device AUDIO control (3D,audio 1.0) Stereo Extender Processing Unit Control Selectors */ #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_PU_ST_EXT_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_ST_EXT_WIDTH_CONTROL (0x02U) #define USB_DEVICE_AUDIO_PU_ST_EXT_UNDERFLOW_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_ST_EXT_OVERFLOW_CONTROL (0x04U) #define USB_DEVICE_AUDIO_PU_ST_EXT_LATENCY_CONTROL (0x05U) #else #define USB_DEVICE_AUDIO_PU_3D_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_SPACIOUSNESS_CONTROL (0x03U) #endif #if (!USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* USB audio 1.0 */ /*! @brief Commands for USB device AUDIO control Reverberation Processing Unit Control Selectors */ #define USB_DEVICE_AUDIO_PU_RV_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_RV_LEVEL_CONTROL (0x02U) #define USB_DEVICE_AUDIO_PU_RV_TIME_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_RV_FEEDBACK_CONTROL (0x04U) /*! @brief Commands for USB device AUDIO control Chorus Processing Unit Control Selectors */ #define USB_DEVICE_AUDIO_PU_CH_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_CH_LEVEL_CONTROL (0x02U) #define USB_DEVICE_AUDIO_PU_CH_RATE_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_CH_DEPTH_CONTROL (0x04U) /*! @brief Commands for USB device AUDIO control Dynamic Range Compressor Processing Unit Control Selectors */ #define USB_DEVICE_AUDIO_PU_DR_ENABLE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_PU_DR_COMPRESSION_RATE_CONTROL (0x02U) #define USB_DEVICE_AUDIO_PU_DR_MAXAMPL_CONTROL (0x03U) #define USB_DEVICE_AUDIO_PU_DR_THRESHOLD_CONTROL (0x04U) #define USB_DEVICE_AUDIO_PU_DR_ATTACK_TIME (0x05U) #define USB_DEVICE_AUDIO_PU_DR_RELEASE_TIME (0x06U) #endif #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /*! @brief Commands for USB device AUDIO control clock source control selector */ #define USB_DEVICE_AUDIO_CS_CONTROL_UNDEFINED (0x00U) #define USB_DEVICE_AUDIO_CS_SAM_FREQ_CONTROL_SELECTOR (0x01U) #define USB_DEVICE_AUDIO_CS_CLOCK_VALID_CONTROL_SELECTOR (0x02U) /*! @brief Commands for USB device AUDIO control clock selector control selector */ #define USB_DEVICE_AUDIO_CX_CONTROL_UNDEFINED (0x00U) #define USB_DEVICE_AUDIO_CX_CLOCK_SELECTOR_CONTROL_SELECTOR (0x01U) /*! @brief Commands for USB device AUDIO control clock multiplier control selector */ #define USB_DEVICE_AUDIO_CM_CONTROL_UNDEFINED (0x00U) #define USB_DEVICE_AUDIO_CM_NUMERATOR_CONTROL_SELECTOR (0x01U) #define USB_DEVICE_AUDIO_CM_DENOMINATOR_CONTROL_SELECTOR (0x02U) #endif #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /*! @brief Commands for USB device AUDIO streaming Interface Control Selectors */ #define USB_DEVICE_AUDIO_AS_ACT_ALT_SETTING_CONTROL (0x01U) #define USB_DEVICE_AUDIO_AS_VAL_ALT_SETTINGS_CONTROL (0x02U) #define USB_DEVICE_AUDIO_AS_AUDIO_DATA_FORMAT_CONTROL (0x03U) /*! @brief Commands for USB device AUDIO streaming Encoder control selector */ #define USB_DEVICE_AUDIO_EN_BIT_RATE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_EN_QUALITY_CONTROL (0x02U) #define USB_DEVICE_AUDIO_EN_VBR_CONTROL (0x03U) #define USB_DEVICE_AUDIO_EN_TYPE_CONTROL (0x04U) #define USB_DEVICE_AUDIO_EN_UNDERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_EN_OVERFLOW_CONTROL (0x06U) #define USB_DEVICE_AUDIO_EN_ENCODER_ERROR_CONTROL (0x07U) #define USB_DEVICE_AUDIO_EN_PARAM1_CONTROL (0x08U) #define USB_DEVICE_AUDIO_EN_PARAM2_CONTROL (0x09U) #define USB_DEVICE_AUDIO_EN_PARAM3_CONTROL (0x0AU) #define USB_DEVICE_AUDIO_EN_PARAM4_CONTROL (0x0BU) #define USB_DEVICE_AUDIO_EN_PARAM5_CONTROL (0x0CU) #define USB_DEVICE_AUDIO_EN_PARAM6_CONTROL (0x0DU) #define USB_DEVICE_AUDIO_EN_PARAM7_CONTROL (0x0EU) #define USB_DEVICE_AUDIO_EN_PARAM8_CONTROL (0x0FU) /*! @brief Commands for USB device AUDIO streaming MPEG Decoder control selector */ #define USB_DEVICE_AUDIO_MD_DUAL_CHANNEL_CONTROL (0x01U) #define USB_DEVICE_AUDIO_MD_SECOND_STEREO_CONTROL (0x02U) #define USB_DEVICE_AUDIO_MD_MULTILINGUAL_CONTROL (0x03U) #define USB_DEVICE_AUDIO_MD_DYN_RANGE_CONTROL (0x04U) #define USB_DEVICE_AUDIO_MD_SCALING_CONTROL (0x05U) #define USB_DEVICE_AUDIO_MD_HILO_SCALING_CONTROL (0x06U) #define USB_DEVICE_AUDIO_MD_UNDERFLOW_CONTROL (0x07U) #define USB_DEVICE_AUDIO_MD_OVERFLOW_CONTROL (0x08U) #define USB_DEVICE_AUDIO_MD_DECODER_ERROR_CONTROL (0x09U) /*! @brief Commands for USB device AUDIO streaming AC-3 Decoder Control Selectors */ #define USB_DEVICE_AUDIO_AD_MODE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_AD_DYN_RANGE_CONTROL (0x02U) #define USB_DEVICE_AUDIO_AD_SCALING_CONTROL (0x03U) #define USB_DEVICE_AUDIO_AD_HILO_SCALING_CONTROLL (0x04U) #define USB_DEVICE_AUDIO_AD_UNDERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_AD_OVERFLOW_CONTROL (0x06U) #define USB_DEVICE_AUDIO_AD_DECODER_ERROR_CONTROL (0x07U) /*! @brief Commands for USB device AUDIO streaming WMA Decoder Control Selectors */ #define USB_DEVICE_AUDIO_WD_UNDERFLOW_CONTROL (0x01U) #define USB_DEVICE_AUDIO_WD_OVERFLOW_CONTROL (0x02U) #define USB_DEVICE_AUDIO_WD_DECODER_ERROR_CONTROL (0x03U) /*! @brief Commands for USB device AUDIO streaming DTS Decoder Control Selectors */ #define USB_DEVICE_AUDIO_DD_UNDERFLOW_CONTROL (0x01U) #define USB_DEVICE_AUDIO_DD_OVERFLOW_CONTROL (0x02U) #define USB_DEVICE_AUDIO_DD_DECODER_ERROR_CONTROL (0x03U) #endif #if (!USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* USB audio 1.0 */ /*! @brief Commands for USB device AUDIO streaming MPEG control selector */ #define USB_DEVICE_AUDIO_MP_DUAL_CHANNEL_CONTROL (0x01U) #define USB_DEVICE_AUDIO_MP_SECOND_STEREO_CONTROL (0x02U) #define USB_DEVICE_AUDIO_MP_MULTILINGUAL_CONTROL (0x03U) #define USB_DEVICE_AUDIO_MP_DYN_RANGE_CONTROL (0x04U) #define USB_DEVICE_AUDIO_MP_SCALING_CONTROL (0x05U) #define USB_DEVICE_AUDIO_MP_HILO_SCALING_CONTROL (0x06U) /*! @brief Commands for USB device AUDIO streaming AC-3 Control Selectors */ #define USB_DEVICE_AUDIO_AC_MODE_CONTROL (0x01U) #define USB_DEVICE_AUDIO_AC_DYN_RANGE_CONTRO (0x02U) #define USB_DEVICE_AUDIO_AC_SCALING_CONTROL (0x03U) #define USB_DEVICE_AUDIO_AC_HILO_SCALING_CONTROL (0x04U) #endif /*! @brief Commands for USB device AUDIO streaming endpoint control selector */ #define USB_DEVICE_AUDIO_EP_CONTROL_UNDEFINED (0x00U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_EP_PITCH_CONTROL_SELECTOR_AUDIO20 (0x01U) #define USB_DEVICE_AUDIO_EP_DATA_OVERRUN_CONTROL_SELECTOR (0x02U) #define USB_DEVICE_AUDIO_EP_DATA_UNDERRUN_CONTROL_SELECTOR (0x03U) #else #define USB_DEVICE_AUDIO_EP_SAMPLING_FREQ_CONTROL_SELECTOR (0x01U) #define USB_DEVICE_AUDIO_EP_PITCH_CONTROL_SELECTOR (0x02U) #endif /* Commands for USB device AUDIO terminal control selector */ #define USB_DEVICE_AUDIO_TE_CONTROL_UNDEFINED (0x00U) #define USB_DEVICE_AUDIO_TE_COPY_PROTECT_CONTROL (0x01U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_TE_CONNECTOR_CONTROL (0x02U) #define USB_DEVICE_AUDIO_TE_OVERLOAD_CONTROL (0x03U) #define USB_DEVICE_AUDIO_TE_CLUSTER_CONTROL (0x04U) #define USB_DEVICE_AUDIO_TE_UNDERFLOW_CONTROL (0x05U) #define USB_DEVICE_AUDIO_TE_OVERFLOW_CONTROL (0x06U) #define USB_DEVICE_AUDIO_TE_LATENCY_CONTROL (0x07U) #endif /*! @brief Audio device class-specific FU GET CUR COMMAND */ #define USB_DEVICE_AUDIO_FU_GET_CUR_MUTE_CONTROL (0x8101U) #define USB_DEVICE_AUDIO_FU_GET_CUR_VOLUME_CONTROL (0x8102U) #define USB_DEVICE_AUDIO_FU_GET_CUR_BASS_CONTROL (0x8103U) #define USB_DEVICE_AUDIO_FU_GET_CUR_MID_CONTROL (0x8104U) #define USB_DEVICE_AUDIO_FU_GET_CUR_TREBLE_CONTROL (0x8105U) #define USB_DEVICE_AUDIO_FU_GET_CUR_GRAPHIC_EQUALIZER_CONTROL (0x8106U) #define USB_DEVICE_AUDIO_FU_GET_CUR_AUTOMATIC_GAIN_CONTROL (0x8107U) #define USB_DEVICE_AUDIO_FU_GET_CUR_DELAY_CONTROL (0x8108U) #define USB_DEVICE_AUDIO_FU_GET_CUR_BASS_BOOST_CONTROL (0x8109U) #define USB_DEVICE_AUDIO_FU_GET_CUR_LOUDNESS_CONTROL (0x810AU) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_FU_GET_CUR_UNDERFLOW_CONTROL (0x810EU) #define USB_DEVICE_AUDIO_FU_GET_CUR_OVERFLOW_CONTROL (0x810FU) #endif /*! @brief Audio device class-specific FU GET MIN COMMAND */ #define USB_DEVICE_AUDIO_FU_GET_MIN_VOLUME_CONTROL (0x8202U) #define USB_DEVICE_AUDIO_FU_GET_MIN_BASS_CONTROL (0x8203U) #define USB_DEVICE_AUDIO_FU_GET_MIN_MID_CONTROL (0x8204U) #define USB_DEVICE_AUDIO_FU_GET_MIN_TREBLE_CONTROL (0x8205U) #define USB_DEVICE_AUDIO_FU_GET_MIN_GRAPHIC_EQUALIZER_CONTROL (0x8206U) #define USB_DEVICE_AUDIO_FU_GET_MIN_DELAY_CONTROL (0x8208U) /*! @brief Audio device class-specific FU GET MAX COMMAND */ #define USB_DEVICE_AUDIO_FU_GET_MAX_VOLUME_CONTROL (0x8302U) #define USB_DEVICE_AUDIO_FU_GET_MAX_BASS_CONTROL (0x8303U) #define USB_DEVICE_AUDIO_FU_GET_MAX_MID_CONTROL (0x8304U) #define USB_DEVICE_AUDIO_FU_GET_MAX_TREBLE_CONTROL (0x8305U) #define USB_DEVICE_AUDIO_FU_GET_MAX_GRAPHIC_EQUALIZER_CONTROL (0x8306U) #define USB_DEVICE_AUDIO_FU_GET_MAX_DELAY_CONTROL (0x8308U) /*! @brief Audio device class-specific FU GET RES COMMAND */ #define USB_DEVICE_AUDIO_FU_GET_RES_VOLUME_CONTROL (0x8402U) #define USB_DEVICE_AUDIO_FU_GET_RES_BASS_CONTROL (0x8403U) #define USB_DEVICE_AUDIO_FU_GET_RES_MID_CONTROL (0x8404U) #define USB_DEVICE_AUDIO_FU_GET_RES_TREBLE_CONTROL (0x8405U) #define USB_DEVICE_AUDIO_FU_GET_RES_GRAPHIC_EQUALIZER_CONTROL (0x8406U) #define USB_DEVICE_AUDIO_FU_GET_RES_DELAY_CONTROL (0x8408U) /*! @brief Audio device class-specific FU SET CUR COMMAND */ #define USB_DEVICE_AUDIO_FU_SET_CUR_MUTE_CONTROL (0x0101U) #define USB_DEVICE_AUDIO_FU_SET_CUR_VOLUME_CONTROL (0x0102U) #define USB_DEVICE_AUDIO_FU_SET_CUR_BASS_CONTROL (0x0103U) #define USB_DEVICE_AUDIO_FU_SET_CUR_MID_CONTROL (0x0104U) #define USB_DEVICE_AUDIO_FU_SET_CUR_TREBLE_CONTROL (0x0105U) #define USB_DEVICE_AUDIO_FU_SET_CUR_GRAPHIC_EQUALIZER_CONTROL (0x0106U) #define USB_DEVICE_AUDIO_FU_SET_CUR_AUTOMATIC_GAIN_CONTROL (0x0107U) #define USB_DEVICE_AUDIO_FU_SET_CUR_DELAY_CONTROL (0x0108U) #define USB_DEVICE_AUDIO_FU_SET_CUR_BASS_BOOST_CONTROL (0x0109U) #define USB_DEVICE_AUDIO_FU_SET_CUR_LOUDNESS_CONTROL (0x010AU) /*! @brief Audio device class-specific FU SET MIN COMMAND */ #define USB_DEVICE_AUDIO_FU_SET_MIN_VOLUME_CONTROL (0x0202U) #define USB_DEVICE_AUDIO_FU_SET_MIN_BASS_CONTROL (0x0203U) #define USB_DEVICE_AUDIO_FU_SET_MIN_MID_CONTROL (0x0204U) #define USB_DEVICE_AUDIO_FU_SET_MIN_TREBLE_CONTROL (0x0205U) #define USB_DEVICE_AUDIO_FU_SET_MIN_GRAPHIC_EQUALIZER_CONTROL (0x0206U) #define USB_DEVICE_AUDIO_FU_SET_MIN_DELAY_CONTROL (0x0208U) /*! @brief Audio device class-specific FU SET MAX COMMAND */ #define USB_DEVICE_AUDIO_FU_SET_MAX_VOLUME_CONTROL (0x0302U) #define USB_DEVICE_AUDIO_FU_SET_MAX_BASS_CONTROL (0x0303U) #define USB_DEVICE_AUDIO_FU_SET_MAX_MID_CONTROL (0x0304U) #define USB_DEVICE_AUDIO_FU_SET_MAX_TREBLE_CONTROL (0x0305U) #define USB_DEVICE_AUDIO_FU_SET_MAX_GRAPHIC_EQUALIZER_CONTROL (0x0306U) #define USB_DEVICE_AUDIO_FU_SET_MAX_DELAY_CONTROL (0x0308U) /*! @brief Audio device class-specific FU SET RES COMMAND */ #define USB_DEVICE_AUDIO_FU_SET_RES_VOLUME_CONTROL (0x0402U) #define USB_DEVICE_AUDIO_FU_SET_RES_BASS_CONTROL (0x0403U) #define USB_DEVICE_AUDIO_FU_SET_RES_MID_CONTROL (0x0404U) #define USB_DEVICE_AUDIO_FU_SET_RES_TREBLE_CONTROL (0x0405U) #define USB_DEVICE_AUDIO_FU_SET_RES_GRAPHIC_EQUALIZER_CONTROL (0x0406U) #define USB_DEVICE_AUDIO_FU_SET_RES_DELAY_CONTROL (0x0408U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* Audio 2.0 FU : the following application command value is started from ox20 \ */ /*! @brief Audio device class-specific ENDP SET CUR COMMAND */ #define USB_DEVICE_AUDIO_EP_SET_CUR_PITCH_CONTROL_AUDIO20 (0x0122U) /*! @brief Audio device class-specific ENDP GET CUR COMMAND */ #define USB_DEVICE_AUDIO_EP_GET_CUR_DATA_OVERRUN_CONTROL (0x8121U) #define USB_DEVICE_AUDIO_EP_GET_CUR_DATA_UNDERRUN_CONTROL (0x8122U) #else /*! @brief Audio device class-specific ENDP SET CUR COMMAND */ #define USB_DEVICE_AUDIO_EP_SET_CUR_PITCH_CONTROL (0x0120U) #define USB_DEVICE_AUDIO_EP_SET_CUR_SAMPLING_FREQ_CONTROL (0x0121U) /*! @brief Audio device class-specific ENDP SET MIN COMMAND */ #define USB_DEVICE_AUDIO_EP_SET_MIN_SAMPLING_FREQ_CONTROL (0x0220U) /*! @brief Audio device class-specific ENDP SET MAX COMMAND */ #define USB_DEVICE_AUDIO_EP_SET_MAX_SAMPLING_FREQ_CONTROL (0x0320U) /*! @brief Audio device class-specific ENDP SET RES COMMAND */ #define USB_DEVICE_AUDIO_EP_SET_RES_SAMPLING_FREQ_CONTROL (0x0420U) /*! @brief Audio device class-specific ENDP GET CUR COMMAND */ #define USB_DEVICE_AUDIO_EP_GET_CUR_SAMPLING_FREQ_CONTROL (0x8120U) /*! @brief Audio device class-specific ENDP GET MIN COMMAND */ #define USB_DEVICE_AUDIO_EP_GET_MIN_SAMPLING_FREQ_CONTROL (0x8220U) /*! @brief Audio device class-specific ENDP GET MAX COMMAND */ #define USB_DEVICE_AUDIO_EP_GET_MAX_SAMPLING_FREQ_CONTROL (0x8320U) /*! @brief Audio device class-specific ENDP GET RES COMMAND */ #define USB_DEVICE_AUDIO_EP_GET_RES_SAMPLING_FREQ_CONTROL (0x8420U) #endif #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* CS: the following application command value is started from ox30 */ /*! @brief Audio device class-specific CS SET CUR COMMAND */ #define USB_DEVICE_AUDIO_CS_SET_CUR_SAMPLING_FREQ_CONTROL (0x0130U) #define USB_DEVICE_AUDIO_CS_SET_CUR_CLOCK_VALID_CONTROL (0x0131U) /*! @brief Audio device class-specific CS GET CUR COMMAND */ #define USB_DEVICE_AUDIO_CS_GET_CUR_SAMPLING_FREQ_CONTROL (0x8130U) #define USB_DEVICE_AUDIO_CS_GET_CUR_CLOCK_VALID_CONTROL (0x8131U) /*! @brief Audio device class-specific CS GET RANGE COMMAND */ #define USB_DEVICE_AUDIO_CS_GET_RANGE_SAMPLING_FREQ_CONTROL (0x8630U) #endif #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) /* Audio 2.0 FU : the following application command value is started from ox40 \ */ /*! @brief Audio device class-specific GET RANGE COMMAND */ #define USB_DEVICE_AUDIO_FU_GET_RANGE_VOLUME_CONTROL (0x8640U) #endif /* Terminal : the following application command value is started from ox50 */ /*! @brief Audio device class-specific TE GET CUR COMMAND */ #define USB_DEVICE_AUDIO_TE_GET_CUR_COPY_PROTECT_CONTROL (0x8150U) /*! @brief Audio device class-specific TE SET CUR COMMAND */ #define USB_DEVICE_AUDIO_TE_SET_CUR_COPY_PROTECT_CONTROL (0x0150U) #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) #define USB_DEVICE_AUDIO_TE_GET_CUR_CONNECTOR_CONTROL (0x8151U) #define USB_DEVICE_AUDIO_TE_GET_CUR_OVERLOAD_CONTROL (0x8152U) #endif /*! @}*/ /*! * @name USB Audio class setup request types * @{ */ /*! @brief Audio device class setup request set type */ #define USB_DEVICE_AUDIO_SET_REQUEST_INTERFACE (0x21U) #define USB_DEVICE_AUDIO_SET_REQUEST_ENDPOINT (0x22U) /*! @brief Audio device class setup request get type */ #define USB_DEVICE_AUDIO_GET_REQUEST_INTERFACE (0xA1U) #define USB_DEVICE_AUDIO_GET_REQUEST_ENDPOINT (0xA2U) /*! @}*/ /*! @brief Available common EVENT types in audio class callback */ typedef enum { kUSB_DeviceAudioEventStreamSendResponse = 0x01U, /*!< Send data completed or cancelled etc in stream pipe */ kUSB_DeviceAudioEventStreamRecvResponse, /*!< Data received or cancelled etc in stream pipe */ kUSB_DeviceAudioEventControlSendResponse, /*!< Send data completed or cancelled etc in audio control pipe */ } usb_device_audio_event_t; /*! * @brief The audio device class-specific information. * The structure is used to pass the audio entity information filled by application. * Such as * entity id (unit or terminal ID), * entity type (unit or terminal type), * and terminal type if the entity is a terminal. */ typedef struct _usb_device_audio_entity_struct { uint8_t entityId; uint8_t entityType; uint16_t terminalType; } usb_device_audio_entity_struct_t; /*! * @brief The audio device class-specific information list. * The structure is used to pass the audio entity informations filled by the application. * The type of each entity is usb_device_audio_entity_struct_t. * The structure pointer is kept in the usb_device_interface_struct_t::classSpecific, * such as, if there are three entities (an out terminal, camera terminal, and processing unit), * the value of the count field is 3 and the entity field saves the every entity information. */ typedef struct _usb_device_audio_entities_struct { usb_device_audio_entity_struct_t *entity; uint8_t count; } usb_device_audio_entities_struct_t; /*! @brief The audio device class status structure */ typedef struct _usb_device_audio_struct { usb_device_handle handle; /*!< The device handle */ usb_device_class_config_struct_t *configStruct; /*!< The configuration of the class. */ usb_device_interface_struct_t *controlInterfaceHandle; /*!< Current control interface handle */ usb_device_interface_struct_t *streamInterfaceHandle; /*!< Current stream interface handle */ uint8_t configuration; /*!< Current configuration */ uint8_t controlInterfaceNumber; /*!< The control interface number of the class */ uint8_t controlAlternate; /*!< Current alternate setting of the control interface */ uint8_t streamInterfaceNumber; /*!< The stream interface number of the class */ uint8_t streamAlternate; /*!< Current alternate setting of the stream interface */ uint8_t streamInPipeBusy; /*!< Stream IN pipe busy flag */ uint8_t streamOutPipeBusy; /*!< Stream OUT pipe busy flag */ } usb_device_audio_struct_t; #if (USB_DEVICE_CONFIG_AUDIO_CLASS_2_0) STRUCT_PACKED struct _usb_device_control_range_layout3_struct { uint16_t wNumSubRanges; uint32_t wMIN; uint32_t wMAX; uint32_t wRES; } STRUCT_UNPACKED; typedef struct _usb_device_control_range_layout3_struct usb_device_control_range_layout3_struct_t; STRUCT_PACKED struct _usb_device_control_range_layout2_struct { uint16_t wNumSubRanges; uint16_t wMIN; uint16_t wMAX; uint16_t wRES; } STRUCT_UNPACKED; typedef struct _usb_device_control_range_layout2_struct usb_device_control_range_layout2_struct_t; #endif /******************************************************************************* * API ******************************************************************************/ /*! * @name USB Audio Class Driver * @{ */ /*! * @brief Initializes the USB audio class. * * This function obtains a USB device handle according to the controller ID, initializes the audio class * with the class configuration parameters, and creates the mutex for each pipe. * * @param controllerId The ID of the controller. The value can be chosen from the kUSB_ControllerKhci0, * kUSB_ControllerKhci1, kUSB_ControllerEhci0, or kUSB_ControllerEhci1. * @param config The user configuration structure of type usb_device_class_config_struct_t. The user * populates the members of this structure and passes the pointer of this structure * into this function. * @param handle An out parameter. The class handle of the audio class. * @return A USB error code or kStatus_USB_Success. * @retval kStatus_USB_Success The audio class is initialized successfully. * @retval kStatus_USB_Busy No audio device handle available for allocation. * @retval kStatus_USB_InvalidHandle The audio device handle allocation failure. * @retval kStatus_USB_InvalidParameter The USB device handle allocation failure. */ extern usb_status_t USB_DeviceAudioInit(uint8_t controllerId, usb_device_class_config_struct_t *config, class_handle_t *handle); /*! * @brief Deinitializes the USB audio class. * * This function destroys the mutex for each pipe, deinitializes each endpoint of the audio class, and frees * the audio class handle. * * @param handle The class handle of the audio class. * @return A USB error code or kStatus_USB_Success. * @retval kStatus_USB_Success The audio class is deinitialized successfully. * @retval kStatus_USB_Error The endpoint deinitialization failure. * @retval kStatus_USB_InvalidHandle The audio device handle or the audio class handle is invalid. * @retval kStatus_USB_InvalidParameter The endpoint number of the audio class handle is invalid. */ extern usb_status_t USB_DeviceAudioDeinit(class_handle_t handle); /*! * @brief Handles the USB audio class event. * * This function responds to various events including the common device events and the class-specific events. * For class-specific events, it calls the class callback defined in the application to deal with the class-specific * event. * * @param handle The class handle of the audio class. * @param event The event type. * @param param The class handle of the audio class. * @return A USB error code or kStatus_USB_Success. * @retval kStatus_USB_Success The audio class is deinitialized successfully. * @retval kStatus_USB_Error The configure structure of the audio class handle is invalid. * @retval kStatus_USB_InvalidHandle The audio device handle or the audio class handle is invalid. * @retval kStatus_USB_InvalidParameter The endpoint number of the audio class handle is invalid. * @retval Others The error code returned by class callback in application. */ extern usb_status_t USB_DeviceAudioEvent(void *handle, uint32_t event, void *param); /*! * @brief Primes the endpoint to send a packet to the host. * * This function checks whether the endpoint is sending packet, then it primes the endpoint * with the buffer address and the buffer length if the pipe is not busy. Otherwise, it ignores this transfer by * returning an error code. * * @param handle The class handle of the audio class. * @param ep The endpoint number of the transfer. * @param buffer The pointer to the buffer to be transferred. * @param length The length of the buffer to be transferred. * @return A USB error code or kStatus_USB_Success. * @retval kStatus_USB_Success Prime to send packet successfully. * @retval kStatus_USB_Busy The endpoint is busy in transferring. * @retval kStatus_USB_InvalidHandle The audio device handle or the audio class handle is invalid. * @retval kStatus_USB_ControllerNotFound The controller interface is invalid. * * @note The function can only be called in the same context. */ extern usb_status_t USB_DeviceAudioSend(class_handle_t handle, uint8_t ep, uint8_t *buffer, uint32_t length); /*! * @brief Primes the endpoint to receive a packet from the host. * * This function checks whether the endpoint is receiving packet, then it primes the endpoint * with the buffer address and the buffer length if the pipe is not busy. Otherwise, it ignores this transfer by * returning an error code. * * @param handle The class handle of the audio class. * @param ep The endpoint number of the transfer. * @param buffer The pointer to the buffer to be transferred. * @param length The length of the buffer to be transferred. * @return A USB error code or kStatus_USB_Success. * @retval kStatus_USB_Success Prime to receive packet successfully. * @retval kStatus_USB_Busy The endpoint is busy in transferring. * @retval kStatus_USB_InvalidHandle The audio device handle or the audio class handle is invalid. * @retval kStatus_USB_ControllerNotFound The controller interface is invalid. * * @note The function can only be called in the same context. */ extern usb_status_t USB_DeviceAudioRecv(class_handle_t handle, uint8_t ep, uint8_t *buffer, uint32_t length); /*! @}*/ /*! @}*/ #endif /* __USB_DEVICE_AUDIO_H__ */