grblHAL core  20251016
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-2025 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_load_plugin(x)
37 
38 #ifndef bcopy
39 #define bcopy(src, dest, len) memmove(dest, src, len)
40 #endif
41 
42 #if !(defined(__time_t_defined) || defined(_TIME_H_) || defined(__MSP432P401R__) || defined(PART_TM4C123GH6PM))
43 typedef struct {
44  short date;
45  short time;
46 } time_t;
47 
48 struct tm {
49  int tm_year;
50  int tm_mon;
51  int tm_mday;
52  int tm_hour;
53  int tm_min;
54  int tm_sec;
55 };
56 #endif // __time_t_defined
57 
58 typedef union
59 {
60  uint8_t mode;
61  struct {
62  uint8_t read_only :1,
63  hidden :1,
64  system :1,
65  unused :1,
67  archive :1;
68  };
70 
71 typedef struct {
72  size_t st_size;
74 #ifdef ESP_PLATFORM // some versions of ESP-IDF/Compiler combos are fcked up
75  time_t st_mtim;
76 #else
78 #endif
79 } vfs_stat_t;
80 
81 typedef struct {
82  const void *fs;
83  size_t size;
84  bool update;
85  uint8_t handle __attribute__ ((aligned (4))); // first byte of file handle structure
86 } vfs_file_t;
87 
88 struct vfs_dir;
89 typedef struct vfs_dir vfs_dir_t;
90 
91 typedef struct {
92  char name[255];
93  size_t size;
95 } vfs_dirent_t;
96 
97 typedef struct {
98  uint64_t size;
99  uint64_t used;
100 } vfs_free_t;
101 
102 typedef struct {
103  const char *name;
104  size_t size;
106  const uint8_t data[];
108 
109 typedef vfs_file_t *(*vfs_open_ptr)(const char *filename, const char *mode);
110 typedef char *(*vfs_getcwd_ptr)(char *buf, size_t size);
111 typedef size_t (*vfs_read_ptr)(void *buffer, size_t size, size_t count, vfs_file_t *file);
112 typedef size_t (*vfs_write_ptr)(const void *buffer, size_t size, size_t count, vfs_file_t *file);
113 typedef void (*vfs_close_ptr)(vfs_file_t *file);
114 typedef size_t (*vfs_ftell_ptr)(vfs_file_t *file);
115 typedef int (*vfs_fseek_ptr)(vfs_file_t *file, size_t offset);
116 typedef bool (*vfs_eof_ptr)(vfs_file_t *file);
117 typedef int (*vfs_rename_ptr)(const char *from, const char *to);
118 typedef int (*vfs_unlink_ptr)(const char *filename);
119 
120 typedef int (*vfs_mkdir_ptr)(const char *path);
121 typedef int (*vfs_chdir_ptr)(const char *path);
122 typedef int (*vfs_rmdir_ptr)(const char *path);
123 typedef vfs_dir_t *(*vfs_opendir_ptr)(const char *path);
124 typedef char *(*vfs_readdir_ptr)(vfs_dir_t *dir, vfs_dirent_t *dirent);
125 typedef void (*vfs_closedir_ptr)(vfs_dir_t *dir);
126 typedef int (*vfs_chmod_ptr)(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask);
127 typedef int (*vfs_stat_ptr)(const char *filename, vfs_stat_t *st);
128 typedef int (*vfs_utime_ptr)(const char *filename, struct tm *modified);
129 
130 typedef bool (*vfs_getfree_ptr)(vfs_free_t *free);
131 typedef int (*vfs_format_ptr)(void);
132 
133 typedef struct
134 {
135  const char *fs_name;
136  bool removable;
158 } vfs_t;
159 
160 typedef void (*on_vfs_changed_ptr)(const vfs_t *fs);
161 typedef void (*on_vfs_mount_ptr)(const char *path, const vfs_t *fs, vfs_st_mode_t mode);
162 typedef void (*on_vfs_unmount_ptr)(const char *path);
163 
164 typedef struct {
168 } vfs_events_t;
169 
170 typedef struct vfs_mount
171 {
172  char path[64];
173  const vfs_t *vfs;
175 #ifdef ESP_PLATFORM // some versions of ESP-IDF/Compiler combos are fcked up
176  time_t st_mtim;
177 #else
179 #endif
180  struct vfs_mount *next;
182 
183 typedef struct vfs_mount_ll_entry
184 {
188 
189 typedef struct {
191 } vfs_drives_t;
192 
193 typedef struct {
194  const char *name;
195  const char *path;
196  bool removable;
198  const void *fs;
199 } vfs_drive_t;
200 
201 struct vfs_dir {
202  const void *fs;
204  uint8_t handle __attribute__ ((aligned (4))); // must be last!
205 };
206 
207 extern volatile int vfs_errno;
208 extern vfs_events_t vfs;
209 
210 char *vfs_fixpath (char *path);
211 
212 bool vfs_mount (const char *path, const vfs_t *fs, vfs_st_mode_t mode);
213 bool vfs_unmount (const char *path);
214 vfs_file_t *vfs_open (const char *filename, const char *mode);
215 void vfs_close (vfs_file_t *file);
216 size_t vfs_read (void *buffer, size_t size, size_t count, vfs_file_t *file);
217 size_t vfs_write (const void *buffer, size_t size, size_t count, vfs_file_t *file);
218 int vfs_puts (const char *s, vfs_file_t *file);
219 size_t vfs_tell (vfs_file_t *file);
220 int vfs_seek (vfs_file_t *file, size_t offset);
221 bool vfs_eof (vfs_file_t *file);
222 int vfs_rename (const char *from, const char *to);
223 int vfs_unlink (const char *filename);
224 int vfs_mkdir (const char *path);
225 int vfs_rmdir (const char *path);
226 int vfs_chdir (const char *path);
227 vfs_dir_t *vfs_opendir (const char *path);
229 void vfs_closedir (vfs_dir_t *dir);
230 char *vfs_getcwd (char *buf, size_t len);
231 int vfs_chmod (const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask);
232 int vfs_stat (const char *filename, vfs_stat_t *st);
233 int vfs_utime (const char *filename, struct tm *modified);
234 vfs_free_t *vfs_fgetfree (const char *path);
235 
237 vfs_drive_t *vfs_drives_read (vfs_drives_t *handle, bool add_hidden);
238 void vfs_drives_close (vfs_drives_t *handle);
240 int vfs_drive_format (vfs_drive_t *drive);
241 vfs_drive_t *vfs_get_drive (const char *path);
242 
243 #endif // INCLUDE_VFS_H
Definition: vfs.h:102
vfs_st_mode_t st_mode
Definition: vfs.h:105
size_t size
Definition: vfs.h:104
const char * name
Definition: vfs.h:103
Definition: vfs.h:43
short time
Definition: vfs.h:45
short date
Definition: vfs.h:44
Definition: vfs.h:48
int tm_mday
Definition: vfs.h:51
int tm_sec
Definition: vfs.h:54
int tm_hour
Definition: vfs.h:52
int tm_min
Definition: vfs.h:53
int tm_year
Definition: vfs.h:49
int tm_mon
Definition: vfs.h:50
Definition: vfs.h:201
uint8_t handle
Definition: vfs.h:204
const void * fs
Definition: vfs.h:202
vfs_mount_ll_entry_t * mounts
Definition: vfs.h:203
Definition: vfs.h:91
vfs_st_mode_t st_mode
Definition: vfs.h:94
size_t size
Definition: vfs.h:93
Definition: vfs.h:193
bool removable
Definition: vfs.h:196
const void * fs
Definition: vfs.h:198
const char * path
Definition: vfs.h:195
const char * name
Definition: vfs.h:194
vfs_st_mode_t mode
Definition: vfs.h:197
Definition: vfs.h:189
vfs_mount_t * mount
Definition: vfs.h:190
Definition: vfs.h:164
on_vfs_unmount_ptr on_unmount
Called when a file system is unmounted.
Definition: vfs.h:166
on_vfs_changed_ptr on_fs_changed
Called when file system content is changed.
Definition: vfs.h:167
on_vfs_mount_ptr on_mount
Called when a file system is mounted.
Definition: vfs.h:165
Definition: vfs.h:81
const void * fs
Definition: vfs.h:82
size_t size
Definition: vfs.h:83
bool update
Definition: vfs.h:84
Definition: vfs.h:97
uint64_t used
Definition: vfs.h:99
uint64_t size
Definition: vfs.h:98
Definition: vfs.h:184
struct vfs_mount_ll_entry * next
Definition: vfs.h:186
vfs_mount_t * mount
Definition: vfs.h:185
Definition: vfs.h:171
struct vfs_mount * next
Definition: vfs.h:180
const vfs_t * vfs
Definition: vfs.h:173
vfs_st_mode_t mode
Definition: vfs.h:174
time_t st_mtime
Definition: vfs.h:178
char path[64]
Definition: vfs.h:172
Definition: vfs.h:71
vfs_st_mode_t st_mode
Definition: vfs.h:73
size_t st_size
Definition: vfs.h:72
time_t st_mtime
Definition: vfs.h:77
Definition: vfs.h:134
vfs_open_ptr fopen
Definition: vfs.h:137
vfs_getfree_ptr fgetfree
Definition: vfs.h:156
bool removable
Definition: vfs.h:136
vfs_chmod_ptr fchmod
Definition: vfs.h:152
vfs_format_ptr format
Definition: vfs.h:157
vfs_chdir_ptr fchdir
Definition: vfs.h:147
vfs_write_ptr fwrite
Definition: vfs.h:140
vfs_stat_ptr fstat
Definition: vfs.h:153
vfs_eof_ptr feof
Definition: vfs.h:143
vfs_mkdir_ptr fmkdir
Definition: vfs.h:146
const char * fs_name
Definition: vfs.h:135
vfs_close_ptr fclose
Definition: vfs.h:138
vfs_getcwd_ptr fgetcwd
Definition: vfs.h:155
vfs_fseek_ptr fseek
Definition: vfs.h:142
vfs_readdir_ptr readdir
Definition: vfs.h:150
vfs_unlink_ptr funlink
Definition: vfs.h:145
vfs_rename_ptr frename
Definition: vfs.h:144
vfs_opendir_ptr fopendir
Definition: vfs.h:149
vfs_read_ptr fread
Definition: vfs.h:139
vfs_ftell_ptr ftell
Definition: vfs.h:141
vfs_utime_ptr futime
Definition: vfs.h:154
vfs_rmdir_ptr frmdir
Definition: vfs.h:148
vfs_closedir_ptr fclosedir
Definition: vfs.h:151
Definition: vfs.h:59
uint8_t directory
Definition: vfs.h:66
uint8_t system
Definition: vfs.h:64
uint8_t mode
Definition: vfs.h:60
uint8_t hidden
Definition: vfs.h:63
uint8_t read_only
Definition: vfs.h:62
uint8_t archive
Definition: vfs.h:67
uint8_t unused
Definition: vfs.h:65
int(* vfs_chmod_ptr)(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask)
Definition: vfs.h:126
vfs_free_t * vfs_drive_getfree(vfs_drive_t *drive)
Definition: vfs.c:711
struct vfs_mount vfs_mount_t
void(* vfs_closedir_ptr)(vfs_dir_t *dir)
Definition: vfs.h:125
int vfs_rename(const char *from, const char *to)
Definition: vfs.c:329
void(* on_vfs_mount_ptr)(const char *path, const vfs_t *fs, vfs_st_mode_t mode)
Definition: vfs.h:161
void(* on_vfs_unmount_ptr)(const char *path)
Definition: vfs.h:162
size_t(* vfs_read_ptr)(void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.h:111
vfs_free_t * vfs_fgetfree(const char *path)
Definition: vfs.c:547
int(* vfs_rename_ptr)(const char *from, const char *to)
Definition: vfs.h:117
int(* vfs_mkdir_ptr)(const char *path)
Definition: vfs.h:120
volatile int vfs_errno
Definition: vfs.c:207
vfs_dir_t *(* vfs_opendir_ptr)(const char *path)
Definition: vfs.h:123
int vfs_puts(const char *s, vfs_file_t *file)
Definition: vfs.c:296
void vfs_closedir(vfs_dir_t *dir)
Definition: vfs.c:477
bool vfs_eof(vfs_file_t *file)
Definition: vfs.c:322
vfs_dir_t * vfs_opendir(const char *path)
Definition: vfs.c:421
vfs_drive_t * vfs_drives_read(vfs_drives_t *handle, bool add_hidden)
Definition: vfs.c:681
size_t vfs_read(void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.c:282
char * vfs_fixpath(char *path)
Definition: vfs.c:216
bool(* vfs_getfree_ptr)(vfs_free_t *free)
Definition: vfs.h:130
vfs_drive_t * vfs_get_drive(const char *path)
Definition: vfs.c:643
int(* vfs_unlink_ptr)(const char *filename)
Definition: vfs.h:118
char *(* vfs_readdir_ptr)(vfs_dir_t *dir, vfs_dirent_t *dirent)
Definition: vfs.h:124
int vfs_rmdir(const char *path)
Definition: vfs.c:369
size_t(* vfs_ftell_ptr)(vfs_file_t *file)
Definition: vfs.h:114
int vfs_stat(const char *filename, vfs_stat_t *st)
Definition: vfs.c:512
int vfs_mkdir(const char *path)
Definition: vfs.c:357
vfs_drives_t * vfs_drives_open(void)
Definition: vfs.c:657
int vfs_drive_format(vfs_drive_t *drive)
Definition: vfs.c:720
struct vfs_mount_ll_entry vfs_mount_ll_entry_t
bool(* vfs_eof_ptr)(vfs_file_t *file)
Definition: vfs.h:116
int vfs_seek(vfs_file_t *file, size_t offset)
Definition: vfs.c:315
int(* vfs_rmdir_ptr)(const char *path)
Definition: vfs.h:122
char *(* vfs_getcwd_ptr)(char *buf, size_t size)
Definition: vfs.h:110
int(* vfs_chdir_ptr)(const char *path)
Definition: vfs.h:121
bool vfs_mount(const char *path, const vfs_t *fs, vfs_st_mode_t mode)
Definition: vfs.c:570
int(* vfs_stat_ptr)(const char *filename, vfs_stat_t *st)
Definition: vfs.h:127
void vfs_close(vfs_file_t *file)
Definition: vfs.c:272
int(* vfs_fseek_ptr)(vfs_file_t *file, size_t offset)
Definition: vfs.h:115
vfs_events_t vfs
Definition: vfs.c:208
void(* vfs_close_ptr)(vfs_file_t *file)
Definition: vfs.h:113
int vfs_chmod(const char *filename, vfs_st_mode_t attr, vfs_st_mode_t mask)
Definition: vfs.c:505
char * vfs_getcwd(char *buf, size_t len)
Definition: vfs.c:490
size_t(* vfs_write_ptr)(const void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.h:112
int vfs_utime(const char *filename, struct tm *modified)
Definition: vfs.c:540
int vfs_chdir(const char *path)
Definition: vfs.c:381
bool vfs_unmount(const char *path)
Definition: vfs.c:613
vfs_file_t *(* vfs_open_ptr)(const char *filename, const char *mode)
Definition: vfs.h:109
vfs_file_t * vfs_open(const char *filename, const char *mode)
Definition: vfs.c:259
void(* on_vfs_changed_ptr)(const vfs_t *fs)
Definition: vfs.h:160
void vfs_drives_close(vfs_drives_t *handle)
Definition: vfs.c:706
int(* vfs_utime_ptr)(const char *filename, struct tm *modified)
Definition: vfs.h:128
int(* vfs_format_ptr)(void)
Definition: vfs.h:131
int vfs_unlink(const char *filename)
Definition: vfs.c:345
vfs_dirent_t * vfs_readdir(vfs_dir_t *dir)
Definition: vfs.c:451
size_t vfs_write(const void *buffer, size_t size, size_t count, vfs_file_t *file)
Definition: vfs.c:289
size_t vfs_tell(vfs_file_t *file)
Definition: vfs.c:308