littlefs

v2.11.2
littlefs is a fail-safe filesystem specifically designed for microcontrollers with limited resources, featuring power-loss resilience and dynamic wear leveling. It employs a unique two-layer architecture combining metadata logs and copy-on-write structures to ensure data integrity and minimize flash wear while maintaining a strictly bounded memory footprint.

Features

  • Power-loss resilience with strong copy-on-write guarantees for all file operations.

  • Dynamic wear leveling across flash blocks to extend storage lifespan.

  • Bad block detection and automatic workaround capabilities for NAND/NOR flash.

  • Strictly bounded RAM and ROM usage that remains constant regardless of filesystem size.

  • Elimination of unbounded recursion to prevent stack overflow in constrained environments.

  • Configurable, potentially static buffers to avoid dynamic memory allocation.

  • Full POSIX-like API for file and directory management.

  • Atomic POSIX operations including file removal and renaming.

  • Metadata stored in small logs called metadata pairs for efficient, low-latency updates.

  • File data stored in copy-on-write structures to prevent wear amplification.

  • C99 compliant source code for maximum portability across embedded compilers.

  • Support for multiple simultaneous filesystem instances via user-allocated state structures.

  • Data integrity verification through read-back checks during write operations.

  • Customizable block device interface for read, program, erase, and sync operations.

  • Support for custom error codes returned from underlying block device drivers.

  • Integrated test suite for PC/Linux environments using emulated block devices.

Architecture

littlefs is architected as a block-based filesystem utilizing a “two-layered cake” design to balance performance and reliability. The first layer consists of metadata pairs, which are small logs used to store directory information and file metadata. These logs allow for fast, frequent updates to metadata anywhere on the storage medium without requiring large-scale erases. The second layer uses larger copy-on-write (COW) structures to store actual file data, ensuring that data is stored compactly and that updates do not cause unnecessary wear amplification.

At the core of the system is a common block allocator that services both metadata and data structures. This allocator implements dynamic wear leveling by tracking and limiting the number of erases allowed on a block per allocation cycle. The system is designed to be entirely reentrant and supports multiple instances by requiring the user to provide the state storage (lfs_t) and configuration (lfs_config). This design ensures that RAM usage is strictly bounded and predictable, as the filesystem does not use recursion or unbounded dynamic memory allocation.

Use Cases

This library is ideal for:

  • IoT Edge Devices: Systems requiring high reliability during unpredictable power cycles or battery failures.
  • Data Logging: Applications that need to write data frequently to flash while maximizing the lifespan of the hardware through wear leveling.
  • Embedded Firmware Storage: Storing system configurations and firmware images where corruption could lead to device bricking.
  • Resource-Constrained MCUs: Microcontrollers with very limited RAM (e.g., <10KB) where a traditional filesystem would be too heavy.
  • NAND/NOR Flash Management: Devices using raw flash chips that require manual bad block management and wear leveling.

Getting Started

To integrate littlefs, developers must first define a lfs_config structure that specifies the block device dimensions (read size, program size, block size, and count) and provides function pointers for the hardware-specific read, prog, erase, and sync operations. Once the configuration is defined, the filesystem can be initialized using lfs_mount. If the mount fails (common on first boot), lfs_format can be called to create a fresh filesystem.

Detailed API documentation is located within the lfs.h header file. For developers looking to port the library, the DESIGN.md and SPEC.md files in the repository provide deep dives into the on-disk format and architectural tradeoffs. Testing can be performed on a development PC using the provided emulated block device and the Python-based test runner found in the scripts directory.

Related Projects (107)

View All 107 Projects →

AutoNetwork Library

A modern WiFi connection manager for ESP32 applications using the Arduino framework. It provides a captive portal for credential configuration, persistent storage in NVS, and non-blocking operation integrated with ESPAsyncWebServer.

freertos littlefs
16

AyresWiFiManager (AWM)

A professional Wi-Fi manager for ESP32 and ESP8266 microcontrollers featuring a real captive portal and modern UI served from LittleFS. It provides robust credential storage, configurable fallback policies, NTP synchronization, and integrated status LED/button handling.

freertos littlefs
15
OpenFIRE Firmware for ESP32

OpenFIRE Firmware for ESP32

An ESP32S3 port of the OpenFIRE light gun firmware, providing open-source light gun capabilities with IR tracking and force feedback. It introduces wireless connectivity using the ESP-NOW protocol and supports both ESP32S3 and RP2040 microcontrollers.

freertos littlefsspiffs
11

GeekMagic Open Firmware

An open-source firmware for ESP8266-based GeekMagic devices like the HelloCubic Lite and Smalltv-Ultra. It provides a complete replacement for the factory software, featuring a custom ST7789 display driver, LittleFS storage, and a web-based configuration interface.

littlefs
34

Open Display Firmware

A firmware solution for Bluetooth Low Energy (BLE) electronic display tags supporting NRF52840 and ESP32 microcontrollers. It provides a framework for managing e-paper displays, configuring tag settings, and uploading images over BLE. The project is built using the Arduino framework and PlatformIO.

freertos littlefs
13
PIXLPAL-M1 Firmware

PIXLPAL-M1 Firmware

A modular AIoT firmware for the Pixlpal desktop companion based on the ESP32-S3 SoC. It utilizes the ESP-IDF framework and FreeRTOS to power an interactive 128x64 RGB LED matrix display with features like Wi-Fi connectivity, BLE control, and audio processing.

freertos littlefslwipnimble
11
ESPTimeCast

ESPTimeCast

A WiFi-connected LED matrix clock and weather display built for ESP8266 and ESP32 microcontrollers. It utilizes the MAX7219 driver to display real-time NTP clock data and live weather updates from OpenWeatherMap, all configurable via a built-in web interface.

littlefs
1,026
Smart Sign Language Glove Translator

Smart Sign Language Glove Translator

An ESP32-powered wearable device that translates sign language gestures into spoken or text-based output. It utilizes a K-Nearest Neighbors (KNN) algorithm for real-time gesture classification and features a web-based 3D visualization tool built with Three.js.

freertos littlefs
14