ESPixelStick Firmware
Firmware for the ESPixelStick
Loading...
Searching...
No Matches
FileMgr.hpp
Go to the documentation of this file.
1#pragma once
2/*
3* FileMgr.hpp - Output Management class
4*
5* Project: ESPixelStick - An ESP8266 / ESP32 and E1.31 based pixel driver
6* Copyright (c) 2021, 2025 Shelby Merrick
7* http://www.forkineye.com
8*
9* This program is provided free for you to use in any way that you wish,
10* subject to the laws and regulations where you are using it. Due diligence
11* is strongly suggested before using this code. Please give credit where due.
12*
13* The Author makes no warranty of any kind, express or implied, with regard
14* to this program or the documentation contained in this document. The
15* Author shall not be liable in any event for incidental or consequential
16* damages in connection with, or arising out of, the furnishing, performance
17* or use of these programs.
18*
19*/
20
21#include "ESPixelStick.h"
22#include <LittleFS.h>
23#ifdef SUPPORT_SD_MMC
24# include <SD_MMC.h>
25#endif // def SUPPORT_SD_MMC
26#include "SdFat.h"
27#include <map>
28#include <vector>
29
30#ifdef ARDUINO_ARCH_ESP32
31# ifdef SUPPORT_SD_MMC
32# define ESP_SD SD_MMC
33# define ESP_SDFS SD_MMC
34# else // !def SUPPORT_SD_MMC
35extern SdFat sd;
36# define ESP_SD sd
37# define ESP_SDFS SdFile
38# endif // !def SUPPORT_SD_MMC
39#else // !ARDUINO_ARCH_ESP32
40# define ESP_SD sd
41# define ESP_SDFS SdFile
42#endif // !ARDUINO_ARCH_ESP32
43
45{
46public:
47 c_FileMgr ();
48 virtual ~c_FileMgr ();
49
50 typedef uint32_t FileId;
51 const static FileId INVALID_FILE_HANDLE = 0;
52
53 void Begin ();
54 void Poll ();
55 void GetConfig (JsonObject& json);
56 bool SetConfig (JsonObject& json);
57 void GetStatus (JsonObject& json);
58 void UpdateFtp ();
59
60 bool handleFileUpload (const String & filename, size_t index, uint8_t * data, size_t len, bool final, uint32_t totalLen);
61 void AbortSdFileUpload();
62
63 typedef std::function<void (JsonDocument& json)> DeserializationHandler;
64
65 typedef enum
66 {
70 } FileMode;
71
72 void DeleteFlashFile (String FileName);
73 void RenameFlashFile (String OldName, String NewName);
74 bool SaveFlashFile (const String & FileName, String & FileData);
75 bool SaveFlashFile (const String & FileName, const char * FileData);
76 bool SaveFlashFile (const String & FileName, JsonDocument & FileData);
77 bool SaveFlashFile (const String & filename, uint32_t index, uint8_t *data, uint32_t len, bool final);
78
79 bool ReadFlashFile (const String & FileName, String & FileData);
80 bool ReadFlashFile (const String & FileName, JsonDocument & FileData);
81 bool ReadFlashFile (const String & FileName, byte * FileData, size_t maxlen);
82 bool LoadFlashFile (const String & FileName, DeserializationHandler Handler);
83 bool FlashFileExists (const String & FileName);
84
87 void DeleteSdFile (const String & FileName);
88 void SaveSdFile (const String & FileName, String & FileData);
89 void SaveSdFile (const String & FileName, JsonVariant & FileData);
90 bool OpenSdFile (const String & FileName, FileMode Mode, FileId & FileHandle, int FileListIndex);
91 uint64_t ReadSdFile (const FileId & FileHandle, byte * FileData, uint64_t NumBytesToRead, uint64_t StartingPosition);
92 bool ReadSdFile (const String & FileName, String & FileData);
93 bool ReadSdFile (const String & FileName, JsonDocument & FileData);
94 uint64_t WriteSdFileBuf (const FileId & FileHandle, byte * FileData, uint64_t NumBytesToWrite);
95 uint64_t WriteSdFile (const FileId & FileHandle, byte * FileData, uint64_t NumBytesToWrite);
96 uint64_t WriteSdFile (const FileId & FileHandle, byte * FileData, uint64_t NumBytesToWrite, uint64_t StartingPosition);
97 void CloseSdFile (FileId & FileHandle);
98 void GetListOfSdFiles (std::vector<String> & Response);
99 uint64_t GetSdFileSize (const String & FileName);
100 uint64_t GetSdFileSize (const FileId & FileHandle);
101 void RenameSdFile (String & OldName, String & NewName);
102 void BuildFseqList (bool DisplayFileNames);
103
104 void GetDriverName (String& Name) { Name = F("FileMgr"); }
105 void NetworkStateChanged (bool NewState);
106 void FindFirstZipFile (String &FileName);
107 int FileListFindSdFileHandle (FileId HandleToFind);
108
109#define SD_BLOCK_SIZE 512
110
111#if defined ARDUINO_ARCH_ESP8266
112# define MAX_SD_BUFFER_SIZE (4 * SD_BLOCK_SIZE)
113#else
114# define MAX_SD_BUFFER_SIZE (14 * SD_BLOCK_SIZE)
115#endif
116
117#define ConnrectFilename(n) \
118{ \
119 if(0 != n.indexOf("/")) \
120 { \
121 n = String("/") + n; \
122 } \
123}
124
125private:
126 void SetSpiIoPins ();
127 void SetSdSpeed ();
128 void ResetSdCard ();
129 void LockSd();
130 void UnLockSd();
131 bool SeekSdFile(const FileId & FileHandle, uint64_t position, SeekMode Mode);
132 void BuildDefaultFseqList ();
133
134# define SD_CARD_CLK_MHZ SD_SCK_MHZ(37) // 50 MHz SPI clock
135#ifndef MaxSdTransSpeedMHz
136# define MaxSdTransSpeedMHz 200
137#endif // ndef MaxSdTransSpeedMHz
138
139 void listDir (fs::FS& fs, String dirname, uint8_t levels);
140 void DescribeSdCardToUser ();
141 void handleFileUploadNewFile (const String & filename);
142 void printDirectory (FsFile & dir, int numTabs);
143
144 bool SdCardInstalled = false;
153 String FtpUserName = "esps";
154 String FtpPassword = "esps";
155 String WelcomeString = "ESPS V4 FTP";
156 bool FtpEnabled = true;
157 uint64_t SdCardSizeMB = 0;
159 bool FoundZipFile = false;
160 const String FSEQFILELIST = "/fseqfilelist.json";
161
162public: struct __attribute__((__packed__, aligned(4))) CSD {
163 public: union {
164 public: struct __attribute__((__packed__, aligned(1))) {
165 public: enum {
166 CSD_VERSION_1 = 0, // enum CSD version 1.0 - 1.1, Version 2.00/Standard Capacity
167 CSD_VERSION_2 = 1, // enum CSD cersion 2.0, Version 2.00/High Capacity and Extended Capacity
168 } csd_structure : 2; // @127-126 CSD Structure Version as on SD CSD bits
169 unsigned spec_vers : 6; // @125-120 CSD version as on SD CSD bits
170 uint8_t taac; // @119-112 taac as on SD CSD bits
171 uint8_t nsac; // @111-104 nsac as on SD CSD bits
172 uint8_t tran_speed; // @103-96 trans_speed as on SD CSD bits
173 }Decode_0;
174 public: uint32_t Raw32_0; // @127-96 Union to access 32 bits as a uint32_t
175 };
176 public: union {
177 public: struct __attribute__((__packed__, aligned(1))) {
178 unsigned ccc : 12; // @95-84 ccc as on SD CSD bits
179 unsigned read_bl_len : 4; // @83-80 read_bl_len on SD CSD bits
180 unsigned read_bl_partial : 1; // @79 read_bl_partial as on SD CSD bits
181 unsigned write_blk_misalign : 1; // @78 write_blk_misalign as on SD CSD bits
182 unsigned read_blk_misalign : 1; // @77 read_blk_misalign as on SD CSD bits
183 unsigned dsr_imp : 1; // @76 dsr_imp as on SD CSD bits
184 unsigned c_size : 12; // @75-64 Version 1 C_Size as on SD CSD bits
185 };
186 public: uint32_t Raw32_1; // @0-31 Union to access 32 bits as a uint32_t
187 };
188 public: union {
189 public: struct __attribute__((__packed__, aligned(1))) {
190 public: union {
191 public: struct __attribute__((__packed__, aligned(1))) {
192 unsigned vdd_r_curr_min : 3; // @61-59 vdd_r_curr_min as on SD CSD bits
193 unsigned vdd_r_curr_max : 3; // @58-56 vdd_r_curr_max as on SD CSD bits
194 unsigned vdd_w_curr_min : 3; // @55-53 vdd_w_curr_min as on SD CSD bits
195 unsigned vdd_w_curr_max : 3; // @52-50 vdd_w_curr_max as on SD CSD bits
196 unsigned c_size_mult : 3; // @49-47 c_size_mult as on SD CSD bits
197 unsigned reserved0 : 7; // reserved for CSD ver 2.0 size match
198 };
199 unsigned ver2_c_size : 22; // Version 2 C_Size
200 };
201 unsigned erase_blk_en : 1; // @46 erase_blk_en as on SD CSD bits
202 unsigned sector_size : 7; // @45-39 sector_size as on SD CSD bits
203 unsigned reserved1 : 2; // 2 Spares bit unused
204 };
205 public: uint32_t Raw32_2; // @0-31 Union to access 32 bits as a uint32_t
206 };
207 public: union {
208 public: struct __attribute__((__packed__, aligned(1))) {
209 unsigned wp_grp_size : 7; // @38-32 wp_grp_size as on SD CSD bits
210 unsigned wp_grp_enable : 1; // @31 wp_grp_enable as on SD CSD bits
211 unsigned reserved2 : 2; // @30-29 Write as zero read as don't care
212 unsigned r2w_factor : 3; // @28-26 r2w_factor as on SD CSD bits
213 unsigned write_bl_len : 4; // @25-22 write_bl_len as on SD CSD bits
214 unsigned write_bl_partial : 1; // @21 write_bl_partial as on SD CSD bits
215 unsigned default_ecc : 5; // @20-16 default_ecc as on SD CSD bits
216 unsigned file_format_grp : 1; // @15 file_format_grp as on SD CSD bits
217 unsigned copy : 1; // @14 copy as on SD CSD bits
218 unsigned perm_write_protect : 1; // @13 perm_write_protect as on SD CSD bits
219 unsigned tmp_write_protect : 1; // @12 tmp_write_protect as on SD CSD bits
220 public: enum {
221 // FAT_PARTITION_TABLE = 0, // enum SD card is FAT with partition table
222 // FAT_NO_PARTITION_TABLE = 1, // enum SD card is FAT with no partition table
223 // FS_UNIVERSAL = 2, // enum SD card file system is universal
224 // FS_OTHER = 3, // enum SD card file system is other
225 } file_format : 2; // @11-10 File format as on SD CSD bits
226 unsigned ecc : 2; // @9-8 ecc as on SD CSD bits
227 unsigned reserved3 : 1; // 1 spare bit unused
228 };
229 public: uint32_t Raw32_3; // @0-31 Union to access 32 bits as a uint32_t
230 };
231};
232#define MaxOpenFiles 5
234 {
236 FsFile fsFile;
237 uint64_t size = 0;
238 int entryId = -1;
239 String Filename = emptyString;
241 bool IsOpen = false;
242 struct
243 {
244 byte *DataBuffer = nullptr;
245 uint64_t size = 0;
246 uint64_t offset = 0;
248 };
249#define DATABUFFERSIZE (5 * 1024)
250
252 void InitSdFileList ();
253
255 uint32_t LastFileSent = 0;
256 uint32_t expectedIndex = 0;
257
258#ifdef ARDUINO_ARCH_ESP32
259 SemaphoreHandle_t SdAccessSemaphore = NULL;
260#endif // def ARDUINO_ARCH_ESP32
261
262protected:
263
264}; // c_FileMgr
265
266#ifdef DEBUG_FILE_HANDLES
267#define DEBUG_FILE_HANDLE(fh) \
268{ \
269 if (fh == c_FileMgr::INVALID_FILE_HANDLE) \
270 { \
271 DEBUG_V(String(F("Found an invalid file handle before a request to FileMgr. File Handle: ")) + String(fh)); \
272 } \
273 else \
274 { \
275 if (-1 == FileMgr.FileListFindSdFileHandle (fh)) \
276 { \
277 DEBUG_V(String(F("Could not look up File Handle: ")) + String(fh)); \
278 } \
279 } \
280}
281#else
282#define DEBUG_FILE_HANDLE(fh)
283#endif // def DEBUG_FILE_HANDLE
284
285extern c_FileMgr FileMgr;
SdFs sd
Definition FileMgr.cpp:30
c_FileMgr FileMgr
Definition FileMgr.cpp:2224
#define MaxOpenFiles
Definition FileMgr.hpp:232
#define MaxSdTransSpeedMHz
Definition FileMgr.hpp:136
#define SD_CARD_MISO_PIN
Definition GPIO_Defs_ESP32_Bong69.hpp:42
#define SD_CARD_CS_PIN
Definition GPIO_Defs_ESP32_Bong69.hpp:45
#define SD_CARD_MOSI_PIN
Definition GPIO_Defs_ESP32_Bong69.hpp:43
#define SD_CARD_CLK_PIN
Definition GPIO_Defs_ESP32_Bong69.hpp:44
Definition FileMgr.hpp:45
FileId CreateSdFileHandle()
Definition FileMgr.cpp:1049
void printDirectory(FsFile &dir, int numTabs)
Definition FileMgr.cpp:1185
void GetListOfSdFiles(std::vector< String > &Response)
Definition FileMgr.cpp:1125
bool FoundZipFile
Definition FileMgr.hpp:159
void SetSdSpeed()
Definition FileMgr.cpp:500
bool SeekSdFile(const FileId &FileHandle, uint64_t position, SeekMode Mode)
Definition FileMgr.cpp:2134
void SaveSdFile(const String &FileName, String &FileData)
Definition FileMgr.cpp:1226
void BuildDefaultFseqList()
Definition FileMgr.cpp:2115
String fsUploadFileName
Definition FileMgr.hpp:150
void GetConfig(JsonObject &json)
Definition FileMgr.cpp:311
bool OpenSdFile(const String &FileName, FileMode Mode, FileId &FileHandle, int FileListIndex)
Definition FileMgr.cpp:1262
static const FileId INVALID_FILE_HANDLE
Definition FileMgr.hpp:51
void InitSdFileList()
Definition FileMgr.cpp:1005
File FileSendDir
Definition FileMgr.hpp:254
c_FileMgr()
< Start up the driver and put it into a safe mode
Definition FileMgr.cpp:143
void Begin()
< Start the module
Definition FileMgr.cpp:163
void DeleteSdFile(const String &FileName)
Definition FileMgr.cpp:1086
uint8_t clk_pin
Definition FileMgr.hpp:147
uint8_t cs_pin
Definition FileMgr.hpp:148
uint32_t LastFileSent
Definition FileMgr.hpp:255
void listDir(fs::FS &fs, String dirname, uint8_t levels)
Definition FileMgr.cpp:625
uint64_t SdCardSizeMB
Definition FileMgr.hpp:157
void GetStatus(JsonObject &json)
Definition FileMgr.cpp:330
void LockSd()
Definition FileMgr.cpp:2187
bool LoadFlashFile(const String &FileName, DeserializationHandler Handler)
Definition FileMgr.cpp:668
int FileListFindSdFileHandle(FileId HandleToFind)
Definition FileMgr.cpp:1021
FileListEntry_t FileList[MaxOpenFiles]
Definition FileMgr.hpp:251
uint64_t ReadSdFile(const FileId &FileHandle, byte *FileData, uint64_t NumBytesToRead, uint64_t StartingPosition)
Definition FileMgr.cpp:1452
std::function< void(JsonDocument &json)> DeserializationHandler
Definition FileMgr.hpp:63
const String FSEQFILELIST
Definition FileMgr.hpp:160
uint32_t MaxSdSpeed
Definition FileMgr.hpp:158
void FindFirstZipFile(String &FileName)
Definition FileMgr.cpp:1887
String FtpPassword
Definition FileMgr.hpp:154
virtual ~c_FileMgr()
< deallocate any resources and put the output channels into a safe state
Definition FileMgr.cpp:153
void UnLockSd()
Definition FileMgr.cpp:2199
String WelcomeString
Definition FileMgr.hpp:155
String FtpUserName
Definition FileMgr.hpp:153
uint8_t mosi_pin
Definition FileMgr.hpp:146
bool handleFileUpload(const String &filename, size_t index, uint8_t *data, size_t len, bool final, uint32_t totalLen)
Definition FileMgr.cpp:1960
bool FtpEnabled
Definition FileMgr.hpp:156
void NetworkStateChanged(bool NewState)
Definition FileMgr.cpp:217
uint32_t expectedIndex
Definition FileMgr.hpp:256
void BuildFseqList(bool DisplayFileNames)
Definition FileMgr.cpp:1754
uint64_t WriteSdFileBuf(const FileId &FileHandle, byte *FileData, uint64_t NumBytesToWrite)
Definition FileMgr.cpp:1571
FileMode
Definition FileMgr.hpp:66
@ FileWrite
Definition FileMgr.hpp:68
@ FileAppend
Definition FileMgr.hpp:69
@ FileRead
Definition FileMgr.hpp:67
void SetSpiIoPins()
Definition FileMgr.cpp:372
bool SaveFlashFile(const String &FileName, String &FileData)
Definition FileMgr.cpp:736
void RenameSdFile(String &OldName, String &NewName)
Definition FileMgr.cpp:1734
FileId fsUploadFileHandle
Definition FileMgr.hpp:149
void DescribeSdCardToUser()
Definition FileMgr.cpp:1106
void CloseSdFile(FileId &FileHandle)
Definition FileMgr.cpp:1486
bool SdCardIsInstalled()
Definition FileMgr.hpp:85
bool ReadFlashFile(const String &FileName, String &FileData)
Definition FileMgr.cpp:871
uint32_t fsUploadStartTime
Definition FileMgr.hpp:152
uint64_t GetSdFileSize(const String &FileName)
Definition FileMgr.cpp:1689
void handleFileUploadNewFile(const String &filename)
Definition FileMgr.cpp:2071
uint64_t WriteSdFile(const FileId &FileHandle, byte *FileData, uint64_t NumBytesToWrite)
Definition FileMgr.cpp:1526
bool SdCardInstalled
Definition FileMgr.hpp:144
void ResetSdCard()
Definition FileMgr.cpp:565
bool SetConfig(JsonObject &json)
Definition FileMgr.cpp:258
bool fsUploadFileSavedIsEnabled
Definition FileMgr.hpp:151
uint32_t FileId
Definition FileMgr.hpp:50
void AbortSdFileUpload()
Definition FileMgr.cpp:2210
void UpdateFtp()
Definition FileMgr.cpp:207
uint8_t miso_pin
Definition FileMgr.hpp:145
void DeleteFlashFile(String FileName)
Definition FileMgr.cpp:587
void Poll()
Definition FileMgr.cpp:244
void RenameFlashFile(String OldName, String NewName)
Definition FileMgr.cpp:605
bool FlashFileExists(const String &FileName)
Definition FileMgr.cpp:996
void GetDriverName(String &Name)
Definition FileMgr.hpp:104
char filename[250]
Definition fseq.h:7
struct FSEQParsedRangeEntry __attribute__
Definition FileMgr.hpp:234
uint64_t size
Definition FileMgr.hpp:237
FsFile fsFile
Definition FileMgr.hpp:236
uint64_t offset
Definition FileMgr.hpp:246
String Filename
Definition FileMgr.hpp:239
FileId handle
Definition FileMgr.hpp:235
FileMode mode
Definition FileMgr.hpp:240
int entryId
Definition FileMgr.hpp:238
struct c_FileMgr::FileListEntry_t::@2 buffer
byte * DataBuffer
Definition FileMgr.hpp:244
bool IsOpen
Definition FileMgr.hpp:241