SPIFFS
0.3.7Features
-
Designed for low RAM usage on small embedded targets without dynamic memory allocation (heap).
-
Uses statically sized RAM buffers that remain independent of the number of files present.
-
Provides a POSIX-like API including open, close, read, write, seek, and stat functions.
-
Compatible with any NOR flash, including SPI flash and internal microprocessor flash.
-
Supports multiple SPIFFS configurations running concurrently on the same target or flash device.
-
Implements static wear leveling to prolong the life of flash memory by distributing erase cycles.
-
Includes built-in file system consistency checks to ensure data integrity after power loss.
-
Highly configurable through compile-time defines to adjust page/block sizes and features.
-
Supports optional file metadata for storing additional information alongside files.
-
Features index memory mapping to improve file reading performance and determinism.
-
Includes a temporal cache system to speed up file opening operations by caching file descriptors.
-
Offers a read-only build configuration to minimize the library’s binary footprint.
-
Provides both quick (non-intrusive) and full-scale (intrusive) garbage collection mechanisms.
-
Supports a flat file structure without directory support to minimize metadata overhead.
-
Includes API functions for file system formatting and retrieving usage information.
-
Allows for file renaming and explicit error code clearing via SPIFFS_clearerr.
-
Supports singleton mode to optimize performance and RAM when only one instance is used.
-
Configurable garbage collection heuristics to tune wear-leveling behavior.
-
Provides a HAL layer requiring only three basic functions: read, write, and erase.
Architecture
SPIFFS operates on a logical abstraction layer over physical NOR flash memory. It divides the flash into logical blocks, which are further subdivided into logical pages. A logical page is the smallest unit of data storage and metadata tracking. The system is designed to be entirely heap-less, relying on user-provided static buffers for work areas, file descriptors, and optional caches. This design ensures deterministic memory usage, which is critical for small embedded systems.
The file system utilizes a flat structure where filenames can include slashes to simulate paths, but no actual directory hierarchy exists. This minimizes the metadata overhead required for navigation. The architecture includes a Hardware Abstraction Layer (HAL) that requires only three primitive operations from the user: read, write, and erase. Internally, SPIFFS manages an object index to track file locations and a garbage collector that reclaims space from deleted or modified files while maintaining wear leveling across the flash blocks.
Core Components
- HAL Interface: The bridge between SPIFFS and physical flash hardware, handling address-based read, write, and erase calls.
- Object Indexer: Manages file metadata, including names, sizes, and the mapping of logical pages to physical locations.
- Garbage Collector: Implements heuristics to select blocks for erasure, balancing free space reclamation with wear leveling.
- Cache Subsystem: Provides optional read/write caching and a temporal file descriptor cache to improve performance on frequently accessed files.
- Consistency Checker: A built-in tool to verify the integrity of the file system structure and repair common issues caused by unexpected power loss.
Use Cases
This library is ideal for:
- IoT Sensors: Storing periodic sensor readings on small SPI flash chips where RAM is extremely limited.
- Configuration Management: Saving and updating device settings, calibration data, and network credentials in non-volatile memory.
- Bootloaders: Utilizing the read-only mode to load firmware images from flash while maintaining a minimal binary footprint.
- Data Logging: Efficiently appending logs to files with wear leveling to prevent premature failure of specific flash sectors.
- Embedded Web Servers: Storing static assets like HTML, CSS, and JavaScript files for local device management dashboards.
- Resource Storage: Storing UI assets, fonts, or lookup tables for microcontrollers driving small displays.
Getting Started
To integrate SPIFFS into an embedded project, begin by copying the source files from the src/ directory and the spiffs_config.h template into your build system. You must define basic integer types (e.g., u32_t, s32_t) in the configuration header to match your architecture. The integration requires implementing three HAL functions for your specific flash hardware: read, write, and erase.
Once the HAL is ready, initialize a spiffs_config struct with the physical parameters of your flash (start address, total size, and block sizes) and provide the necessary static RAM buffers for the work area and file descriptors. Call SPIFFS_mount to initialize the system. If the flash is unformatted or contains invalid data, SPIFFS_format must be called before a successful mount can occur. For detailed configuration options and performance tuning, refer to the SPIFFS Wiki.
Related Projects (153)
View All 153 Projects →Seeed Studio XIAO ESP32 Project Collection
A comprehensive development resource for the Seeed Studio XIAO ESP32 family, including the C3, S3, and C6 modules. It provides over thirty modular projects demonstrating hardware-specific features like LiPo battery monitoring, deep sleep optimization, and advanced wireless implementations such as BLE HID keyboards and WebSocket camera servers.
SQLite3 for ESP-IDF
A port of the SQLite3 relational database engine for ESP32 microcontrollers using the ESP-IDF framework. It supports ESP-IDF V5.x, offers specialized PSRAM memory management, and integrates with various filesystems including SPIFFS, LittleFS, and FATFS.
zlib Compression and Decompression for ESP-IDF
A comprehensive set of examples for integrating the zlib compression library with ESP-IDF on ESP32 series microcontrollers. It includes implementations for SPIFFS, HTTP servers, MQTT, and TCP communication, with a focus on optimizing memory footprint for embedded environments.
PathShield
PathShield is a privacy-focused RF monitoring tool for the M5StickC-Plus, designed to detect and alert users to persistent WiFi and BLE devices. It employs a multi-threaded ESP32 architecture and a sophisticated persistence scoring algorithm to distinguish potential trackers from ambient wireless noise. The system features an offline manufacturer database and customizable detection thresholds for enhanced situational awareness.
ESPRI (ESP Radio Interface)
ESPRI is an ESP32-based interface designed to extend the functionality of ham radios, such as the Quansheng UV-K5. Built using the ESP-IDF framework and FreeRTOS, it provides features like wireless UART, AFSK/Morse beacons, audio recording to SD cards, and a web-based control panel.
BugBuster
BugBuster is an open-source, four-channel analog/digital I/O debug and programming tool built around the ESP32-S3 and the Analog Devices AD74416H. It features a high-precision ADC/DAC, waveform generation, and a 32-switch MUX matrix, all managed by a FreeRTOS-based firmware and a cross-platform Tauri desktop application.
EnergyMe-Home
An open-source energy monitoring system built on the ESP32-S3 and ADE7953 IC, capable of tracking up to 17 circuits. It features a task-based FreeRTOS architecture and supports multiple integration protocols including MQTT, Modbus TCP, and InfluxDB.
ESP32-WeatherStationRTC
This ESP32-based desk clock provides real-time monitoring of temperature, atmospheric pressure, and humidity using the BME280 sensor and a DS3231 RTC. The system features an auto-dimming MAX7219 LED matrix display, WiFi-based NTP time synchronization, and a built-in web server for configuration, all developed using the Arduino framework and SPIFFS for data management.