esp-idf/examples/storage/fatfsgen
Kevin (Lao Kaiyao) 432864e917 Merge branch 'ci/enable_c5_mp_ci_jobs' into 'master'
ci(esp32c5mp): enable esp32c5 build on CI

See merge request espressif/esp-idf!29895
2024-04-08 12:16:16 +08:00
..
fatfs_image support for wear levelling in fatfs partition generator 2021-11-29 16:57:47 +01:00
fatfs_long_name_image fatfsgen.py: enabled long names support 2022-03-11 11:20:31 +01:00
main feat(fatfs): Add an option to use 2 FATs (file allocation tables) in FATFS volumes 2024-01-18 14:03:28 +01:00
CMakeLists.txt tools: Increase the minimal supported CMake version to 3.16 2022-06-01 06:35:02 +00:00
partitions_example.csv support for generating FATFS on a host 2021-11-03 13:06:11 +01:00
pytest_fatfsgen_example.py ci: fix pytest generic env markers 2024-04-03 18:10:43 +08:00
README.md ci(esp32c5mp): disable the unsupported tests 2024-04-07 12:13:29 +08:00
sdkconfig.ci.test_read_only_partition_gen fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_only_partition_gen_default_dt fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_only_partition_gen_ln fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_only_partition_gen_ln_default_dt fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_write_partition_gen fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_write_partition_gen_default_dt fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_write_partition_gen_ln fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.ci.test_read_write_partition_gen_ln_default_dt fatfsparse.py: Add support for WL 2022-07-26 14:50:07 +02:00
sdkconfig.defaults support for generating FATFS on a host 2021-11-03 13:06:11 +01:00

Supported Targets ESP32 ESP32-C2 ESP32-C3 ESP32-C5 ESP32-C6 ESP32-H2 ESP32-P4 ESP32-S2 ESP32-S3

FATFS partition generation example

(See the README.md file in the upper level 'examples' directory for more information about examples.)

This example demonstrates how to use the FATFS partition generation tool fatfsgen.py to automatically create a FATFS filesystem image from the contents of a host folder during build, with an option of automatically flashing the created image on invocation of idf.py -p PORT flash. Beware that the minimal required size of the flash is 4 MB. You can specify using menuconfig weather example will use read-only or read-write mode. The default option is read-write mode. To change it just use menuconfig:

idf.py menuconfig

Then select Example Configuration a chose Mode for generated FATFS image either Read-Write Mode or Read-Only Mode. Read-Only option indicates generating raw fatfs image without wear levelling support. On the other hand, for Read-Write the generated fatfs image will support wear levelling thus can be mounted in read-write mode.

The following gives an overview of the example:

  1. There is a directory fatfs_image from which the FATFS filesystem image will be created.

  2. The function fatfs_create_rawflash_image is used to specify that a FATFS image should be created during build for the storage partition. For CMake, it is called from the main component's CMakeLists.txt. FLASH_IN_PROJECT specifies that the created image should be flashed on invocation of idf.py -p PORT flash together with app, bootloader, partition table, etc. The image is created on the example's build directory with the output filename storage.bin.

  3. Upon invocation of idf.py -p PORT flash monitor, application loads and finds there is already a valid FATFS filesystem in the storage partition with files same as those in fatfs_image directory. The application is then able to read those files.

How to use example

Build and flash

To run the example, type the following command:

# CMake
idf.py -p PORT flash monitor

(To exit the serial monitor, type Ctrl-].)

See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects.

Example output

Here is the example's console output:

...
I (322) example: Mounting FAT filesystem
I (332) example: Reading file
I (332) example: Read from file: 'this is test'
I (332) example: Unmounting FAT filesystem
I (342) example: Done

The logic of the example is contained in a single source file, and it should be relatively simple to match points in its execution with the log outputs above.