esp-idf/components/sdmmc/test_apps/sdmmc_console/main/sdmmc_console_main.c

100 wiersze
2.7 KiB
C

/*
* SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*
* SDMMC console test application
*/
#include <string.h>
#include "esp_system.h"
#include "esp_log.h"
#include "esp_console.h"
#include "esp_vfs_fat.h"
#include "cmd_system.h"
#include "cmd_sdmmc.h"
#include "cmd_unity.h"
#include "sdmmc_test_board.h"
static const char* TAG = "sdmmc_console_main";
#define MOUNT_PATH "/data"
#define HISTORY_PATH MOUNT_PATH "/history.txt"
static void init_filesystem(void);
static void init_console(void);
static void card_power_down(void);
void app_main(void)
{
sdmmc_test_board_print_info();
esp_register_shutdown_handler(&card_power_down);
init_filesystem();
init_console();
/* Register all the console commands */
register_system_common();
register_sdmmc_common();
#if SOC_SDMMC_HOST_SUPPORTED
register_sdmmc_host();
#endif
register_unity();
}
static void init_console(void)
{
esp_console_repl_t *repl = NULL;
esp_console_repl_config_t repl_config = ESP_CONSOLE_REPL_CONFIG_DEFAULT();
repl_config.prompt = "sdmmc>";
repl_config.max_cmdline_length = 80;
repl_config.history_save_path = HISTORY_PATH;
esp_console_register_help_command();
#if defined(CONFIG_ESP_CONSOLE_UART_DEFAULT) || defined(CONFIG_ESP_CONSOLE_UART_CUSTOM)
esp_console_dev_uart_config_t hw_config = ESP_CONSOLE_DEV_UART_CONFIG_DEFAULT();
ESP_ERROR_CHECK(esp_console_new_repl_uart(&hw_config, &repl_config, &repl));
#elif defined(CONFIG_ESP_CONSOLE_USB_CDC)
esp_console_dev_usb_cdc_config_t hw_config = ESP_CONSOLE_DEV_CDC_CONFIG_DEFAULT();
ESP_ERROR_CHECK(esp_console_new_repl_usb_cdc(&hw_config, &repl_config, &repl));
#elif defined(CONFIG_ESP_CONSOLE_USB_SERIAL_JTAG)
esp_console_dev_usb_serial_jtag_config_t hw_config = ESP_CONSOLE_DEV_USB_SERIAL_JTAG_CONFIG_DEFAULT();
ESP_ERROR_CHECK(esp_console_new_repl_usb_serial_jtag(&hw_config, &repl_config, &repl));
#else
#error Unsupported console type
#endif
ESP_ERROR_CHECK(esp_console_start_repl(repl));
}
/**
* @brief Initialize FAT in SPI flash, for storing the history of console commands.
*/
static void init_filesystem(void)
{
static wl_handle_t wl_handle;
const esp_vfs_fat_mount_config_t mount_config = {
.max_files = 4,
.format_if_mount_failed = true
};
esp_err_t err = esp_vfs_fat_spiflash_mount_rw_wl(MOUNT_PATH, "storage", &mount_config, &wl_handle);
if (err != ESP_OK) {
ESP_LOGE(TAG, "Failed to mount FATFS (%s)", esp_err_to_name(err));
return;
}
}
/**
* Called before restarting using 'restart' command or esp_restart()
* Turn of the SD card power.
*/
static void card_power_down(void)
{
sdmmc_test_board_card_power_set(false);
}