grblHAL core  20260411
vfs.h
Go to the documentation of this file.
1 /*
2  vfs.h - An embedded CNC Controller with rs274/ngc (g-code) support
3 
4  Virtual File System handler
5 
6  Part of grblHAL
7 
8  Copyright (c) 2022-2026 Terje Io
9 
10  grblHAL is free software: you can redistribute it and/or modify
11  it under the terms of the GNU General Public License as published by
12  the Free Software Foundation, either version 3 of the License, or
13  (at your option) any later version.
14 
15  grblHAL is distributed in the hope that it will be useful,
16  but WITHOUT ANY WARRANTY; without even the implied warranty of
17  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  GNU General Public License for more details.
19 
20  You should have received a copy of the GNU General Public License
21  along with grblHAL. If not, see <http://www.gnu.org/licenses/>.
22 */
23 
24 #ifndef INCLUDE_VFS_H
25 #define INCLUDE_VFS_H
26 
27 #define GRBL_VFS
28 
29 #include <stdint.h>
30 #include <stdbool.h>
31 #include <stddef.h>
32 #include <stdlib.h>
33 #include <string.h>
34 #include <time.h>
35 
36 #define VFS_MOUNT_PATH_LEN 33
37 
38 #define vfs_load_plugin(x)
39 
40 #ifndef bcopy
41 #define bcopy(src, dest, len) memmove(dest, src, len)
42 #endif
43 
44 #if !(defined(__time_t_defined) || defined(_TIME_H_) || defined(__MSP432P401R__) || defined(PART_TM4C123GH6PM))
45 typedef struct {
46  short date;
47  short time;
48 } time_t;
49 
50 struct tm {
51  int tm_year;
52  int tm_mon;
53  int tm_mday;
54  int tm_hour;
55  int tm_min;
56  int tm_sec;
57 };
58 #endif // __time_t_defined
59 
60 typedef union
61 {
62  uint8_t mode;
63  struct {
64  uint8_t read_only :1,
65  hidden :1,
66  system :1,
67  unused :1,
69  archive :1;
70  };
72 
73 typedef struct {
74  size_t st_size;
76 #ifdef ESP_PLATFORM // some versions of ESP-IDF/Compiler combos are fcked up
77  time_t st_mtim;
78 #else
80 #endif
81 } vfs_stat_t;
82 
83 typedef struct {
84  uint8_t update :1,
86  unused :6;
88 
89 typedef struct {
90  const void *fs;
91  size_t size;
93  uint8_t handle __attribute__ ((aligned (4))); // first byte of file handle structure
94 } vfs_file_t;
95 
96 struct vfs_dir;
97 typedef struct vfs_dir vfs_dir_t;
98 
99 typedef struct {
100  char name[255];
101  size_t size;
103 } vfs_dirent_t;
104 
105 typedef struct {
106  uint64_t size;
107  uint64_t used;
108 } vfs_free_t;
109 
110 typedef struct {
111  const char *name;
112  size_t size;
114  const uint8_t data[];
116 
117 typedef vfs_file_t *(*vfs_open_ptr)(const char *filename, const char *mode);
118 typedef char *(*vfs_getcwd_ptr)(char *buf, size_t size);
119 typedef size_t (*vfs_read_ptr)(void *buffer, size_t size, size_t count, vfs_file_t *file);
120 typedef size_t (*vfs_write_ptr)(const void *buffer, size_t size, size_t count, vfs_file_t *file);
121 typedef void (*vfs_close_ptr)(vfs_file_t *file);
122 typedef size_t (*vfs_ftell_ptr)(vfs_file_t *file);
123 typedef int (*vfs_fseek_ptr)(vfs_file_t *file, size_t offset);
124 typedef bool (*vfs_eof_ptr)(vfs_file_t *file);
125 typedef int (*vfs_rename_ptr)(const char *from, const char *to);
126 typedef int (*vfs_unlink_ptr)(const char *filename);
127 
128 typedef int (*vfs_mkdir_ptr)(const char *path);
129 typedef int (*vfs_chdir_ptr)(const char *path);
130 typedef int (*vfs_rmdir_ptr)(const char *path);
131 typedef vfs_dir_t *(*vfs_opendir_ptr)(const char *path);
132 typedef char *(*vfs_readdir_ptr)(vfs_dir_t *dir, vfs_dirent_t *dirent);
133 typedef void (*vfs_closedir_ptr)(vfs_dir_t *dir);
134 typedef int (*vfs_chmod_ptr)(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask);
135 typedef int (*vfs_stat_ptr)(const char *filename, vfs_stat_t *st);
136 typedef int (*vfs_utime_ptr)(const char *filename, struct tm *modified);
137 
138 typedef bool (*vfs_getfree_ptr)(vfs_free_t *free);
139 typedef int (*vfs_format_ptr)(void);
140 
141 typedef struct
142 {
143  const char *fs_name;
144  bool removable;
166 } vfs_t;
167 
168 typedef void (*on_vfs_changed_ptr)(const vfs_t *fs);
169 typedef void (*on_vfs_mount_ptr)(const char *path, const vfs_t *fs, vfs_st_mode_t mode);
170 typedef void (*on_vfs_unmount_ptr)(const char *path);
171 
172 typedef struct {
176 } vfs_events_t;
177 
178 typedef struct vfs_mount
179 {
181  const vfs_t *vfs;
183 #ifdef ESP_PLATFORM // some versions of ESP-IDF/Compiler combos are fcked up
184  time_t st_mtim;
185 #else
187 #endif
188  struct vfs_mount *next;
190 
191 typedef struct vfs_mount_ll_entry
192 {
196 
197 typedef struct {
199 } vfs_drives_t;
200 
201 typedef struct {
202  const char *name;
203  char *path;
204  bool removable;
206  const void *fs;
207 } vfs_drive_t;
208 
209 struct vfs_dir {
210  const void *fs;
212  uint8_t handle __attribute__ ((aligned (4))); // must be last!
213 };
214 
215 extern volatile int vfs_errno;
216 extern vfs_events_t vfs;
217 
218 char *vfs_fixpath (char *path);
219 
220 bool vfs_mount (const char *path, const vfs_t *fs, vfs_st_mode_t mode);
221 bool vfs_unmount (const char *path);
222 vfs_file_t *vfs_open (const char *filename, const char *mode);
223 void vfs_close (vfs_file_t *file);
224 size_t vfs_read (void *buffer, size_t size, size_t count, vfs_file_t *file);
225 size_t vfs_write (const void *buffer, size_t size, size_t count, vfs_file_t *file);
226 int vfs_puts (const char *s, vfs_file_t *file);
227 size_t vfs_tell (vfs_file_t *file);
228 int vfs_seek (vfs_file_t *file, size_t offset);
229 bool vfs_eof (vfs_file_t *file);
230 int vfs_rename (const char *from, const char *to);
231 int vfs_unlink (const char *filename);
232 int vfs_mkdir (const char *path);
233 int vfs_rmdir (const char *path);
234 int vfs_chdir (const char *path);
235 vfs_dir_t *vfs_opendir (const char *path);
237 void vfs_closedir (vfs_dir_t *dir);
238 char *vfs_getcwd (char *buf, size_t len);
239 int vfs_chmod (const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask);
240 int vfs_stat (const char *filename, vfs_stat_t *st);
241 int vfs_utime (const char *filename, struct tm *modified);
242 vfs_free_t *vfs_fgetfree (const char *path);
243 
245 vfs_drive_t *vfs_drives_read (vfs_drives_t *handle, bool add_hidden);
246 void vfs_drives_close (vfs_drives_t *handle);
248 int vfs_drive_format (vfs_drive_t *drive);
249 vfs_drive_t *vfs_get_drive (const char *path);
250 
251 #endif // INCLUDE_VFS_H
uint32_t size
Definition: nvs_buffer.c:46
Definition: vfs.h:110
vfs_st_mode_t st_mode
Definition: vfs.h:113
size_t size
Definition: vfs.h:112
const char * name
Definition: vfs.h:111
Definition: vfs.h:45
short time
Definition: vfs.h:47
short date
Definition: vfs.h:46
Definition: vfs.h:50
int tm_mday
Definition: vfs.h:53
int tm_sec
Definition: vfs.h:56
int tm_hour
Definition: vfs.h:54
int tm_min
Definition: vfs.h:55
int tm_year
Definition: vfs.h:51
int tm_mon
Definition: vfs.h:52
Definition: vfs.h:209
uint8_t handle
Definition: vfs.h:212
const void * fs
Definition: vfs.h:210
vfs_mount_ll_entry_t * mounts
Definition: vfs.h:211
Definition: vfs.h:99
vfs_st_mode_t st_mode
Definition: vfs.h:102
size_t size
Definition: vfs.h:101
Definition: vfs.h:201
bool removable
Definition: vfs.h:204
const void * fs
Definition: vfs.h:206
char * path
Definition: vfs.h:203
const char * name
Definition: vfs.h:202
vfs_st_mode_t mode
Definition: vfs.h:205
Definition: vfs.h:197
vfs_mount_t * mount
Definition: vfs.h:198
Definition: vfs.h:172
on_vfs_unmount_ptr on_unmount
Called when a file system is unmounted.
Definition: vfs.h:174
on_vfs_changed_ptr on_fs_changed
Called when file system content is changed.
Definition: vfs.h:175
on_vfs_mount_ptr on_mount
Called when a file system is mounted.
Definition: vfs.h:173
Definition: vfs.h:83
uint8_t is_temporary
Definition: vfs.h:85
uint8_t update
Definition: vfs.h:84
uint8_t unused
Definition: vfs.h:86
Definition: vfs.h:89
const void * fs
Definition: vfs.h:90
size_t size
Definition: vfs.h:91
vfs_file_status_t status
Definition: vfs.h:92
Definition: vfs.h:105
uint64_t used
Definition: vfs.h:107
uint64_t size
Definition: vfs.h:106
Definition: vfs.h:192
struct vfs_mount_ll_entry * next
Definition: vfs.h:194
vfs_mount_t * mount
Definition: vfs.h:193
Definition: vfs.h:179
struct vfs_mount * next
Definition: vfs.h:188
char path[VFS_MOUNT_PATH_LEN]
Definition: vfs.h:180
const vfs_t * vfs
Definition: vfs.h:181
vfs_st_mode_t mode
Definition: vfs.h:182
time_t st_mtime
Definition: vfs.h:186
Definition: vfs.h:73
vfs_st_mode_t st_mode
Definition: vfs.h:75
size_t st_size
Definition: vfs.h:74
time_t st_mtime
Definition: vfs.h:79
Definition: vfs.h:142
vfs_open_ptr fopen
Definition: vfs.h:145
vfs_getfree_ptr fgetfree
Definition: vfs.h:164
bool removable
Definition: vfs.h:144
vfs_chmod_ptr fchmod
Definition: vfs.h:160
vfs_format_ptr format
Definition: vfs.h:165
vfs_chdir_ptr fchdir
Definition: vfs.h:155
vfs_write_ptr fwrite
Definition: vfs.h:148
vfs_stat_ptr fstat
Definition: vfs.h:161
vfs_eof_ptr feof
Definition: vfs.h:151
vfs_mkdir_ptr fmkdir
Definition: vfs.h:154
const char * fs_name
Definition: vfs.h:143
vfs_close_ptr fclose
Definition: vfs.h:146
vfs_getcwd_ptr fgetcwd
Definition: vfs.h:163
vfs_fseek_ptr fseek
Definition: vfs.h:150
vfs_readdir_ptr readdir
Definition: vfs.h:158
vfs_unlink_ptr funlink
Definition: vfs.h:153
vfs_rename_ptr frename
Definition: vfs.h:152
vfs_opendir_ptr fopendir
Definition: vfs.h:157
vfs_read_ptr fread
Definition: vfs.h:147
vfs_ftell_ptr ftell
Definition: vfs.h:149
vfs_utime_ptr futime
Definition: vfs.h:162
vfs_rmdir_ptr frmdir
Definition: vfs.h:156
vfs_closedir_ptr fclosedir
Definition: vfs.h:159
Definition: vfs.h:61
uint8_t directory
Definition: vfs.h:68
uint8_t system
Definition: vfs.h:66
uint8_t mode
Definition: vfs.h:62
uint8_t hidden
Definition: vfs.h:65
uint8_t read_only
Definition: vfs.h:64
uint8_t archive
Definition: vfs.h:69
uint8_t unused
Definition: vfs.h:67
int(* vfs_chmod_ptr)(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask)
Definition: vfs.h:134
vfs_free_t * vfs_drive_getfree(vfs_drive_t *drive)
Definition: vfs.c:737
struct vfs_mount vfs_mount_t
void(* vfs_closedir_ptr)(vfs_dir_t *dir)
Definition: vfs.h:133
int vfs_rename(const char *from, const char *to)
Definition: vfs.c:372
void(* on_vfs_mount_ptr)(const char *path, const vfs_t *fs, vfs_st_mode_t mode)
Definition: vfs.h:169
void(* on_vfs_unmount_ptr)(const char *path)
Definition: vfs.h:170
size_t(* vfs_read_ptr)(void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.h:119
vfs_free_t * vfs_fgetfree(const char *path)
Definition: vfs.c:562
int(* vfs_rename_ptr)(const char *from, const char *to)
Definition: vfs.h:125
int(* vfs_mkdir_ptr)(const char *path)
Definition: vfs.h:128
volatile int vfs_errno
Definition: vfs.c:213
vfs_dir_t *(* vfs_opendir_ptr)(const char *path)
Definition: vfs.h:131
int vfs_puts(const char *s, vfs_file_t *file)
Definition: vfs.c:339
void vfs_closedir(vfs_dir_t *dir)
Definition: vfs.c:506
bool vfs_eof(vfs_file_t *file)
Definition: vfs.c:365
vfs_dir_t * vfs_opendir(const char *path)
Definition: vfs.c:450
vfs_drive_t * vfs_drives_read(vfs_drives_t *handle, bool add_hidden)
Definition: vfs.c:705
size_t vfs_read(void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.c:325
char * vfs_fixpath(char *path)
Definition: vfs.c:222
bool(* vfs_getfree_ptr)(vfs_free_t *free)
Definition: vfs.h:138
vfs_drive_t * vfs_get_drive(const char *path)
Definition: vfs.c:665
int(* vfs_unlink_ptr)(const char *filename)
Definition: vfs.h:126
char *(* vfs_readdir_ptr)(vfs_dir_t *dir, vfs_dirent_t *dirent)
Definition: vfs.h:132
int vfs_rmdir(const char *path)
Definition: vfs.c:412
size_t(* vfs_ftell_ptr)(vfs_file_t *file)
Definition: vfs.h:122
int vfs_stat(const char *filename, vfs_stat_t *st)
Definition: vfs.c:546
int vfs_mkdir(const char *path)
Definition: vfs.c:400
vfs_drives_t * vfs_drives_open(void)
Definition: vfs.c:681
int vfs_drive_format(vfs_drive_t *drive)
Definition: vfs.c:746
struct vfs_mount_ll_entry vfs_mount_ll_entry_t
bool(* vfs_eof_ptr)(vfs_file_t *file)
Definition: vfs.h:124
int vfs_seek(vfs_file_t *file, size_t offset)
Definition: vfs.c:358
int(* vfs_rmdir_ptr)(const char *path)
Definition: vfs.h:130
char *(* vfs_getcwd_ptr)(char *buf, size_t size)
Definition: vfs.h:118
int(* vfs_chdir_ptr)(const char *path)
Definition: vfs.h:129
bool vfs_mount(const char *path, const vfs_t *fs, vfs_st_mode_t mode)
Definition: vfs.c:585
int(* vfs_stat_ptr)(const char *filename, vfs_stat_t *st)
Definition: vfs.h:135
void vfs_close(vfs_file_t *file)
Definition: vfs.c:315
int(* vfs_fseek_ptr)(vfs_file_t *file, size_t offset)
Definition: vfs.h:123
vfs_events_t vfs
Definition: vfs.c:214
void(* vfs_close_ptr)(vfs_file_t *file)
Definition: vfs.h:121
int vfs_chmod(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask)
Definition: vfs.c:539
char * vfs_getcwd(char *buf, size_t len)
Definition: vfs.c:519
size_t(* vfs_write_ptr)(const void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.h:120
int vfs_utime(const char *filename, struct tm *modified)
Definition: vfs.c:555
int vfs_chdir(const char *path)
Definition: vfs.c:424
bool vfs_unmount(const char *path)
Definition: vfs.c:628
vfs_file_t *(* vfs_open_ptr)(const char *filename, const char *mode)
Definition: vfs.h:117
vfs_file_t * vfs_open(const char *filename, const char *mode)
Definition: vfs.c:302
void(* on_vfs_changed_ptr)(const vfs_t *fs)
Definition: vfs.h:168
#define VFS_MOUNT_PATH_LEN
Definition: vfs.h:36
void vfs_drives_close(vfs_drives_t *handle)
Definition: vfs.c:732
int(* vfs_utime_ptr)(const char *filename, struct tm *modified)
Definition: vfs.h:136
int(* vfs_format_ptr)(void)
Definition: vfs.h:139
int vfs_unlink(const char *filename)
Definition: vfs.c:388
vfs_dirent_t * vfs_readdir(vfs_dir_t *dir)
Definition: vfs.c:480
size_t vfs_write(const void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.c:332
size_t vfs_tell(vfs_file_t *file)
Definition: vfs.c:351