This is a wrapper for the LittleFS File System for the Teensy family of microprocessors and provides support for RAM Disks, NOR and NAND Flash chips, and FRAM chips. For the NOR, NAND Flash support is provided for SPI and QSPI in the case of the Teensy 4.1. For FRAM only SPI is supported.
In addition, LittleFS is linked with the SD library so the user can create, delete, read/write files to any of the supported memory type. See usuage section.
MFG | PART # | Size |
---|---|---|
Winbond | W25Q16JV*IQ/W25Q16FV | 16Mb |
... | W25Q32JV*IQ/W25Q32FV | 32Mb |
... | W25Q64JV*IQ/W25Q64FV | 64Mb |
... | W25Q128JV*IQ/W25Q128FV | 128Mb |
... | W25Q256JV*IQ | 256Mb |
... | Winbond W25Q512JV*IQ | 512Mb |
... | W25Q64JV*IM (DTR) | 64Mb |
... | W25Q128JV*IM (DTR) | 128Mb |
... | W25Q256JV*IM (DTR) | 256Mb |
... | W25Q512JV*IM (DTR) | 512Mb |
Adesto/Atmel | AT25SF041 | 4Mb |
Spansion | S25FL208K | 8Mb |
MFG | PART # | Size |
---|---|---|
Winbond | W25N01G | 1Gb |
... | W25N02G | 2Gb |
... | W25M02 | 2Gb |
MFG | PART # | Size |
---|---|---|
Cypress | CY15B108QN-40SXI | 8Mb |
... | FM25V10-G | 1Mb |
... | FM25V10-G rev1 | 1Mb |
... | CY15B104Q-SXI | 4Mb |
... | CY15B102Q-SXI | 2Mb |
ROHM | MR45V100A | 1Mb |
Fujitsu | MB85RS2MTAPNF | 2Mb |
Fujitsu | MB85RS4MT | 4Mb |
NOTE: This option is only available on the Teensy 4.0, Teensy 4.1 and Teensy Micromod boards.
Creates the filesystem using program memory. The begin function expects a size in bytes, for the amount of the program memory you wish to use. It must be at least 65536 and smaller than the actual unused program space. All interrupts are disabled during writing and erasing, so use of this storage does come with pretty substantial impact on interrupt latency for other libraries. Uploading new code by Teensy Loader completely wipes the unused program space, erasing all stored files. But the filesystem persists across reboots and power cycling.
To create a disk in program memory the following constructor is used:
LittleFS_Program myfs;
In setup space is allocated int program memory by specifing space in the begin statement:
if (!myfs.begin(1024 * 1024 * 6)) {
Serial.printf("Error starting %s\n", "Program flash DISK");
}
A RAM disk can be setup to use space on the PSRAM chip in the case of the Teensy 4.1 or to use DMAMEM or RAM space on the Teensy itself. If using DMAMEM or RAM the amount of available space to create these disks to going to be dependent on the Teensy model you are using so be careful. Not to worry though it will let you know if you are out of space on compile.
To create a RAM disk you need to first allocate the space based on the type of memory area, for the Teensy 4.1 for example you can use these settings:
EXTMEM char buf[8 * 1024 * 1024];
This allocates all 8Mb of the PSRAM for the RAM disk.DMAMEM char buf[490000];
This allocates 490K of the DMAMEMchar buf[390000];
This allocates 390K of RAM
Afer allocating space you specify that you want to create a RAM Disk:
LittleFS_RAM myfs;
In setup you have to specify to begin using the memory area:
if (!myfs.begin(buf, sizeof(buf))) {
Serial.printf("Error starting %s\n", "RAM DISK);
}
At this point you can access or create files in the same manner as you would with an SD Card using the SD Library bundled with Teensyduino. See the examples section for creating and writing a file.
QSPI is only supported on the Teensy 4.1. These are the Flash chips that you would solder onto the bottom side of the Teesny 4.1. To access Flash NOR or NAND chips QSPI is similar to the RAM disk:
- For a NAND Flash chip use the following construtor:
LittleFS_QPINAND myfs;
- For a NOR flash
LittleFS_QSPIFlash myfs;
And then in setup all you need for the NAND or NOR QSPI is:
if (!myfs.begin() {
Serial.printf("Error starting %s\n", "QSPI");
}
For SPI, three constructors are availble - NOR Flash, NAND Flash and FRAM
LittleFS_SPIFlash myfs;
LittleFS_SPINAND myfs;
LittleFS_SPIFram myfs;
For SPI the begin
statement requires the user to specify the Chip Select pin and optionally which SPI port to use:
myfs.begin(CSpin, SPIport);
By default the SPI port is SPI, use SPI1, SPI2 etc for other ports.
Several examples are provided. A simple example is as follows for a datalogger for a SPI NAND
/*
LittleFS datalogger
This example shows how to log data from three analog sensors
to an storage device such as a FLASH.
This example code is in the public domain.
*/
#include <LittleFS.h>
LittleFS_SPINAND myfs; //Specifies to use an SPI NOR Flash attached to SPI
const int chipSelect = 4;
void setup()
{
// Open serial communications and wait for port to open:
Serial.begin(9600);
while (!Serial) {
// wait for serial port to connect.
}
Serial.print("Initializing SPI FLASH...");
// see if the Flash is present and can be initialized:
if (!myfs.begin(chipSelect, SPI)) {
Serial.printf("Error starting %s\n", "SPI FLASH");
while (1) {
// Flash error, so don't do anything more - stay stuck here
}
}
Serial.println("Flash initialized.");
}
void loop()
{
// make a string for assembling the data to log:
String dataString = "";
// read three sensors and append to the string:
for (int analogPin = 0; analogPin < 3; analogPin++) {
int sensor = analogRead(analogPin);
dataString += String(sensor);
if (analogPin < 2) {
dataString += ",";
}
}
// open the file.
File dataFile = myfs.open("datalog.txt", FILE_WRITE);
// if the file is available, write to it:
if (dataFile) {
dataFile.println(dataString);
dataFile.close();
// print to the serial port too:
Serial.println(dataString);
} else {
// if the file isn't open, pop up an error:
Serial.println("error opening datalog.txt");
}
delay(100); // run at a reasonable not-too-fast speed
}
This is an example taked from the SD library. Basically instead of specifying the SD library you specify to use the littleFS library on the first line as shown in the example. Then using our methods for specifing which memory to use all we did was substitute "myfs" for where "SD" was specified before.