/* * SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: CC0 */ #include #include #include #include "esp_vfs.h" #include "esp_vfs_fat.h" #include "esp_system.h" #include "sdkconfig.h" #if CONFIG_EXAMPLE_FATFS_MODE_READ_ONLY #define EXAMPLE_FATFS_MODE_READ_ONLY true #else #define EXAMPLE_FATFS_MODE_READ_ONLY false #endif static const char *TAG = "example"; // Mount path for the partition const char *base_path = "/spiflash"; // Handle of the wear levelling library instance static wl_handle_t s_wl_handle = WL_INVALID_HANDLE; void app_main(void) { ESP_LOGI(TAG, "Mounting FAT filesystem"); // To mount device we need name of device partition, define base_path // and allow format partition in case if it is new one and was not formatted before const esp_vfs_fat_mount_config_t mount_config = { .max_files = 4, .format_if_mount_failed = false, .allocation_unit_size = CONFIG_WL_SECTOR_SIZE }; esp_err_t err; if (EXAMPLE_FATFS_MODE_READ_ONLY){ err = esp_vfs_fat_rawflash_mount(base_path, "storage", &mount_config); } else { err = esp_vfs_fat_spiflash_mount(base_path, "storage", &mount_config, &s_wl_handle); } if (err != ESP_OK) { ESP_LOGE(TAG, "Failed to mount FATFS (%s)", esp_err_to_name(err)); return; } char line[128]; if (!EXAMPLE_FATFS_MODE_READ_ONLY){ // Open file for reading ESP_LOGI(TAG, "Opening file"); FILE *f = fopen("/spiflash/inner.txt", "wb"); if (f == NULL) { ESP_LOGE(TAG, "Failed to open file for writing"); return; } fprintf(f, "This is written by the device"); fclose(f); ESP_LOGI(TAG, "File written"); // Open file for reading ESP_LOGI(TAG, "Reading file"); f = fopen("/spiflash/inner.txt", "rb"); if (f == NULL) { ESP_LOGE(TAG, "Failed to open file for reading"); return; } 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); } FILE *f; char *pos; ESP_LOGI(TAG, "Reading file"); if (EXAMPLE_FATFS_MODE_READ_ONLY){ f = fopen("/spiflash/sub/test.txt", "rb"); } else { f = fopen("/spiflash/hello.txt", "rb"); } if (f == NULL) { ESP_LOGE(TAG, "Failed to open file for reading"); return; } fgets(line, sizeof(line), f); fclose(f); // strip newline pos = strchr(line, '\n'); if (pos) { *pos = '\0'; } ESP_LOGI(TAG, "Read from file: '%s'", line); // Unmount FATFS ESP_LOGI(TAG, "Unmounting FAT filesystem"); if (EXAMPLE_FATFS_MODE_READ_ONLY){ ESP_ERROR_CHECK(esp_vfs_fat_rawflash_unmount(base_path, "storage")); } else { ESP_ERROR_CHECK(esp_vfs_fat_spiflash_unmount(base_path, s_wl_handle)); } ESP_LOGI(TAG, "Done"); }