1.. zephyr:code-sample:: littlefs 2 :name: LittleFS filesystem 3 :relevant-api: file_system_api flash_area_api 4 5 Use file system API over LittleFS. 6 7Overview 8******** 9 10This sample app demonstrates use of Zephyr's :ref:`file system API 11<file_system_api>` over `littlefs`_, using file system with files that: 12* count the number of times the system has booted 13* holds binary pattern with properly incremented values in it 14 15Other information about the file system is also displayed. 16 17.. _littlefs: 18 https://github.com/ARMmbed/littlefs 19 20Requirements 21************ 22 23Flash memory device 24------------------- 25 26The partition labeled "storage" will be used for the file system; see 27:ref:`flash_map_api`. If that area does not already have a 28compatible littlefs file system its contents will be replaced by an 29empty file system. You will see diagnostics like this:: 30 31 [00:00:00.010,192] <inf> littlefs: LittleFS version 2.0, disk version 2.0 32 [00:00:00.010,559] <err> littlefs: Corrupted dir pair at 0 1 33 [00:00:00.010,559] <wrn> littlefs: can't mount (LFS -84); formatting 34 35The error and warning are normal for a new file system. 36 37After the file system is mounted you'll also see:: 38 39 [00:00:00.182,434] <inf> littlefs: filesystem mounted! 40 [00:00:00.867,034] <err> fs: failed get file or dir stat (-2) 41 42This error is also normal for Zephyr not finding a file (the boot count, 43in this case). 44 45Block device (e.g. SD card) 46--------------------------- 47 48One needs to prepare the SD/MMC card with littlefs file system on 49the host machine with the `lfs`_ program. 50 51.. _lfs: 52 https://www.thevtool.com/mounting-littlefs-on-linux-machine/ 53 54.. code-block:: console 55 56 sudo chmod a+rw /dev/sda 57 lfs -d -s -f --read_size=512 --prog_size=512 --block_size=512 --cache_size=512 --lookahead_size=8192 --format /dev/sda 58 lfs -d -s -f --read_size=512 --prog_size=512 --block_size=512 --cache_size=512 --lookahead_size=8192 /dev/sda ./mnt_littlefs 59 cd ./mnt_littlefs 60 echo -en '\x01' > foo.txt 61 cd - 62 fusermount -u ./mnt_littlefs 63 64 65Building and Running 66******************** 67 68Flash memory device 69------------------- 70 71This example should work on any board that provides a "storage" 72partition. Two tested board targets are described below. 73 74You can set ``CONFIG_APP_WIPE_STORAGE`` to force the file system to be 75recreated. 76 77Block device (e.g. SD card) 78--------------------------- 79 80This example has been devised and initially tested on :zephyr:board:`nucleo_h743zi` 81board. It can be also run on any other board with SD/MMC card connected to it. 82 83To build the test: 84 85.. zephyr-app-commands:: 86 :zephyr-app: samples/subsys/fs/littlefs 87 :board: nucleo_h743zi 88 :goals: build flash 89 :gen-args: -DCONF_FILE=prj_blk.conf 90 :compact: 91 92At the moment, only two types of block devices are acceptable in this sample: SDMMC and MMC. 93 94It is possible that both the ``zephyr,sdmmc-disk`` and ``zephyr,mmc-disk`` block devices will be 95present and enabled in the final board dts and configuration files simultaneously, the mount 96point name for the ``littlefs`` file system block device will be determined based on the 97following logic: 98 99* if the :kconfig:option:`CONFIG_DISK_DRIVER_SDMMC` configuration is defined, ``"SD"`` 100 will be used as the mount point name; 101* if the :kconfig:option:`CONFIG_DISK_DRIVER_SDMMC` configuration is not defined, but the 102 :kconfig:option:`CONFIG_DISK_DRIVER_MMC` configuration is defined, ``"SD2"`` will 103 be used as the mount point name; 104* if neither :kconfig:option:`CONFIG_DISK_DRIVER_SDMMC` nor :kconfig:option:`CONFIG_DISK_DRIVER_MMC` 105 configurations are defined, the mount point name will not be determined, and an appropriate error 106 will appear during the sample build. 107 108NRF52840 Development Kit 109======================== 110 111On this device the file system will be placed in the SOC flash. 112 113.. zephyr-app-commands:: 114 :zephyr-app: samples/subsys/fs/littlefs 115 :board: nrf52840dk/nrf52840 116 :goals: build 117 :compact: 118 119Particle Xenon 120============== 121 122On this device the file system will be placed on the external SPI NOR 123flash memory. 124 125.. zephyr-app-commands:: 126 :zephyr-app: samples/subsys/fs/littlefs 127 :board: particle_xenon 128 :goals: build 129 :compact: 130