From 7f672374b1ab4bc98dc061541adc64eb3dd856d7 Mon Sep 17 00:00:00 2001 From: Philip Gladstone Date: Thu, 12 Dec 2024 00:09:10 +0000 Subject: [PATCH] Fixed the i2s problems --- components/base_nodemcu/user_main.c | 8 -------- components/modules/CMakeLists.txt | 7 +++---- components/modules/console.c | 2 +- components/modules/i2s.c | 14 ++++++++++++++ 4 files changed, 18 insertions(+), 13 deletions(-) diff --git a/components/base_nodemcu/user_main.c b/components/base_nodemcu/user_main.c index 0e7e5b7a..13fb86b0 100644 --- a/components/base_nodemcu/user_main.c +++ b/components/base_nodemcu/user_main.c @@ -15,14 +15,6 @@ #include "esp_system.h" #include "esp_event.h" #include "esp_netif.h" -//#include "esp_vfs_dev.h" -//#include "esp_vfs_cdcacm.h" -//#include "esp_vfs_console.h" -//#include "esp_vfs_usb_serial_jtag.h" -//#include "driver/uart_vfs.h" -//#include "driver/usb_serial_jtag.h" -//#include "driver/uart_vfs.h" -//#include "driver/usb_serial_jtag_vfs.h" #include "nvs_flash.h" #include "task/task.h" diff --git a/components/modules/CMakeLists.txt b/components/modules/CMakeLists.txt index 03a29ef4..ffe67457 100644 --- a/components/modules/CMakeLists.txt +++ b/components/modules/CMakeLists.txt @@ -83,10 +83,9 @@ elseif(IDF_TARGET STREQUAL "esp32c3") ) elseif(IDF_TARGET STREQUAL "esp32c5") list(APPEND module_srcs - # "can.c" - # "i2s.c" - # "pulsecnt.c" - # "sdmmc.c" + "can.c" + "i2s.c" + "pulsecnt.c" ${wifi_modules} ) elseif(IDF_TARGET STREQUAL "esp32c6") diff --git a/components/modules/console.c b/components/modules/console.c index e115c958..d3b26453 100644 --- a/components/modules/console.c +++ b/components/modules/console.c @@ -6,7 +6,7 @@ #include "task/task.h" #include "esp_vfs_dev.h" -#include "esp_vfs_cdcacm.h" +//#include "esp_vfs_cdcacm.h" #include "esp_vfs_usb_serial_jtag.h" #include "driver/usb_serial_jtag.h" #include "freertos/FreeRTOS.h" diff --git a/components/modules/i2s.c b/components/modules/i2s.c index cd213c57..49932f1d 100644 --- a/components/modules/i2s.c +++ b/components/modules/i2s.c @@ -161,9 +161,13 @@ static int node_i2s_start( lua_State *L ) pin_config.data_out_num = opt_checkint(L, "data_out_pin", I2S_PIN_NO_CHANGE); pin_config.data_in_num = opt_checkint(L, "data_in_pin", I2S_PIN_NO_CHANGE); // +#ifdef SOC_I2S_SUPPORTS_DAC i2s_dac_mode_t dac_mode = opt_checkint_range(L, "dac_mode", I2S_DAC_CHANNEL_DISABLE, 0, I2S_DAC_CHANNEL_MAX-1); +#endif // +#ifdef SOC_I2S_SUPPORTS_ADC adc1_channel_t adc1_channel = opt_checkint_range(L, "adc1_channel", ADC1_CHANNEL_MAX, ADC1_CHANNEL_0, ADC1_CHANNEL_MAX); +#endif // handle optional callback functions TX and RX lua_settop( L, top ); @@ -183,14 +187,18 @@ static int node_i2s_start( lua_State *L ) if (err != ESP_OK) luaL_error( L, "i2s can not start" ); +#ifdef SOC_I2S_SUPPORTS_DAC if (dac_mode != I2S_DAC_CHANNEL_DISABLE) { if (i2s_set_dac_mode( dac_mode ) != ESP_OK) luaL_error( L, "error setting dac mode" ); } +#endif +#ifdef SOC_I2S_SUPPORTS_ADC if (adc1_channel != ADC1_CHANNEL_MAX) { if (i2s_set_adc_mode( ADC_UNIT_1, adc1_channel ) != ESP_OK) luaL_error( L, "error setting adc1 mode" ); } +#endif if (i2s_set_pin(i2s_id, &pin_config) != ESP_OK) luaL_error( L, "error setting pins" ); @@ -331,14 +339,20 @@ LROT_BEGIN(i2s, NULL, 0) LROT_NUMENTRY( MODE_SLAVE, I2S_MODE_SLAVE ) LROT_NUMENTRY( MODE_TX, I2S_MODE_TX ) LROT_NUMENTRY( MODE_RX, I2S_MODE_RX ) +#ifdef SOC_I2S_SUPPORTS_DAC LROT_NUMENTRY( MODE_DAC_BUILT_IN, I2S_MODE_DAC_BUILT_IN ) +#endif +#ifdef SOC_I2S_SUPPORTS_ADC LROT_NUMENTRY( MODE_ADC_BUILT_IN, I2S_MODE_ADC_BUILT_IN ) +#endif LROT_NUMENTRY( MODE_PDM, I2S_MODE_PDM ) +#ifdef SOC_I2S_SUPPORTS_DAC LROT_NUMENTRY( DAC_CHANNEL_DISABLE, I2S_DAC_CHANNEL_DISABLE ) LROT_NUMENTRY( DAC_CHANNEL_RIGHT, I2S_DAC_CHANNEL_RIGHT_EN ) LROT_NUMENTRY( DAC_CHANNEL_LEFT, I2S_DAC_CHANNEL_LEFT_EN ) LROT_NUMENTRY( DAC_CHANNEL_BOTH, I2S_DAC_CHANNEL_BOTH_EN ) +#endif LROT_END(i2s, NULL, 0) int luaopen_i2s( lua_State *L ) {