4#if defined(ESP32) && !USE_LEGACY_I2S || defined(DOXYGEN)
7#include "driver/i2s_pdm.h"
8#include "driver/i2s_std.h"
9#include "driver/i2s_tdm.h"
10#include "esp_system.h"
12#define IS_I2S_IMPLEMENTED
73 LOGE(
"Did not expect go get here");
183 LOGE(
"i2s_channel_init_std_mode %s",
"tx");
187 LOGE(
"i2s_channel_enable %s",
"tx");
194 LOGE(
"i2s_channel_init_std_mode %s",
"rx");
198 LOGE(
"i2s_channel_enable %s",
"rx");
239 LOGW(
"Using channel_format: I2SChannelSelect::Left for mono");
256 frame_size = (frame_size == 0) ? 1 : frame_size;
257 if (size > 0) result.dma_frame_num = size / frame_size;
258 LOGI(
"dma_frame_num: %d", (
int)result.dma_frame_num);
279 LOGI(
"mclk_multiple=384");
296#if SOC_I2S_HW_VERSION_2
297 LOGI(
"pin_mclk is input");
301 LOGE(
"pin_mclk as input not supported");
308#if SOC_I2S_SUPPORTS_APLL
310 LOGI(
"clk_src is I2S_CLK_SRC_APLL");
311#elif SOC_I2S_SUPPORTS_PLL_F160M
313 LOGI(
"clk_src is I2S_CLK_SRC_PLL_160M");
343 i2s_chan_handle_t &rx_chan,
int txPin,
int rxPin) {
345 return startTX(cfg, tx_chan, txPin);
347 return startRX(cfg, rx_chan, rxPin);
349 LOGE(
"Only RX and TX is supported for PDM")
354 i2s_pdm_tx_slot_config_t getTxSlotConfig(I2SConfigESP32V1 &cfg) {
355#ifdef SOC_I2S_HW_VERSION_2
356 return I2S_PDM_TX_SLOT_DAC_DEFAULT_CONFIG(
357 (i2s_data_bit_width_t)cfg.bits_per_sample,
358 (i2s_slot_mode_t)cfg.channels);
360 return I2S_PDM_TX_SLOT_DEFAULT_CONFIG(
361 (i2s_data_bit_width_t)cfg.bits_per_sample,
362 (i2s_slot_mode_t)cfg.channels);
366 i2s_chan_config_t getChannelConfig(I2SConfigESP32V1 &cfg) {
367 return I2S_CHANNEL_DEFAULT_CONFIG(
368 (i2s_port_t)cfg.port_no,
369 cfg.is_master ? I2S_ROLE_MASTER : I2S_ROLE_SLAVE);
372 i2s_pdm_tx_clk_config_t getTxClockConfig(I2SConfigESP32V1 &cfg) {
373#if defined(I2S_PDM_TX_CLK_DAC_DEFAULT_CONFIG)
374 return I2S_PDM_TX_CLK_DAC_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
376 return I2S_PDM_TX_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
380 bool startTX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &tx_chan,
int txPin) {
381 i2s_pdm_tx_config_t pdm_tx_cfg = {
382 .clk_cfg = getTxClockConfig(cfg),
383 .slot_cfg = getTxSlotConfig(cfg),
386 .clk = (gpio_num_t)cfg.pin_bck,
387 .dout = (gpio_num_t)txPin,
395 if (i2s_channel_init_pdm_tx_mode(tx_chan, &pdm_tx_cfg) != ESP_OK) {
396 LOGE(
"i2s_channel_init_pdm_tx_mode %s",
"tx");
399 if (i2s_channel_enable(tx_chan) != ESP_OK) {
400 LOGE(
"i2s_channel_enable %s",
"tx");
406#if defined(USE_PDM_RX)
407 i2s_pdm_rx_slot_config_t getRxSlotConfig(I2SConfigESP32V1 &cfg) {
408 return I2S_PDM_RX_SLOT_DEFAULT_CONFIG(
409 (i2s_data_bit_width_t)cfg.bits_per_sample,
410 (i2s_slot_mode_t)cfg.channels);
412 i2s_pdm_rx_clk_config_t getRxClockConfig(I2SConfigESP32V1 &cfg) {
413 return I2S_PDM_RX_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
415 bool startRX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &rx_chan,
int rxPin) {
416 i2s_pdm_rx_config_t pdm_rx_cfg = {
417 .clk_cfg = getRxClockConfig(cfg),
418 .slot_cfg = getRxSlotConfig(cfg),
421 .clk = (gpio_num_t)cfg.pin_bck,
422 .din = (gpio_num_t)rxPin,
430 if (i2s_channel_init_pdm_rx_mode(rx_chan, &pdm_rx_cfg) != ESP_OK) {
431 LOGE(
"i2s_channel_init_pdm_rx_mode %s",
"rx");
434 if (i2s_channel_enable(rx_chan) != ESP_OK) {
435 LOGE(
"i2s_channel_enable %s",
"tx");
441 bool startRX(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &rx_chan,
int rxPin) {
442 LOGE(
"PDM RX not supported");
454 bool startChannels(I2SConfigESP32V1 &cfg, i2s_chan_handle_t &tx_chan,
455 i2s_chan_handle_t &rx_chan,
int txPin,
int rxPin) {
456 i2s_tdm_config_t tdm_cfg = {
457 .clk_cfg = getClockConfig(cfg),
458 .slot_cfg = getSlotConfig(cfg),
461 .mclk = (gpio_num_t)cfg.pin_mck,
462 .bclk = (gpio_num_t)cfg.pin_bck,
463 .ws = (gpio_num_t)cfg.pin_ws,
464 .dout = (gpio_num_t)txPin,
465 .din = (gpio_num_t)rxPin,
475 if (cfg.rx_tx_mode == TX_MODE || cfg.rx_tx_mode == RXTX_MODE) {
476 if (i2s_channel_init_tdm_mode(tx_chan, &tdm_cfg) != ESP_OK) {
477 LOGE(
"i2s_channel_init_tdm_tx_mode %s",
"tx");
481 if (cfg.rx_tx_mode == RX_MODE || cfg.rx_tx_mode == RXTX_MODE) {
482 if (i2s_channel_init_tdm_mode(rx_chan, &tdm_cfg) != ESP_OK) {
483 LOGE(
"i2s_channel_init_tdm_tx_mode %s",
"rx");
491 i2s_tdm_slot_config_t getSlotConfig(I2SConfigESP32V1 &cfg) {
493 for (
int j = 0; j < cfg.channels; j++) {
497 i2s_tdm_slot_config_t slot_cfg = I2S_TDM_PHILIPS_SLOT_DEFAULT_CONFIG(
498 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
499 (i2s_tdm_slot_mask_t)slots);
501 switch (cfg.i2s_format) {
506 slot_cfg = I2S_TDM_PHILIPS_SLOT_DEFAULT_CONFIG(
507 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
508 (i2s_tdm_slot_mask_t)slots);
512 slot_cfg = I2S_TDM_MSB_SLOT_DEFAULT_CONFIG(
513 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
514 (i2s_tdm_slot_mask_t)slots);
517 slot_cfg = I2S_TDM_PCM_LONG_SLOT_DEFAULT_CONFIG(
518 (i2s_data_bit_width_t)cfg.bits_per_sample, I2S_SLOT_MODE_STEREO,
519 (i2s_tdm_slot_mask_t)slots);
522 LOGE(
"TDM: Unsupported format");
528 i2s_chan_config_t getChannelConfig(I2SConfigESP32V1 &cfg) {
529 return I2S_CHANNEL_DEFAULT_CONFIG(
530 (i2s_port_t)cfg.port_no,
531 cfg.is_master ? I2S_ROLE_MASTER : I2S_ROLE_SLAVE);
534 i2s_tdm_clk_config_t getClockConfig(I2SConfigESP32V1 &cfg) {
535 return I2S_TDM_CLK_DEFAULT_CONFIG((uint32_t)cfg.sample_rate);
563 LOGE(
"Channels not started");
608 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 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:30
@ RXTX_MODE
Definition AudioTypes.h:30
@ TX_MODE
Definition AudioTypes.h:30
@ RX_MODE
Definition AudioTypes.h:30