| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- /*
- * SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD
- *
- * SPDX-License-Identifier: Unlicense OR CC0-1.0
- */
- /* eMMC and FAT filesystem example.
- This example code is in the Public Domain (or CC0 licensed, at your option.)
- Unless required by applicable law or agreed to in writing, this
- software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
- CONDITIONS OF ANY KIND, either express or implied.
- */
- // This example uses SDMMC peripheral to communicate with an eMMC.
- #include <string.h>
- #include <sys/unistd.h>
- #include <sys/stat.h>
- #include "esp_vfs_fat.h"
- #include "sdmmc_cmd.h"
- #include "driver/sdmmc_host.h"
- static const char *TAG = "example";
- #define MOUNT_POINT "/eMMC"
- void app_main(void)
- {
- esp_err_t ret;
- // Options for mounting the filesystem.
- // If format_if_mount_failed is set to true, eMMC will be partitioned and
- // formatted in case when mounting fails.
- esp_vfs_fat_sdmmc_mount_config_t mount_config = {
- #ifdef CONFIG_EXAMPLE_FORMAT_IF_MOUNT_FAILED
- .format_if_mount_failed = true,
- #else
- .format_if_mount_failed = false,
- #endif // EXAMPLE_FORMAT_IF_MOUNT_FAILED
- .max_files = 5,
- .allocation_unit_size = 16 * 1024
- };
- sdmmc_card_t *card = NULL;
- const char mount_point[] = MOUNT_POINT;
- ESP_LOGI(TAG, "Initializing eMMC");
- // Use settings defined above to initialize eMMC and mount FAT filesystem.
- // Note: esp_vfs_fat_sdmmc_mount is all-in-one convenience functions.
- // Please check its source code and implement error recovery when developing
- // production applications.
- ESP_LOGI(TAG, "Using SDMMC peripheral");
- // By default, eMMC frequency is initialized to SDMMC_FREQ_DEFAULT (20MHz)
- // For setting a specific frequency, use host.max_freq_khz (range 400kHz - 52MHz for SDMMC)
- // Example: for fixed frequency of 10MHz, use host.max_freq_khz = 10000;
- sdmmc_host_t host = SDMMC_HOST_DEFAULT();
- host.max_freq_khz = SDMMC_FREQ_52M;
- // This initializes the slot without card detect (CD) and write protect (WP) signals.
- // Other fields will be initialized to zero
- sdmmc_slot_config_t slot_config = {
- .cd = SDMMC_SLOT_NO_CD,
- .wp = SDMMC_SLOT_NO_WP,
- };
- // Set bus width to use:
- #if CONFIG_EXAMPLE_EMMC_BUS_WIDTH_8
- slot_config.width = 8;
- #elif CONFIG_EXAMPLE_EMMC_BUS_WIDTH_4
- slot_config.width = 4;
- #else
- slot_config.width = 1;
- #endif
- // Set bus IOs
- #if CONFIG_SOC_SDMMC_USE_GPIO_MATRIX
- slot_config.clk = CONFIG_EXAMPLE_PIN_CLK;
- slot_config.cmd = CONFIG_EXAMPLE_PIN_CMD;
- slot_config.d0 = CONFIG_EXAMPLE_PIN_D0;
- #if CONFIG_EXAMPLE_EMMC_BUS_WIDTH_4 || CONFIG_EXAMPLE_EMMC_BUS_WIDTH_8
- slot_config.d1 = CONFIG_EXAMPLE_PIN_D1;
- slot_config.d2 = CONFIG_EXAMPLE_PIN_D2;
- slot_config.d3 = CONFIG_EXAMPLE_PIN_D3;
- #endif // CONFIG_EXAMPLE_EMMC_BUS_WIDTH_4 || CONFIG_EXAMPLE_EMMC_BUS_WIDTH_8
- #if CONFIG_EXAMPLE_EMMC_BUS_WIDTH_8
- slot_config.d4 = CONFIG_EXAMPLE_PIN_D4;
- slot_config.d5 = CONFIG_EXAMPLE_PIN_D5;
- slot_config.d6 = CONFIG_EXAMPLE_PIN_D6;
- slot_config.d7 = CONFIG_EXAMPLE_PIN_D7;
- #endif //CONFIG_EXAMPLE_EMMC_BUS_WIDTH_8
- #endif // CONFIG_SOC_SDMMC_USE_GPIO_MATRIX
- // Enable internal pullups on enabled pins. The internal pullups
- // are insufficient however, please make sure 10k external pullups are
- // connected on the bus. This is for debug / example purpose only.
- slot_config.flags |= SDMMC_SLOT_FLAG_INTERNAL_PULLUP;
- ESP_LOGI(TAG, "Mounting filesystem");
- ret = esp_vfs_fat_sdmmc_mount(mount_point, &host, &slot_config, &mount_config, &card);
- if (ret != ESP_OK) {
- if (ret == ESP_FAIL) {
- ESP_LOGE(TAG, "Failed to mount filesystem. "
- "If you want the eMMC to be formatted, set the EXAMPLE_FORMAT_IF_MOUNT_FAILED menuconfig option.");
- } else {
- ESP_LOGE(TAG, "Failed to initialize the eMMC (%s). "
- "Make sure eMMC lines have pull-up resistors in place.", esp_err_to_name(ret));
- }
- return;
- }
- ESP_LOGI(TAG, "Filesystem mounted");
- // Card has been initialized, print its properties
- sdmmc_card_print_info(stdout, card);
- // Use POSIX and C standard library functions to work with files:
- // First create a file.
- const char *file_hello = MOUNT_POINT"/hello.txt";
- ESP_LOGI(TAG, "Opening file %s", file_hello);
- FILE *f = fopen(file_hello, "w");
- if (f == NULL) {
- ESP_LOGE(TAG, "Failed to open file for writing");
- return;
- }
- fprintf(f, "Hello %s!\n", card->cid.name);
- fclose(f);
- ESP_LOGI(TAG, "File written");
- const char *file_foo = MOUNT_POINT"/foo.txt";
- // Check if destination file exists before renaming
- struct stat st;
- if (stat(file_foo, &st) == 0) {
- // Delete it if it exists
- unlink(file_foo);
- }
- // Rename original file
- ESP_LOGI(TAG, "Renaming file %s to %s", file_hello, file_foo);
- if (rename(file_hello, file_foo) != 0) {
- ESP_LOGE(TAG, "Rename failed");
- return;
- }
- // Open renamed file for reading
- ESP_LOGI(TAG, "Reading file %s", file_foo);
- f = fopen(file_foo, "r");
- if (f == NULL) {
- ESP_LOGE(TAG, "Failed to open file for reading");
- return;
- }
- // Read a line from file
- char line[64];
- fgets(line, sizeof(line), f);
- fclose(f);
- // Strip newline
- char *pos = strchr(line, '\n');
- if (pos) {
- *pos = '\0';
- }
- ESP_LOGI(TAG, "Read from file: '%s'", line);
- // All done, unmount partition and disable SDMMC peripheral
- esp_vfs_fat_sdcard_unmount(mount_point, card);
- ESP_LOGI(TAG, "Card unmounted");
- }
|