4#if defined(ESP32) && !USE_LEGACY_I2S || defined(DOXYGEN)
8#include "driver/i2s_pdm.h"
9#include "driver/i2s_std.h"
10#include "driver/i2s_tdm.h"
11#include "esp_system.h"
13#define IS_I2S_IMPLEMENTED
18#if ESP_IDF_VERSION >= ESP_IDF_VERSION_VAL(6, 0, 0)
23#if ESP_IDF_VERSION <= ESP_IDF_VERSION_VAL(5, 1, 4)
24#define I2S_MCLK_MULTIPLE_192 static_cast<i2s_mclk_multiple_t>(192)
85 LOGE(
"Did not expect go get here");
195 LOGE(
"i2s_channel_init_std_mode %s",
"tx");
199 LOGE(
"i2s_channel_enable %s",
"tx");
206 LOGE(
"i2s_channel_init_std_mode %s",
"rx");
210 LOGE(
"i2s_channel_enable %s",
"rx");
251 LOGW(
"Using channel_format: I2SChannelSelect::Left for mono");
268 frame_size = (frame_size == 0) ? 1 : frame_size;
269 if (size > 0) result.dma_frame_num = size / frame_size;
270 LOGI(
"dma_frame_num: %d", (
int)result.dma_frame_num);
291 LOGI(
"mclk_multiple=384");
308#if SOC_I2S_HW_VERSION_2
309 LOGI(
"pin_mclk is input");
313 LOGE(
"pin_mclk as input not supported");
320#if SOC_I2S_SUPPORTS_APLL
322 LOGI(
"clk_src is I2S_CLK_SRC_APLL");
323#elif SOC_I2S_SUPPORTS_PLL_F160M
325 LOGI(
"clk_src is I2S_CLK_SRC_PLL_160M");
355 i2s_chan_handle_t &rx_chan,
int txPin,
int rxPin) {
357 return startTX(cfg, tx_chan, txPin);
359 return startRX(cfg, rx_chan, rxPin);
361 LOGE(
"Only RX and TX is supported for PDM")
366 i2s_pdm_tx_slot_config_t getTxSlotConfig(I2SConfigESP32V1 &cfg) {
367#ifdef SOC_I2S_HW_VERSION_2
368 return I2S_PDM_TX_SLOT_DAC_DEFAULT_CONFIG(
369 (i2s_data_bit_width_t)cfg.bits_per_sample,
370 (i2s_slot_mode_t)cfg.channels);
372 return I2S_PDM_TX_SLOT_DEFAULT_CONFIG(
373 (i2s_data_bit_width_t)cfg.bits_per_sample,
374 (i2s_slot_mode_t)cfg.channels);
378 i2s_chan_config_t getChannelConfig(I2SConfigESP32V1 &cfg) {
379 return I2S_CHANNEL_DEFAULT_CONFIG(
380 (i2s_port_t)cfg.port_no,
381 cfg.is_master ? I2S_ROLE_MASTER : I2S_ROLE_SLAVE);
384 i2s_pdm_tx_clk_config_t getTxClockConfig(I2SConfigESP32V1 &cfg) {
385#if defined(I2S_PDM_TX_CLK_DAC_DEFAULT_CONFIG)
386 return I2S_PDM_TX_CLK_DAC_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
388 return I2S_PDM_TX_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
392 bool startTX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &tx_chan,
int txPin) {
393 i2s_pdm_tx_config_t pdm_tx_cfg = {
394 .clk_cfg = getTxClockConfig(cfg),
395 .slot_cfg = getTxSlotConfig(cfg),
398 .clk = (gpio_num_t)cfg.pin_bck,
399 .dout = (gpio_num_t)txPin,
400#if SOC_I2S_PDM_MAX_TX_LINES > 1
401 .dout2 = I2S_GPIO_UNUSED,
410 if (i2s_channel_init_pdm_tx_mode(tx_chan, &pdm_tx_cfg) != ESP_OK) {
411 LOGE(
"i2s_channel_init_pdm_tx_mode %s",
"tx");
414 if (i2s_channel_enable(tx_chan) != ESP_OK) {
415 LOGE(
"i2s_channel_enable %s",
"tx");
421#if defined(USE_PDM_RX)
422 i2s_pdm_rx_slot_config_t getRxSlotConfig(I2SConfigESP32V1 &cfg) {
423 return I2S_PDM_RX_SLOT_DEFAULT_CONFIG(
424 (i2s_data_bit_width_t)cfg.bits_per_sample,
425 (i2s_slot_mode_t)cfg.channels);
427 i2s_pdm_rx_clk_config_t getRxClockConfig(I2SConfigESP32V1 &cfg) {
428 return I2S_PDM_RX_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
430 bool startRX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &rx_chan,
int rxPin) {
431 i2s_pdm_rx_config_t pdm_rx_cfg = {
432 .clk_cfg = getRxClockConfig(cfg),
433 .slot_cfg = getRxSlotConfig(cfg),
436 .clk = (gpio_num_t)cfg.pin_bck,
437 .din = (gpio_num_t)rxPin,
445 if (i2s_channel_init_pdm_rx_mode(rx_chan, &pdm_rx_cfg) != ESP_OK) {
446 LOGE(
"i2s_channel_init_pdm_rx_mode %s",
"rx");
449 if (i2s_channel_enable(rx_chan) != ESP_OK) {
450 LOGE(
"i2s_channel_enable %s",
"tx");
456 bool startRX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &rx_chan,
int rxPin) {
457 LOGE(
"PDM RX not supported");
469 bool startChannels(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &tx_chan,
470 i2s_chan_handle_t &rx_chan,
int txPin,
int rxPin) {
471 i2s_tdm_config_t tdm_cfg = {
472 .clk_cfg = getClockConfig(cfg),
473 .slot_cfg = getSlotConfig(cfg),
476 .mclk = (gpio_num_t)cfg.pin_mck,
477 .bclk = (gpio_num_t)cfg.pin_bck,
478 .ws = (gpio_num_t)cfg.pin_ws,
479 .dout = (gpio_num_t)txPin,
480 .din = (gpio_num_t)rxPin,
490 if (cfg.rx_tx_mode == TX_MODE || cfg.rx_tx_mode == RXTX_MODE) {
491 if (i2s_channel_init_tdm_mode(tx_chan, &tdm_cfg) != ESP_OK) {
492 LOGE(
"i2s_channel_init_tdm_tx_mode %s",
"tx");
496 if (cfg.rx_tx_mode == RX_MODE || cfg.rx_tx_mode == RXTX_MODE) {
497 if (i2s_channel_init_tdm_mode(rx_chan, &tdm_cfg) != ESP_OK) {
498 LOGE(
"i2s_channel_init_tdm_tx_mode %s",
"rx");
506 i2s_tdm_slot_config_t getSlotConfig(I2SConfigESP32V1 &cfg) {
508 for (
int j = 0; j < cfg.channels; j++) {
512 i2s_tdm_slot_config_t slot_cfg = I2S_TDM_PHILIPS_SLOT_DEFAULT_CONFIG(
513 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
514 (i2s_tdm_slot_mask_t)slots);
516 switch (cfg.i2s_format) {
521 slot_cfg = I2S_TDM_PHILIPS_SLOT_DEFAULT_CONFIG(
522 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
523 (i2s_tdm_slot_mask_t)slots);
527 slot_cfg = I2S_TDM_MSB_SLOT_DEFAULT_CONFIG(
528 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
529 (i2s_tdm_slot_mask_t)slots);
532 slot_cfg = I2S_TDM_PCM_LONG_SLOT_DEFAULT_CONFIG(
533 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
534 (i2s_tdm_slot_mask_t)slots);
537 LOGE(
"TDM: Unsupported format");
543 i2s_chan_config_t getChannelConfig(I2SConfigESP32V1 &cfg) {
544 return I2S_CHANNEL_DEFAULT_CONFIG(
545 (i2s_port_t)cfg.port_no,
546 cfg.is_master ? I2S_ROLE_MASTER : I2S_ROLE_SLAVE);
549 i2s_tdm_clk_config_t getClockConfig(I2SConfigESP32V1 &cfg) {
550 return I2S_TDM_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
578 LOGE(
"Channels not started");
623 LOGE(
"Unsupported signal_type");
#define LOGW(...)
Definition AudioLoggerIDF.h:29
#define TRACED()
Definition AudioLoggerIDF.h:31
#define LOGI(...)
Definition AudioLoggerIDF.h:28
#define TRACEE()
Definition AudioLoggerIDF.h:34
#define LOGD(...)
Definition AudioLoggerIDF.h:27
#define LOGE(...)
Definition AudioLoggerIDF.h:30
#define I2S_MCLK_MULTIPLE_192
Definition I2SDriverESP32V1.h:24
#define portMAX_DELAY
Definition QueueZephyr.h:14
#define pdMS_TO_TICKS(ms)
Definition QueueZephyr.h:17
uint32_t TickType_t
Definition QueueZephyr.h:11
#define assert(T)
Definition avr.h:10
RxTxMode
The Microcontroller is the Audio Source (TX_MODE) or Audio Sink (RX_MODE). RXTX_MODE is Source and Si...
Definition AudioTypes.h:26
@ RXTX_MODE
Definition AudioTypes.h:26
@ TX_MODE
Definition AudioTypes.h:26
@ RX_MODE
Definition AudioTypes.h:26