adc_pdm_audio_codec.cc 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. #include "adc_pdm_audio_codec.h"
  2. #include <esp_log.h>
  3. #include <driver/i2c.h>
  4. #include <driver/i2c_master.h>
  5. #include <driver/i2s_tdm.h>
  6. #include "adc_mic.h"
  7. #include "driver/i2s_pdm.h"
  8. #include "soc/gpio_sig_map.h"
  9. #include "soc/io_mux_reg.h"
  10. #include "hal/rtc_io_hal.h"
  11. #include "hal/gpio_ll.h"
  12. #include "settings.h"
  13. static const char TAG[] = "AdcPdmAudioCodec";
  14. #define BSP_I2S_GPIO_CFG(_dout) \
  15. { \
  16. .clk = GPIO_NUM_NC, \
  17. .dout = _dout, \
  18. .invert_flags = { \
  19. .clk_inv = false, \
  20. }, \
  21. }
  22. /**
  23. * @brief Mono Duplex I2S configuration structure
  24. *
  25. * This configuration is used by default in bsp_audio_init()
  26. */
  27. #define BSP_I2S_DUPLEX_MONO_CFG(_sample_rate, _dout) \
  28. { \
  29. .clk_cfg = I2S_PDM_TX_CLK_DEFAULT_CONFIG(_sample_rate), \
  30. .slot_cfg = I2S_PDM_TX_SLOT_DEFAULT_CONFIG(I2S_DATA_BIT_WIDTH_16BIT, I2S_SLOT_MODE_MONO), \
  31. .gpio_cfg = BSP_I2S_GPIO_CFG(_dout), \
  32. }
  33. AdcPdmAudioCodec::AdcPdmAudioCodec(int input_sample_rate, int output_sample_rate,
  34. uint32_t adc_mic_channel, gpio_num_t pdm_speak_p,gpio_num_t pdm_speak_n, gpio_num_t pa_ctl) {
  35. input_reference_ = false;
  36. input_sample_rate_ = input_sample_rate;
  37. output_sample_rate_ = output_sample_rate;
  38. uint8_t adc_channel[1] = {0};
  39. adc_channel[0] = adc_mic_channel;
  40. audio_codec_adc_cfg_t cfg = {
  41. .handle = NULL,
  42. .max_store_buf_size = 1024 * 2,
  43. .conv_frame_size = 1024,
  44. .unit_id = ADC_UNIT_1,
  45. .adc_channel_list = adc_channel,
  46. .adc_channel_num = sizeof(adc_channel) / sizeof(adc_channel[0]),
  47. .sample_rate_hz = (uint32_t)input_sample_rate,
  48. };
  49. const audio_codec_data_if_t *adc_if = audio_codec_new_adc_data(&cfg);
  50. esp_codec_dev_cfg_t codec_dev_cfg = {
  51. .dev_type = ESP_CODEC_DEV_TYPE_IN,
  52. .data_if = adc_if,
  53. };
  54. input_dev_ = esp_codec_dev_new(&codec_dev_cfg);
  55. if (!input_dev_) {
  56. ESP_LOGE(TAG, "Failed to create codec device");
  57. return;
  58. }
  59. i2s_chan_config_t chan_cfg = I2S_CHANNEL_DEFAULT_CONFIG(I2S_NUM_0, I2S_ROLE_MASTER);
  60. chan_cfg.auto_clear = true; // Auto clear the legacy data in the DMA buffer
  61. ESP_ERROR_CHECK(i2s_new_channel(&chan_cfg, &tx_handle_, NULL));
  62. i2s_pdm_tx_config_t pdm_cfg_default = BSP_I2S_DUPLEX_MONO_CFG((uint32_t)output_sample_rate, pdm_speak_p);
  63. pdm_cfg_default.clk_cfg.up_sample_fs = output_sample_rate / 100;
  64. pdm_cfg_default.slot_cfg.sd_scale = I2S_PDM_SIG_SCALING_MUL_4;
  65. pdm_cfg_default.slot_cfg.hp_scale = I2S_PDM_SIG_SCALING_MUL_4;
  66. pdm_cfg_default.slot_cfg.lp_scale = I2S_PDM_SIG_SCALING_MUL_4;
  67. pdm_cfg_default.slot_cfg.sinc_scale = I2S_PDM_SIG_SCALING_MUL_4;
  68. const i2s_pdm_tx_config_t *p_i2s_cfg = &pdm_cfg_default;
  69. ESP_ERROR_CHECK(i2s_channel_init_pdm_tx_mode(tx_handle_, p_i2s_cfg));
  70. audio_codec_i2s_cfg_t i2s_cfg = {
  71. .port = I2S_NUM_0,
  72. .rx_handle = NULL,
  73. .tx_handle = tx_handle_,
  74. };
  75. const audio_codec_data_if_t *i2s_data_if = audio_codec_new_i2s_data(&i2s_cfg);
  76. codec_dev_cfg.dev_type = ESP_CODEC_DEV_TYPE_OUT;
  77. codec_dev_cfg.codec_if = NULL;
  78. codec_dev_cfg.data_if = i2s_data_if;
  79. output_dev_ = esp_codec_dev_new(&codec_dev_cfg);
  80. output_volume_ = 100;
  81. if(pa_ctl != GPIO_NUM_NC) {
  82. pa_ctrl_pin_ = pa_ctl;
  83. gpio_config_t io_conf = {};
  84. io_conf.intr_type = GPIO_INTR_DISABLE;
  85. io_conf.mode = GPIO_MODE_OUTPUT;
  86. io_conf.pin_bit_mask = (1ULL << pa_ctrl_pin_);
  87. io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE;
  88. io_conf.pull_up_en = GPIO_PULLUP_DISABLE;
  89. gpio_config(&io_conf);
  90. }
  91. gpio_set_drive_capability(pdm_speak_p, GPIO_DRIVE_CAP_0);
  92. if(pdm_speak_n != GPIO_NUM_NC){
  93. PIN_FUNC_SELECT(GPIO_PIN_MUX_REG[pdm_speak_n], PIN_FUNC_GPIO);
  94. gpio_set_direction(pdm_speak_n, GPIO_MODE_OUTPUT);
  95. esp_rom_gpio_connect_out_signal(pdm_speak_n, I2SO_SD_OUT_IDX, 1, 0); //反转输出 SD OUT 信号
  96. gpio_set_drive_capability(pdm_speak_n, GPIO_DRIVE_CAP_0);
  97. }
  98. ESP_LOGI(TAG, "AdcPdmAudioCodec initialized");
  99. }
  100. AdcPdmAudioCodec::~AdcPdmAudioCodec() {
  101. ESP_ERROR_CHECK(esp_codec_dev_close(output_dev_));
  102. esp_codec_dev_delete(output_dev_);
  103. ESP_ERROR_CHECK(esp_codec_dev_close(input_dev_));
  104. esp_codec_dev_delete(input_dev_);
  105. }
  106. void AdcPdmAudioCodec::SetOutputVolume(int volume) {
  107. ESP_ERROR_CHECK(esp_codec_dev_set_out_vol(output_dev_, volume));
  108. AudioCodec::SetOutputVolume(volume);
  109. }
  110. void AdcPdmAudioCodec::EnableInput(bool enable) {
  111. if (enable == input_enabled_) {
  112. return;
  113. }
  114. if (enable) {
  115. esp_codec_dev_sample_info_t fs = {
  116. .bits_per_sample = 16,
  117. .channel = 1,
  118. .channel_mask = ESP_CODEC_DEV_MAKE_CHANNEL_MASK(0),
  119. .sample_rate = (uint32_t)input_sample_rate_,
  120. .mclk_multiple = 0,
  121. };
  122. ESP_ERROR_CHECK(esp_codec_dev_open(input_dev_, &fs));
  123. } else {
  124. ESP_ERROR_CHECK(esp_codec_dev_close(input_dev_));
  125. }
  126. AudioCodec::EnableInput(enable);
  127. }
  128. void AdcPdmAudioCodec::EnableOutput(bool enable) {
  129. if (enable == output_enabled_) {
  130. return;
  131. }
  132. if (enable) {
  133. // Play 16bit 1 channel
  134. esp_codec_dev_sample_info_t fs = {
  135. .bits_per_sample = 16,
  136. .channel = 1,
  137. .channel_mask = 0,
  138. .sample_rate = (uint32_t)output_sample_rate_,
  139. .mclk_multiple = 0,
  140. };
  141. ESP_ERROR_CHECK(esp_codec_dev_open(output_dev_, &fs));
  142. ESP_ERROR_CHECK(esp_codec_dev_set_out_vol(output_dev_, output_volume_));
  143. if(pa_ctrl_pin_ != GPIO_NUM_NC){
  144. gpio_set_level(pa_ctrl_pin_, 1);
  145. }
  146. } else {
  147. if(pa_ctrl_pin_ != GPIO_NUM_NC){
  148. gpio_set_level(pa_ctrl_pin_, 0);
  149. }
  150. ESP_ERROR_CHECK(esp_codec_dev_close(output_dev_));
  151. }
  152. AudioCodec::EnableOutput(enable);
  153. }
  154. int AdcPdmAudioCodec::Read(int16_t* dest, int samples) {
  155. if (input_enabled_) {
  156. ESP_ERROR_CHECK_WITHOUT_ABORT(esp_codec_dev_read(input_dev_, (void*)dest, samples * sizeof(int16_t)));
  157. }
  158. return samples;
  159. }
  160. int AdcPdmAudioCodec::Write(const int16_t* data, int samples) {
  161. if (output_enabled_) {
  162. ESP_ERROR_CHECK_WITHOUT_ABORT(esp_codec_dev_write(output_dev_, (void*)data, samples * sizeof(int16_t)));
  163. }
  164. return samples;
  165. }
  166. void AdcPdmAudioCodec::Start() {
  167. Settings settings("audio", false);
  168. output_volume_ = settings.GetInt("output_volume", output_volume_);
  169. if (output_volume_ <= 0) {
  170. ESP_LOGW(TAG, "Output volume value (%d) is too small, setting to default (10)", output_volume_);
  171. output_volume_ = 10;
  172. }
  173. ESP_ERROR_CHECK(i2s_channel_enable(tx_handle_));
  174. EnableInput(true);
  175. EnableOutput(true);
  176. ESP_LOGI(TAG, "Audio codec started");
  177. }