Files
xiaozhi-esp32/main/main.cc

56 lines
1.6 KiB
C++
Raw Normal View History

2024-10-03 06:39:22 +08:00
#include <esp_log.h>
#include <esp_err.h>
#include <nvs.h>
#include <nvs_flash.h>
#include <driver/gpio.h>
#include <esp_event.h>
2024-08-31 18:00:23 +08:00
#include "Application.h"
#include "SystemInfo.h"
2024-09-10 00:45:13 +08:00
#include "SystemReset.h"
2024-08-31 18:00:23 +08:00
#define TAG "main"
extern "C" void app_main(void)
{
2024-10-24 09:53:08 +08:00
#ifdef CONFIG_AUDIO_CODEC_ES8311_ES7210
// Make GPIO15 HIGH to enable the 4G module
gpio_config_t ml307_enable_config = {
.pin_bit_mask = (1ULL << 15),
.mode = GPIO_MODE_OUTPUT,
.pull_up_en = GPIO_PULLUP_DISABLE,
.pull_down_en = GPIO_PULLDOWN_DISABLE,
.intr_type = GPIO_INTR_DISABLE,
};
gpio_config(&ml307_enable_config);
gpio_set_level(GPIO_NUM_15, 1);
#endif
2024-09-10 00:45:13 +08:00
// Check if the reset button is pressed
SystemReset system_reset;
system_reset.CheckButtons();
2024-08-31 18:00:23 +08:00
// Initialize the default event loop
ESP_ERROR_CHECK(esp_event_loop_create_default());
// Initialize NVS flash for WiFi configuration
esp_err_t ret = nvs_flash_init();
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
ESP_ERROR_CHECK(nvs_flash_erase());
ret = nvs_flash_init();
}
ESP_ERROR_CHECK(ret);
// Otherwise, launch the application
2024-09-10 05:58:56 +08:00
Application::GetInstance().Start();
2024-08-31 18:00:23 +08:00
2024-09-05 17:22:01 +08:00
// Dump CPU usage every 10 second
2024-08-31 18:00:23 +08:00
while (true) {
2024-09-05 17:22:01 +08:00
vTaskDelay(10000 / portTICK_PERIOD_MS);
2024-10-03 06:39:22 +08:00
// SystemInfo::PrintRealTimeStats(pdMS_TO_TICKS(1000));
int free_sram = heap_caps_get_free_size(MALLOC_CAP_INTERNAL);
int min_free_sram = heap_caps_get_minimum_free_size(MALLOC_CAP_INTERNAL);
ESP_LOGI(TAG, "Free internal: %u minimal internal: %u", free_sram, min_free_sram);
2024-08-31 18:00:23 +08:00
}
}