Files
ESPC3-wireless/app/app_main.c

144 lines
3.5 KiB
C
Raw Normal View History

2024-03-28 12:19:52 +08:00
#include "app_main.h"
/* 标准库 */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* 配置 */
#include "config/board_config.h"
#include "config/app_config.h"
2025-07-09 15:41:50 +08:00
#include "config/app_log.h"
2024-03-28 12:19:52 +08:00
/* SDK */
#include "esp_err.h"
#include "hal/spi_types.h"
2025-07-09 15:41:50 +08:00
#include "spbelib_interface.h"
#include "lib_shell.h"
#include "ota.h"
/* 驱动 */
#include "drivers/ws2812_spi/ws2812_spi.h"
#include "drivers/ws2812_spi/ws2812_spi_shell.h"
2024-03-28 12:19:52 +08:00
/* 通用模块 */
2025-02-18 17:41:45 +08:00
#include "button/button.h"
2024-03-28 12:19:52 +08:00
/* 应用模块 */
/* 自定义框架抽象层 */
#include "os/os.h"
#include "os/os_common.h"
#include "console.h"
#include "shell/sh_vset.h"
#define CONFIG_SYS_LOG_LEVEL SYS_LOG_LEVEL_INF
2024-03-28 12:19:52 +08:00
#define SYS_LOG_DOMAIN "MAIN"
#include "sys_log.h"
nvs_handle g_nvs_hdl; // nvs 句柄
os_work_q_t g_work_q_hdl_low; // 低于 default_os_work_q_hdl 优先级的工作队列
static void _init_nvs(void);
static void _init_ws2812(void);
2025-02-18 17:41:45 +08:00
static void _change_mode_event_button(button_hdl_t *handle, press_event_t event);
2024-03-28 12:19:52 +08:00
static void _vset_cb(sh_t *sh_hdl);
void work_app_main(void *arg)
{
/* 初始化 SDK 的 nvs 模块 */
_init_nvs();
/* 初始化配置 */
board_cfg_init(); // 板级配置
app_cfg_init(); // 应用配置
2025-07-09 15:41:50 +08:00
app_log_init(); // 应用记录
2025-07-09 14:02:53 +08:00
/* 初始化 OTA 功能*/
ota_partition_check();
/* 初始化 ws2812 */
_init_ws2812();
ws2812_spi_shell_register(); // 用于测试 ws2812 的 shell 命令
2024-03-28 12:19:52 +08:00
2025-07-09 15:41:50 +08:00
/* 启动静态库功能 */
sblib_init(SBLIB_INIT_ADAPTER);
lib_shell_register(); // 静态库接口命令
/* 初始化按键检测和控制 */
btn_attach(&g_cfg_board->key_reset, _change_mode_event_button, EVENT_PRESS_UP | EVENT_PRESS_DOWN | EVENT_LONG_PRESS_HOLD);
2024-03-28 12:19:52 +08:00
/* 启动 shell */
os_thread_sleep(100);
shell_start(_vset_cb);
SYS_LOG_DBG("app start");
2024-03-28 12:19:52 +08:00
}
static void _init_nvs(void)
{
#define _NVS_NAME "nvs-app"
if (g_nvs_hdl == 0)
{
ESP_ERROR_CHECK(nvs_open(_NVS_NAME, NVS_READWRITE, &g_nvs_hdl));
}
}
static void _init_ws2812(void)
{
#if (CONFIG_LED_STRIP_MAX_LEDS)
2025-07-09 14:02:53 +08:00
ws2812_spi_led_strip_init(g_cfg_board->led_spi.spi_id, CONFIG_LED_STRIP_MAX_LEDS);
#else
2025-07-09 14:02:53 +08:00
ws2812_spi_led_strip_init(g_cfg_board->led_spi.spi_id, 10);
#endif
}
static void _vset_cb(sh_t *sh_hdl)
{
}
2025-02-18 17:41:45 +08:00
static void _change_mode_event_button(button_hdl_t *handle, press_event_t event)
2024-03-28 12:19:52 +08:00
{
static const char *const stat_tab[] = {
2025-02-18 17:41:45 +08:00
[PRESS_UP] = "up",
[PRESS_DOWN] = "down",
[LONG_PRESS_HOLD] = "held",
2024-03-28 12:19:52 +08:00
};
2025-02-18 17:41:45 +08:00
if (event < __ARRAY_SIZE(stat_tab) && stat_tab[event])
2024-03-28 12:19:52 +08:00
{
2025-02-18 17:41:45 +08:00
SYS_LOG_DBG("button stat: %s", stat_tab[event]);
2024-03-28 12:19:52 +08:00
}
}
2025-07-09 15:41:50 +08:00
// 导出符号,供 linker script 使用
#include "utils/sb_aes.h"
#include "drivers/data_port/sb_data_port.h"
#include "drivers/data_port/uart/uart_port.h"
#if defined(CONFIG_BUILD_BLE)
#include "drivers/data_port/ble_spp/ble_spp_server.h"
#endif
#if defined(CONFIG_BUILD_WIFI)
#include "drivers/data_port/socket_inet/socket_inet.h"
#endif
#if defined(CONFIG_IDF_TARGET_ESP32S3)
#include "drivers/data_port/usb-host/usbport.h"
#endif
void _exporter_reference_symbols(void)
{
btn_attach(NULL, NULL, 0);
sb_aes_init();
sb_data_port_start(NULL);
sb_uart_port_init();
sh_init_vt100(NULL, NULL, NULL);
shell_start(NULL);
ws2812_spi_led_strip_init(0, 0);
#if defined(CONFIG_BUILD_BLE)
sb_ble_server_port_init(NULL);
#endif
#if defined(CONFIG_BUILD_WIFI)
socket_inet_init();
#endif
#if defined(CONFIG_IDF_TARGET_ESP32S3)
usbport_init();
#endif
}