Merge pull request #938 from HiFiPhile/uac_example
Bug fix and Enhancements of UAC2
This commit is contained in:
		| @@ -489,7 +489,7 @@ typedef enum | ||||
|   AUDIO_DATA_FORMAT_TYPE_I_IEEE_FLOAT     = (uint32_t) (1 << 2), | ||||
|   AUDIO_DATA_FORMAT_TYPE_I_ALAW           = (uint32_t) (1 << 3), | ||||
|   AUDIO_DATA_FORMAT_TYPE_I_MULAW          = (uint32_t) (1 << 4), | ||||
|   AUDIO_DATA_FORMAT_TYPE_I_RAW_DATA       = 0x100000000, | ||||
|   AUDIO_DATA_FORMAT_TYPE_I_RAW_DATA       = 0x80000000, | ||||
| } audio_data_format_type_I_t; | ||||
|  | ||||
| /// All remaining definitions are taken from the descriptor descriptions in the UAC2 main specification | ||||
| @@ -823,6 +823,33 @@ typedef struct TU_ATTR_PACKED | ||||
|   uint16_t wLockDelay        ; ///< Indicates the time it takes this endpoint to reliably lock its internal clock recovery circuitry. Units used depend on the value of the bLockDelayUnits field. | ||||
| } audio_desc_cs_as_iso_data_ep_t; | ||||
|  | ||||
| // 5.2.2 Control Request Layout | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|     union | ||||
|     { | ||||
|         struct TU_ATTR_PACKED | ||||
|         { | ||||
|             uint8_t recipient :  5; ///< Recipient type tusb_request_recipient_t. | ||||
|             uint8_t type      :  2; ///< Request type tusb_request_type_t. | ||||
|             uint8_t direction :  1; ///< Direction type. tusb_dir_t | ||||
|         } bmRequestType_bit; | ||||
|          | ||||
|         uint8_t bmRequestType; | ||||
|     }; | ||||
|      | ||||
|     uint8_t bRequest;  ///< Request type audio_cs_req_t | ||||
|     uint8_t bChannelNumber; | ||||
|     uint8_t bControlSelector; | ||||
|     union | ||||
|     { | ||||
|         uint8_t bInterface; | ||||
|         uint8_t bEndpoint; | ||||
|     }; | ||||
|     uint8_t bEntityID; | ||||
|     uint16_t wLength; | ||||
| } audio_control_request_t; | ||||
|  | ||||
| //// 5.2.3 Control Request Parameter Block Layout | ||||
|  | ||||
| // 5.2.3.1 1-byte Control CUR Parameter Block | ||||
|   | ||||
| @@ -102,19 +102,19 @@ | ||||
| // EP IN software buffers and mutexes | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_IN && !CFG_TUD_AUDIO_ENABLE_ENCODING | ||||
| #if CFG_TUD_AUDIO_FUNC_1_EP_IN_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_1[CFG_TUD_AUDIO_FUNC_1_EP_IN_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_1[CFG_TUD_AUDIO_FUNC_1_EP_IN_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_in_ff_mutex_wr_1;                                                             // No need for read mutex as only USB driver reads from FIFO | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO_FUNC_1_EP_IN_SW_BUF_SZ > 0 | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_IN_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_2[CFG_TUD_AUDIO_FUNC_2_EP_IN_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_2[CFG_TUD_AUDIO_FUNC_2_EP_IN_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_in_ff_mutex_wr_2;                                                             // No need for read mutex as only USB driver reads from FIFO | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_IN_SW_BUF_SZ > 0 | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_EP_IN_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_3[CFG_TUD_AUDIO_FUNC_3_EP_IN_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_in_sw_buf_3[CFG_TUD_AUDIO_FUNC_3_EP_IN_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_in_ff_mutex_wr_3;                                                             // No need for read mutex as only USB driver reads from FIFO | ||||
| #endif | ||||
| @@ -126,32 +126,32 @@ osal_mutex_def_t ep_in_ff_mutex_wr_3; | ||||
| // - the software encoding is used - in this case the linear buffers serve as a target memory where logical channels are encoded into | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_IN && (USE_LINEAR_BUFFER || CFG_TUD_AUDIO_ENABLE_ENCODING) | ||||
| #if CFG_TUD_AUDIO_FUNC_1_EP_IN_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_1[CFG_TUD_AUDIO_FUNC_1_EP_IN_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_1[CFG_TUD_AUDIO_FUNC_1_EP_IN_SZ_MAX]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_IN_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_2[CFG_TUD_AUDIO_FUNC_2_EP_IN_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_2[CFG_TUD_AUDIO_FUNC_2_EP_IN_SZ_MAX]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_EP_IN_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_3[CFG_TUD_AUDIO_FUNC_3_EP_IN_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_in_3[CFG_TUD_AUDIO_FUNC_3_EP_IN_SZ_MAX]; | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO_ENABLE_EP_IN && (USE_LINEAR_BUFFER || CFG_TUD_AUDIO_ENABLE_DECODING) | ||||
|  | ||||
| // EP OUT software buffers and mutexes | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_OUT && !CFG_TUD_AUDIO_ENABLE_DECODING | ||||
| #if CFG_TUD_AUDIO_FUNC_1_EP_OUT_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_1[CFG_TUD_AUDIO_FUNC_1_EP_OUT_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_1[CFG_TUD_AUDIO_FUNC_1_EP_OUT_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_out_ff_mutex_rd_1;                                                            // No need for write mutex as only USB driver writes into FIFO | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO_FUNC_1_EP_OUT_SW_BUF_SZ > 0 | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_OUT_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_2[CFG_TUD_AUDIO_FUNC_2_EP_OUT_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_2[CFG_TUD_AUDIO_FUNC_2_EP_OUT_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_out_ff_mutex_rd_2;                                                            // No need for write mutex as only USB driver writes into FIFO | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_OUT_SW_BUF_SZ > 0 | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_EP_OUT_SW_BUF_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_3[CFG_TUD_AUDIO_FUNC_3_EP_OUT_SW_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t audio_ep_out_sw_buf_3[CFG_TUD_AUDIO_FUNC_3_EP_OUT_SW_BUF_SZ]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t ep_out_ff_mutex_rd_3;                                                            // No need for write mutex as only USB driver writes into FIFO | ||||
| #endif | ||||
| @@ -163,52 +163,52 @@ osal_mutex_def_t ep_out_ff_mutex_rd_3; | ||||
| // - the software encoding is used - in this case the linear buffers serve as a target memory where logical channels are encoded into | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_OUT && (USE_LINEAR_BUFFER || CFG_TUD_AUDIO_ENABLE_DECODING) | ||||
| #if CFG_TUD_AUDIO_FUNC_1_EP_OUT_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_1[CFG_TUD_AUDIO_FUNC_1_EP_OUT_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_1[CFG_TUD_AUDIO_FUNC_1_EP_OUT_SZ_MAX]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_EP_OUT_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_2[CFG_TUD_AUDIO_FUNC_2_EP_OUT_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_2[CFG_TUD_AUDIO_FUNC_2_EP_OUT_SZ_MAX]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_EP_OUT_SZ_MAX > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_3[CFG_TUD_AUDIO_FUNC_3_EP_OUT_SZ_MAX]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t lin_buf_out_3[CFG_TUD_AUDIO_FUNC_3_EP_OUT_SZ_MAX]; | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO_ENABLE_EP_OUT && (USE_LINEAR_BUFFER || CFG_TUD_AUDIO_ENABLE_DECODING) | ||||
|  | ||||
| // Control buffers | ||||
| CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_1[CFG_TUD_AUDIO_FUNC_1_CTRL_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_1[CFG_TUD_AUDIO_FUNC_1_CTRL_BUF_SZ]; | ||||
| #if CFG_TUD_AUDIO > 1 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_2[CFG_TUD_AUDIO_FUNC_2_CTRL_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_2[CFG_TUD_AUDIO_FUNC_2_CTRL_BUF_SZ]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_3[CFG_TUD_AUDIO_FUNC_3_CTRL_BUF_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t ctrl_buf_3[CFG_TUD_AUDIO_FUNC_3_CTRL_BUF_SZ]; | ||||
| #endif | ||||
|  | ||||
| // Active alternate setting of interfaces | ||||
| CFG_TUSB_MEM_ALIGN uint8_t alt_setting_1[CFG_TUD_AUDIO_FUNC_1_N_AS_INT]; | ||||
| uint8_t alt_setting_1[CFG_TUD_AUDIO_FUNC_1_N_AS_INT]; | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_N_AS_INT > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t alt_setting_2[CFG_TUD_AUDIO_FUNC_2_N_AS_INT]; | ||||
| uint8_t alt_setting_2[CFG_TUD_AUDIO_FUNC_2_N_AS_INT]; | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_N_AS_INT > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t alt_setting_3[CFG_TUD_AUDIO_FUNC_3_N_AS_INT]; | ||||
| uint8_t alt_setting_3[CFG_TUD_AUDIO_FUNC_3_N_AS_INT]; | ||||
| #endif | ||||
|  | ||||
| // Software encoding/decoding support FIFOs | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_IN && CFG_TUD_AUDIO_ENABLE_ENCODING | ||||
| #if CFG_TUD_AUDIO_FUNC_1_TX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_1[CFG_TUD_AUDIO_FUNC_1_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_1_TX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_1[CFG_TUD_AUDIO_FUNC_1_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_1_TX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t tx_supp_ff_1[CFG_TUD_AUDIO_FUNC_1_N_TX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t tx_supp_ff_mutex_wr_1[CFG_TUD_AUDIO_FUNC_1_N_TX_SUPP_SW_FIFO];                   // No need for read mutex as only USB driver reads from FIFO | ||||
| #endif | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_TX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_2[CFG_TUD_AUDIO_FUNC_2_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_2_TX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_2[CFG_TUD_AUDIO_FUNC_2_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_2_TX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t tx_supp_ff_2[CFG_TUD_AUDIO_FUNC_2_N_TX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t tx_supp_ff_mutex_wr_2[CFG_TUD_AUDIO_FUNC_2_N_TX_SUPP_SW_FIFO];                   // No need for read mutex as only USB driver reads from FIFO | ||||
| #endif | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_TX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_3[CFG_TUD_AUDIO_FUNC_3_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_3_TX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t tx_supp_ff_buf_3[CFG_TUD_AUDIO_FUNC_3_N_TX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_3_TX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t tx_supp_ff_3[CFG_TUD_AUDIO_FUNC_3_N_TX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t tx_supp_ff_mutex_wr_3[CFG_TUD_AUDIO_FUNC_3_N_TX_SUPP_SW_FIFO];                   // No need for read mutex as only USB driver reads from FIFO | ||||
| @@ -218,21 +218,21 @@ osal_mutex_def_t tx_supp_ff_mutex_wr_3[CFG_TUD_AUDIO_FUNC_3_N_TX_SUPP_SW_FIFO]; | ||||
|  | ||||
| #if CFG_TUD_AUDIO_ENABLE_EP_OUT && CFG_TUD_AUDIO_ENABLE_DECODING | ||||
| #if CFG_TUD_AUDIO_FUNC_1_RX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_1[CFG_TUD_AUDIO_FUNC_1_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_1_RX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_1[CFG_TUD_AUDIO_FUNC_1_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_1_RX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t rx_supp_ff_1[CFG_TUD_AUDIO_FUNC_1_N_RX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t rx_supp_ff_mutex_rd_1[CFG_TUD_AUDIO_FUNC_1_N_RX_SUPP_SW_FIFO];                   // No need for write mutex as only USB driver writes into FIFO | ||||
| #endif | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 1 && CFG_TUD_AUDIO_FUNC_2_RX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_2[CFG_TUD_AUDIO_FUNC_2_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_2_RX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_2[CFG_TUD_AUDIO_FUNC_2_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_2_RX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t rx_supp_ff_2[CFG_TUD_AUDIO_FUNC_2_N_RX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t rx_supp_ff_mutex_rd_2[CFG_TUD_AUDIO_FUNC_2_N_RX_SUPP_SW_FIFO];                   // No need for write mutex as only USB driver writes into FIFO | ||||
| #endif | ||||
| #endif | ||||
| #if CFG_TUD_AUDIO > 2 && CFG_TUD_AUDIO_FUNC_3_RX_SUPP_SW_FIFO_SZ > 0 | ||||
| CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_3[CFG_TUD_AUDIO_FUNC_3_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_3_RX_SUPP_SW_FIFO_SZ]; | ||||
| CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t rx_supp_ff_buf_3[CFG_TUD_AUDIO_FUNC_3_N_RX_SUPP_SW_FIFO][CFG_TUD_AUDIO_FUNC_3_RX_SUPP_SW_FIFO_SZ]; | ||||
| tu_fifo_t rx_supp_ff_3[CFG_TUD_AUDIO_FUNC_3_N_RX_SUPP_SW_FIFO]; | ||||
| #if CFG_FIFO_MUTEX | ||||
| osal_mutex_def_t rx_supp_ff_mutex_rd_3[CFG_TUD_AUDIO_FUNC_3_N_RX_SUPP_SW_FIFO];                   // No need for write mutex as only USB driver writes into FIFO | ||||
| @@ -294,7 +294,7 @@ typedef struct | ||||
|  | ||||
|   // Audio control interrupt buffer - no FIFO - 6 Bytes according to UAC 2 specification (p. 74) | ||||
| #if CFG_TUD_AUDIO_INT_CTR_EPSIZE_IN | ||||
|   CFG_TUSB_MEM_ALIGN uint8_t ep_int_ctr_buf[CFG_TUD_AUDIO_INT_CTR_EP_IN_SW_BUFFER_SIZE]; | ||||
|   CFG_TUSB_MEM_SECTION CFG_TUSB_MEM_ALIGN uint8_t ep_int_ctr_buf[CFG_TUD_AUDIO_INT_CTR_EP_IN_SW_BUFFER_SIZE]; | ||||
| #endif | ||||
|  | ||||
|   // Decoding parameters - parameters are set when alternate AS interface is set by host | ||||
| @@ -643,7 +643,6 @@ static bool audiod_decode_type_I_pcm(uint8_t rhport, audiod_function_t* audio, u | ||||
|  | ||||
|   // Determine amount of samples | ||||
|   uint8_t const n_ff_used               = audio->n_ff_used_rx; | ||||
|   uint16_t const nBytesToCopy           = audio->n_channels_per_ff_rx * audio->n_bytes_per_sampe_rx; | ||||
|   uint16_t const nBytesPerFFToRead      = n_bytes_received / n_ff_used; | ||||
|   uint8_t cnt_ff; | ||||
|  | ||||
| @@ -662,14 +661,14 @@ static bool audiod_decode_type_I_pcm(uint8_t rhport, audiod_function_t* audio, u | ||||
|       info.len_lin = tu_min16(nBytesPerFFToRead, info.len_lin); | ||||
|       src = &audio->lin_buf_out[cnt_ff*audio->n_channels_per_ff_rx * audio->n_bytes_per_sampe_rx]; | ||||
|       dst_end = info.ptr_lin + info.len_lin; | ||||
|       src = audiod_interleaved_copy_bytes_fast_decode(nBytesToCopy, info.ptr_lin, dst_end, src, n_ff_used); | ||||
|       src = audiod_interleaved_copy_bytes_fast_decode(audio->n_bytes_per_sampe_rx, info.ptr_lin, dst_end, src, n_ff_used); | ||||
|  | ||||
|       // Handle wrapped part of FIFO | ||||
|       info.len_wrap = tu_min16(nBytesPerFFToRead - info.len_lin, info.len_wrap); | ||||
|       if (info.len_wrap != 0) | ||||
|       { | ||||
|         dst_end = info.ptr_wrap + info.len_wrap; | ||||
|         audiod_interleaved_copy_bytes_fast_decode(nBytesToCopy, info.ptr_wrap, dst_end, src, n_ff_used); | ||||
|         audiod_interleaved_copy_bytes_fast_decode(audio->n_bytes_per_sampe_rx, info.ptr_wrap, dst_end, src, n_ff_used); | ||||
|       } | ||||
|       tu_fifo_advance_write_pointer(&audio->rx_supp_ff[cnt_ff], info.len_lin + info.len_wrap); | ||||
|     } | ||||
| @@ -994,7 +993,7 @@ static uint16_t audiod_encode_type_I_pcm(uint8_t rhport, audiod_function_t* audi | ||||
|     { | ||||
|       info.len_lin = tu_min16(nBytesPerFFToSend, info.len_lin);       // Limit up to desired length | ||||
|       src_end = (uint8_t *)info.ptr_lin + info.len_lin; | ||||
|       dst = audiod_interleaved_copy_bytes_fast_encode(nBytesToCopy, info.ptr_lin, src_end, dst, n_ff_used); | ||||
|       dst = audiod_interleaved_copy_bytes_fast_encode(audio->n_bytes_per_sampe_tx, info.ptr_lin, src_end, dst, n_ff_used); | ||||
|  | ||||
|       // Limit up to desired length | ||||
|       info.len_wrap = tu_min16(nBytesPerFFToSend - info.len_lin, info.len_wrap); | ||||
| @@ -1003,7 +1002,7 @@ static uint16_t audiod_encode_type_I_pcm(uint8_t rhport, audiod_function_t* audi | ||||
|       if (info.len_wrap != 0) | ||||
|       { | ||||
|         src_end = (uint8_t *)info.ptr_wrap + info.len_wrap; | ||||
|         audiod_interleaved_copy_bytes_fast_encode(nBytesToCopy, info.ptr_wrap, src_end, dst, n_ff_used); | ||||
|         audiod_interleaved_copy_bytes_fast_encode(audio->n_bytes_per_sampe_tx, info.ptr_wrap, src_end, dst, n_ff_used); | ||||
|       } | ||||
|  | ||||
|       tu_fifo_advance_read_pointer(&audio->tx_supp_ff[cnt_ff], info.len_lin + info.len_wrap); | ||||
| @@ -1481,18 +1480,20 @@ static bool audiod_set_interface(uint8_t rhport, tusb_control_request_t const * | ||||
|     audio->ep_in_as_intf_num = 0; | ||||
|     usbd_edpt_close(rhport, audio->ep_in); | ||||
|  | ||||
|     // Invoke callback - can be used to stop data sampling | ||||
|     if (tud_audio_set_itf_close_EP_cb) TU_VERIFY(tud_audio_set_itf_close_EP_cb(rhport, p_request)); | ||||
|  | ||||
|     audio->ep_in = 0;                           // Necessary? | ||||
|  | ||||
|     // Clear support FIFOs if used | ||||
| #if CFG_TUD_AUDIO_ENABLE_ENCODING | ||||
|     // Clear FIFOs, since data is no longer valid | ||||
| #if !CFG_TUD_AUDIO_ENABLE_ENCODING | ||||
|     tu_fifo_clear(&audio->ep_in_ff); | ||||
| #else | ||||
|     for (uint8_t cnt = 0; cnt < audio->n_tx_supp_ff; cnt++) | ||||
|     { | ||||
|       tu_fifo_clear(&audio->tx_supp_ff[cnt]); | ||||
|     } | ||||
| #endif | ||||
|      | ||||
|     // Invoke callback - can be used to stop data sampling | ||||
|     if (tud_audio_set_itf_close_EP_cb) TU_VERIFY(tud_audio_set_itf_close_EP_cb(rhport, p_request)); | ||||
|  | ||||
|     audio->ep_in = 0;                           // Necessary? | ||||
|  | ||||
|   } | ||||
| #endif | ||||
| @@ -1502,16 +1503,22 @@ static bool audiod_set_interface(uint8_t rhport, tusb_control_request_t const * | ||||
|   { | ||||
|     audio->ep_out_as_intf_num = 0; | ||||
|     usbd_edpt_close(rhport, audio->ep_out); | ||||
|     audio->ep_out = 0;                          // Necessary? | ||||
|  | ||||
|     // Clear support FIFOs if used | ||||
| #if CFG_TUD_AUDIO_ENABLE_DECODING | ||||
|     // Clear FIFOs, since data is no longer valid | ||||
| #if !CFG_TUD_AUDIO_ENABLE_DECODING | ||||
|     tu_fifo_clear(&audio->ep_out_ff); | ||||
| #else | ||||
|     for (uint8_t cnt = 0; cnt < audio->n_rx_supp_ff; cnt++) | ||||
|     { | ||||
|       tu_fifo_clear(&audio->rx_supp_ff[cnt]); | ||||
|     } | ||||
| #endif | ||||
|  | ||||
|     // Invoke callback - can be used to stop data sampling | ||||
|     if (tud_audio_set_itf_close_EP_cb) TU_VERIFY(tud_audio_set_itf_close_EP_cb(rhport, p_request)); | ||||
|  | ||||
|     audio->ep_out = 0;                          // Necessary? | ||||
|  | ||||
|     // Close corresponding feedback EP | ||||
| #if CFG_TUD_AUDIO_ENABLE_FEEDBACK_EP | ||||
|     usbd_edpt_close(rhport, audio->ep_fb); | ||||
| @@ -1605,9 +1612,17 @@ static bool audiod_set_interface(uint8_t rhport, tusb_control_request_t const * | ||||
|             TU_ASSERT( audio->n_ff_used_rx <= audio->n_rx_supp_ff ); | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #if CFG_TUD_AUDIO_ENABLE_FEEDBACK_EP | ||||
|             // In case of asynchronous EP, call Cb after ep_fb is set | ||||
|             if (!(((tusb_desc_endpoint_t const *) p_desc)->bmAttributes.sync == 0x01 && audio->ep_fb == 0)) | ||||
|             { | ||||
|               if (tud_audio_set_itf_cb) TU_VERIFY(tud_audio_set_itf_cb(rhport, p_request)); | ||||
|             } | ||||
| #else | ||||
|             // Invoke callback | ||||
|             if (tud_audio_set_itf_cb) TU_VERIFY(tud_audio_set_itf_cb(rhport, p_request)); | ||||
|  | ||||
| #endif | ||||
|             // Prepare for incoming data | ||||
| #if USE_LINEAR_BUFFER_RX | ||||
|             TU_VERIFY(usbd_edpt_xfer(rhport, audio->ep_out, audio->lin_buf_out, audio->ep_out_sz), false); | ||||
| @@ -1621,8 +1636,11 @@ static bool audiod_set_interface(uint8_t rhport, tusb_control_request_t const * | ||||
|           { | ||||
|             audio->ep_fb = ep_addr; | ||||
|  | ||||
|             // Invoke callback | ||||
|             if (tud_audio_set_itf_cb) TU_VERIFY(tud_audio_set_itf_cb(rhport, p_request)); | ||||
|             // Invoke callback after ep_out is set | ||||
|             if (audio->ep_out != 0) | ||||
|             { | ||||
|               if (tud_audio_set_itf_cb) TU_VERIFY(tud_audio_set_itf_cb(rhport, p_request)); | ||||
|             } | ||||
|           } | ||||
| #endif | ||||
| #endif // CFG_TUD_AUDIO_ENABLE_EP_OUT | ||||
| @@ -1916,8 +1934,12 @@ bool audiod_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint3 | ||||
|     { | ||||
|       if (tud_audio_fb_done_cb) TU_VERIFY(tud_audio_fb_done_cb(rhport)); | ||||
|  | ||||
|       // Schedule next transmission - value is changed bytud_audio_n_fb_set() in the meantime or the old value gets sent | ||||
|       return audiod_fb_send(rhport, &_audiod_fct[func_id]); | ||||
|       // Schedule a transmit with the new value if EP is not busy  | ||||
|       if (!usbd_edpt_busy(rhport, _audiod_fct[func_id].ep_fb)) | ||||
|       { | ||||
|         // Schedule next transmission - value is changed bytud_audio_n_fb_set() in the meantime or the old value gets sent | ||||
|         return audiod_fb_send(rhport, &_audiod_fct[func_id]); | ||||
|       } | ||||
|     } | ||||
| #endif | ||||
| #endif | ||||
| @@ -1997,15 +2019,17 @@ static bool audiod_get_AS_interface_index(uint8_t itf, audiod_function_t * audio | ||||
|     while (p_desc < p_desc_end) | ||||
|     { | ||||
|       // We assume the number of alternate settings is increasing thus we return the index of alternate setting zero! | ||||
|       if (tu_desc_type(p_desc) == TUSB_DESC_INTERFACE && ((tusb_desc_interface_t const * )p_desc)->bInterfaceNumber == itf) | ||||
|       if (tu_desc_type(p_desc) == TUSB_DESC_INTERFACE && ((tusb_desc_interface_t const * )p_desc)->bAlternateSetting == 0) | ||||
|       { | ||||
|         *idxItf = tmp; | ||||
|         *pp_desc_int = p_desc; | ||||
|         return true; | ||||
|         if (((tusb_desc_interface_t const * )p_desc)->bInterfaceNumber == itf) | ||||
|         { | ||||
|           *idxItf = tmp; | ||||
|           *pp_desc_int = p_desc; | ||||
|           return true; | ||||
|         } | ||||
|         // Increase index, bytes read, and pointer | ||||
|         tmp++; | ||||
|       } | ||||
|  | ||||
|       // Increase index, bytes read, and pointer | ||||
|       tmp++; | ||||
|       p_desc = tu_desc_next(p_desc); | ||||
|     } | ||||
|   } | ||||
| @@ -2207,22 +2231,19 @@ bool tud_audio_n_fb_set(uint8_t func_id, uint32_t feedback) | ||||
|   TU_VERIFY(func_id < CFG_TUD_AUDIO && _audiod_fct[func_id].p_desc != NULL); | ||||
|  | ||||
|   // Format the feedback value | ||||
|   if (_audiod_fct[func_id].rhport == 0) | ||||
|   { | ||||
|     uint8_t * fb = (uint8_t *) &_audiod_fct[func_id].fb_val; | ||||
| #if !TUD_OPT_HIGH_SPEED | ||||
|   uint8_t * fb = (uint8_t *) &_audiod_fct[func_id].fb_val; | ||||
|  | ||||
|     // For FS format is 10.14 | ||||
|     *(fb++) = (feedback >> 2) & 0xFF; | ||||
|     *(fb++) = (feedback >> 10) & 0xFF; | ||||
|     *(fb++) = (feedback >> 18) & 0xFF; | ||||
|     // 4th byte is needed to work correctly with MS Windows | ||||
|     *fb = 0; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     // For HS format is 16.16 as originally demanded | ||||
|     _audiod_fct[func_id].fb_val = feedback; | ||||
|   } | ||||
|   // For FS format is 10.14 | ||||
|   *(fb++) = (feedback >> 2) & 0xFF; | ||||
|   *(fb++) = (feedback >> 10) & 0xFF; | ||||
|   *(fb++) = (feedback >> 18) & 0xFF; | ||||
|   // 4th byte is needed to work correctly with MS Windows | ||||
|   *fb = 0; | ||||
| #else | ||||
|   // For HS format is 16.16 as originally demanded | ||||
|   _audiod_fct[func_id].fb_val = feedback; | ||||
| #endif | ||||
|  | ||||
|   // Schedule a transmit with the new value if EP is not busy - this triggers repetitive scheduling of the feedback value | ||||
|   if (!usbd_edpt_busy(_audiod_fct[func_id].rhport, _audiod_fct[func_id].ep_fb)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Ha Thach
					Ha Thach