Select one of the symbols to view example projects that use it.
 
Outline
#include <stdint.h>
#include <stddef.h>
#include <stdarg.h>
#include <unistd.h>
#include <utime.h>
#include "freertos/FreeRTOS.h"
#include "freertos/semphr.h"
#include "esp_err.h"
#include <sys/types.h>
#include <sys/reent.h>
#include <sys/stat.h>
#include <sys/time.h>
#include <sys/termios.h>
#include <sys/poll.h>
#include <sys/dirent.h>
#include <dirent.h>
#include <string.h>
#include "sdkconfig.h"
esp_vfs_id_t
esp_vfs_select_sem_t
esp_vfs_stat_ctx_op_t
esp_vfs_stat_op_t
esp_vfs_link_ctx_op_t
esp_vfs_link_op_t
esp_vfs_unlink_ctx_op_t
esp_vfs_rename_ctx_op_t
esp_vfs_rename_op_t
esp_vfs_opendir_ctx_op_t
esp_vfs_readdir_ctx_op_t
esp_vfs_readdir_r_ctx_op_t
esp_vfs_readdir_r_op_t
esp_vfs_telldir_ctx_op_t
esp_vfs_seekdir_ctx_op_t
esp_vfs_seekdir_op_t
esp_vfs_closedir_ctx_op_t
esp_vfs_mkdir_ctx_op_t
esp_vfs_mkdir_op_t
esp_vfs_rmdir_ctx_op_t
esp_vfs_access_ctx_op_t
esp_vfs_access_op_t
esp_vfs_truncate_ctx_op_t
esp_vfs_truncate_op_t
esp_vfs_ftruncate_ctx_op_t
esp_vfs_ftruncate_op_t
esp_vfs_utime_ctx_op_t
esp_vfs_utime_op_t
esp_vfs_dir_ops_t
esp_vfs_tcsetattr_ctx_op_t
esp_vfs_tcsetattr_op_t
esp_vfs_tcgetattr_ctx_op_t
esp_vfs_tcgetattr_op_t
esp_vfs_tcdrain_ctx_op_t
esp_vfs_tcflush_ctx_op_t
esp_vfs_tcflush_op_t
esp_vfs_tcflow_ctx_op_t
esp_vfs_tcflow_op_t
esp_vfs_tcgetsid_ctx_op_t
esp_vfs_tcsendbreak_ctx_op_t
esp_vfs_tcsendbreak_op_t
esp_vfs_termios_ops_t
esp_vfs_start_select_op_t
esp_vfs_socket_select_op_t
esp_vfs_stop_socket_select_isr_op_t
esp_vfs_get_socket_select_semaphore_op_t
esp_vfs_select_ops_t
esp_vfs_write_ctx_op_t
esp_vfs_write_op_t
esp_vfs_lseek_ctx_op_t
esp_vfs_lseek_op_t
esp_vfs_read_ctx_op_t
esp_vfs_read_op_t
esp_vfs_pread_ctx_op_t
esp_vfs_pread_op_t
esp_vfs_pwrite_ctx_op_t
esp_vfs_pwrite_op_t
esp_vfs_open_ctx_op_t
esp_vfs_open_op_t
esp_vfs_close_ctx_op_t
esp_vfs_fstat_ctx_op_t
esp_vfs_fstat_op_t
esp_vfs_fcntl_ctx_op_t
esp_vfs_fcntl_op_t
esp_vfs_ioctl_ctx_op_t
esp_vfs_ioctl_op_t
esp_vfs_fsync_ctx_op_t
esp_vfs_fs_ops_t
esp_vfs_register_fs(const char *, const esp_vfs_fs_ops_t *, int, void *);
esp_vfs_register_fs_with_id(const esp_vfs_fs_ops_t *, int, void *, esp_vfs_id_t *);
esp_vfs_unregister_fs(const char *);
esp_vfs_unregister_fs_with_id(esp_vfs_id_t);
Files
loading...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/vfs/include/esp_vfs_ops.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 *//* ... */ #pragma once #include <stdint.h> #include <stddef.h> #include <stdarg.h> #include <unistd.h> #include <utime.h> #include "freertos/FreeRTOS.h" #include "freertos/semphr.h" #include "esp_err.h" #include <sys/types.h> #include <sys/reent.h> #include <sys/stat.h> #include <sys/time.h> #include <sys/termios.h> #include <sys/poll.h>14 includes #ifdef __clang__ // TODO LLVM-330 #include <sys/dirent.h> #else #include <dirent.h> #endif #include <string.h> #include "sdkconfig.h" #ifdef __cplusplus extern "C" { #endif #ifndef _SYS_TYPES_FD_SET #error "VFS should be used with FD_SETSIZE and FD_SET from sys/types.h" #endif /* * @brief VFS identificator used for esp_vfs_register_with_id() *//* ... */ typedef int esp_vfs_id_t; /** * @brief VFS semaphore type for select() * *//* ... */ typedef struct { bool is_sem_local; /*!< type of "sem" is SemaphoreHandle_t when true, defined by socket driver otherwise */ void *sem; /*!< semaphore instance */ }{ ... } esp_vfs_select_sem_t; #ifdef CONFIG_VFS_SUPPORT_DIR typedef int (*esp_vfs_stat_ctx_op_t) (void *ctx, const char *path, struct stat *st); /*!< stat with context pointer */ typedef int (*esp_vfs_stat_op_t) ( const char *path, struct stat *st); /*!< stat without context pointer */ typedef int (*esp_vfs_link_ctx_op_t) (void *ctx, const char *n1, const char *n2); /*!< link with context pointer */ typedef int (*esp_vfs_link_op_t) ( const char *n1, const char *n2); /*!< link without context pointer */ typedef int (*esp_vfs_unlink_ctx_op_t) (void *ctx, const char *path); /*!< unlink with context pointer */ typedef int (*esp_vfs_unlink_op_t) ( const char *path); /*!< unlink without context pointer */ typedef int (*esp_vfs_rename_ctx_op_t) (void *ctx, const char *src, const char *dst); /*!< rename with context pointer */ typedef int (*esp_vfs_rename_op_t) ( const char *src, const char *dst); /*!< rename without context pointer */ typedef DIR* (*esp_vfs_opendir_ctx_op_t) (void *ctx, const char *name); /*!< opendir with context pointer */ typedef DIR* (*esp_vfs_opendir_op_t) ( const char *name); /*!< opendir without context pointer */ typedef struct dirent* (*esp_vfs_readdir_ctx_op_t) (void *ctx, DIR *pdir); /*!< readdir with context pointer */ typedef struct dirent* (*esp_vfs_readdir_op_t) ( DIR *pdir); /*!< readdir without context pointer */ typedef int (*esp_vfs_readdir_r_ctx_op_t) (void *ctx, DIR *pdir, struct dirent *entry, struct dirent **out); /*!< readdir_r with context pointer */ typedef int (*esp_vfs_readdir_r_op_t) ( DIR *pdir, struct dirent *entry, struct dirent **out); /*!< readdir_r without context pointer */ typedef long (*esp_vfs_telldir_ctx_op_t) (void *ctx, DIR *pdir); /*!< telldir with context pointer */ typedef long (*esp_vfs_telldir_op_t) ( DIR *pdir); /*!< telldir without context pointer */ typedef void (*esp_vfs_seekdir_ctx_op_t) (void *ctx, DIR *pdir, long offset); /*!< seekdir with context pointer */ typedef void (*esp_vfs_seekdir_op_t) ( DIR *pdir, long offset); /*!< seekdir without context pointer */ typedef int (*esp_vfs_closedir_ctx_op_t) (void *ctx, DIR *pdir); /*!< closedir with context pointer */ typedef int (*esp_vfs_closedir_op_t) ( DIR *pdir); /*!< closedir without context pointer */ typedef int (*esp_vfs_mkdir_ctx_op_t) (void *ctx, const char *name, mode_t mode); /*!< mkdir with context pointer */ typedef int (*esp_vfs_mkdir_op_t) ( const char *name, mode_t mode); /*!< mkdir without context pointer */ typedef int (*esp_vfs_rmdir_ctx_op_t) (void *ctx, const char *name); /*!< rmdir with context pointer */ typedef int (*esp_vfs_rmdir_op_t) ( const char *name); /*!< rmdir without context pointer */ typedef int (*esp_vfs_access_ctx_op_t) (void *ctx, const char *path, int amode); /*!< access with context pointer */ typedef int (*esp_vfs_access_op_t) ( const char *path, int amode); /*!< access without context pointer */ typedef int (*esp_vfs_truncate_ctx_op_t) (void *ctx, const char *path, off_t length); /*!< truncate with context pointer */ typedef int (*esp_vfs_truncate_op_t) ( const char *path, off_t length); /*!< truncate without context pointer */ typedef int (*esp_vfs_ftruncate_ctx_op_t) (void *ctx, int fd, off_t length); /*!< ftruncate with context pointer */ typedef int (*esp_vfs_ftruncate_op_t) ( int fd, off_t length); /*!< ftruncate without context pointer */ typedef int (*esp_vfs_utime_ctx_op_t) (void *ctx, const char *path, const struct utimbuf *times); /*!< utime with context pointer */ typedef int (*esp_vfs_utime_op_t) ( const char *path, const struct utimbuf *times); /*!< utime without context pointer */ /** * @brief Struct containing function pointers to directory related functionality. * *//* ... */ typedef struct { union { const esp_vfs_stat_ctx_op_t stat_p; /*!< stat with context pointer */ const esp_vfs_stat_op_t stat; /*!< stat without context pointer */ }{ ... }; union { const esp_vfs_link_ctx_op_t link_p; /*!< link with context pointer */ const esp_vfs_link_op_t link; /*!< link without context pointer */ }{ ... }; union { const esp_vfs_unlink_ctx_op_t unlink_p; /*!< unlink with context pointer */ const esp_vfs_unlink_op_t unlink; /*!< unlink without context pointer */ }{ ... }; union { const esp_vfs_rename_ctx_op_t rename_p; /*!< rename with context pointer */ const esp_vfs_rename_op_t rename; /*!< rename without context pointer */ }{ ... }; union { const esp_vfs_opendir_ctx_op_t opendir_p; /*!< opendir with context pointer */ const esp_vfs_opendir_op_t opendir; /*!< opendir without context pointer */ }{ ... }; union { const esp_vfs_readdir_ctx_op_t readdir_p; /*!< readdir with context pointer */ const esp_vfs_readdir_op_t readdir; /*!< readdir without context pointer */ }{ ... }; union { const esp_vfs_readdir_r_ctx_op_t readdir_r_p; /*!< readdir_r with context pointer */ const esp_vfs_readdir_r_op_t readdir_r; /*!< readdir_r without context pointer */ }{ ... }; union { const esp_vfs_telldir_ctx_op_t telldir_p; /*!< telldir with context pointer */ const esp_vfs_telldir_op_t telldir; /*!< telldir without context pointer */ }{ ... }; union { const esp_vfs_seekdir_ctx_op_t seekdir_p; /*!< seekdir with context pointer */ const esp_vfs_seekdir_op_t seekdir; /*!< seekdir without context pointer */ }{ ... }; union { const esp_vfs_closedir_ctx_op_t closedir_p; /*!< closedir with context pointer */ const esp_vfs_closedir_op_t closedir; /*!< closedir without context pointer */ }{ ... }; union { const esp_vfs_mkdir_ctx_op_t mkdir_p; /*!< mkdir with context pointer */ const esp_vfs_mkdir_op_t mkdir; /*!< mkdir without context pointer */ }{ ... }; union { const esp_vfs_rmdir_ctx_op_t rmdir_p; /*!< rmdir with context pointer */ const esp_vfs_rmdir_op_t rmdir; /*!< rmdir without context pointer */ }{ ... }; union { const esp_vfs_access_ctx_op_t access_p; /*!< access with context pointer */ const esp_vfs_access_op_t access; /*!< access without context pointer */ }{ ... }; union { const esp_vfs_truncate_ctx_op_t truncate_p; /*!< truncate with context pointer */ const esp_vfs_truncate_op_t truncate; /*!< truncate without context pointer */ }{ ... }; union { const esp_vfs_ftruncate_ctx_op_t ftruncate_p; /*!< ftruncate with context pointer */ const esp_vfs_ftruncate_op_t ftruncate; /*!< ftruncate without context pointer */ }{ ... }; union { const esp_vfs_utime_ctx_op_t utime_p; /*!< utime with context pointer */ const esp_vfs_utime_op_t utime; /*!< utime without context pointer */ }{ ... }; }{ ... } esp_vfs_dir_ops_t; /* ... */ #endif // CONFIG_VFS_SUPPORT_DIR #ifdef CONFIG_VFS_SUPPORT_TERMIOS typedef int (*esp_vfs_tcsetattr_ctx_op_t) (void *ctx, int fd, int optional_actions, const struct termios *p); /*!< tcsetattr with context pointer */ typedef int (*esp_vfs_tcsetattr_op_t) ( int fd, int optional_actions, const struct termios *p); /*!< tcsetattr without context pointer */ typedef int (*esp_vfs_tcgetattr_ctx_op_t) (void *ctx, int fd, struct termios *p); /*!< tcgetattr with context pointer */ typedef int (*esp_vfs_tcgetattr_op_t) ( int fd, struct termios *p); /*!< tcgetattr without context pointer */ typedef int (*esp_vfs_tcdrain_ctx_op_t) (void *ctx, int fd); /*!< tcdrain with context pointer */ typedef int (*esp_vfs_tcdrain_op_t) ( int fd); /*!< tcdrain without context pointer */ typedef int (*esp_vfs_tcflush_ctx_op_t) (void *ctx, int fd, int select); /*!< tcflush with context pointer */ typedef int (*esp_vfs_tcflush_op_t) ( int fd, int select); /*!< tcflush without context pointer */ typedef int (*esp_vfs_tcflow_ctx_op_t) (void *ctx, int fd, int action); /*!< tcflow with context pointer */ typedef int (*esp_vfs_tcflow_op_t) ( int fd, int action); /*!< tcflow without context pointer */ typedef pid_t (*esp_vfs_tcgetsid_ctx_op_t) (void *ctx, int fd); /*!< tcgetsid with context pointer */ typedef pid_t (*esp_vfs_tcgetsid_op_t) ( int fd); /*!< tcgetsid without context pointer */ typedef int (*esp_vfs_tcsendbreak_ctx_op_t) (void *ctx, int fd, int duration); /*!< tcsendbreak with context pointer */ typedef int (*esp_vfs_tcsendbreak_op_t) ( int fd, int duration); /*!< tcsendbreak without context pointer */ /** * @brief Struct containing function pointers to termios related functionality. * *//* ... */ typedef struct { union { const esp_vfs_tcsetattr_ctx_op_t tcsetattr_p; /*!< tcsetattr with context pointer */ const esp_vfs_tcsetattr_op_t tcsetattr; /*!< tcsetattr without context pointer */ }{ ... }; union { const esp_vfs_tcgetattr_ctx_op_t tcgetattr_p; /*!< tcgetattr with context pointer */ const esp_vfs_tcgetattr_op_t tcgetattr; /*!< tcgetattr without context pointer */ }{ ... }; union { const esp_vfs_tcdrain_ctx_op_t tcdrain_p; /*!< tcdrain with context pointer */ const esp_vfs_tcdrain_op_t tcdrain; /*!< tcdrain without context pointer */ }{ ... }; union { const esp_vfs_tcflush_ctx_op_t tcflush_p; /*!< tcflush with context pointer */ const esp_vfs_tcflush_op_t tcflush; /*!< tcflush without context pointer */ }{ ... }; union { const esp_vfs_tcflow_ctx_op_t tcflow_p; /*!< tcflow with context pointer */ const esp_vfs_tcflow_op_t tcflow; /*!< tcflow without context pointer */ }{ ... }; union { const esp_vfs_tcgetsid_ctx_op_t tcgetsid_p; /*!< tcgetsid with context pointer */ const esp_vfs_tcgetsid_op_t tcgetsid; /*!< tcgetsid without context pointer */ }{ ... }; union { const esp_vfs_tcsendbreak_ctx_op_t tcsendbreak_p; /*!< tcsendbreak with context pointer */ const esp_vfs_tcsendbreak_op_t tcsendbreak; /*!< tcsendbreak without context pointer */ }{ ... }; }{ ... } esp_vfs_termios_ops_t; /* ... */ #endif // CONFIG_VFS_SUPPORT_TERMIOS #ifdef CONFIG_VFS_SUPPORT_SELECT typedef esp_err_t (*esp_vfs_start_select_op_t) (int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, esp_vfs_select_sem_t sem, void **end_select_args); typedef int (*esp_vfs_socket_select_op_t) (int nfds, fd_set *readfds, fd_set *writefds, fd_set *errorfds, struct timeval *timeout); typedef void (*esp_vfs_stop_socket_select_op_t) (void *sem); typedef void (*esp_vfs_stop_socket_select_isr_op_t) (void *sem, BaseType_t *woken); typedef void* (*esp_vfs_get_socket_select_semaphore_op_t) (void); typedef esp_err_t (*esp_vfs_end_select_op_t) (void *end_select_args); /** * @brief Struct containing function pointers to select related functionality. * *//* ... */ typedef struct { /** start_select is called for setting up synchronous I/O multiplexing of the desired file descriptors in the given VFS */ const esp_vfs_start_select_op_t start_select; /** socket select function for socket FDs with the functionality of POSIX select(); this should be set only for the socket VFS */ const esp_vfs_socket_select_op_t socket_select; /** called by VFS to interrupt the socket_select call when select is activated from a non-socket VFS driver; set only for the socket driver */ const esp_vfs_stop_socket_select_op_t stop_socket_select; /** stop_socket_select which can be called from ISR; set only for the socket driver */ const esp_vfs_stop_socket_select_isr_op_t stop_socket_select_isr; /** end_select is called to stop the I/O multiplexing and deinitialize the environment created by start_select for the given VFS */ const esp_vfs_get_socket_select_semaphore_op_t get_socket_select_semaphore; /** get_socket_select_semaphore returns semaphore allocated in the socket driver; set only for the socket driver */ const esp_vfs_end_select_op_t end_select; }{ ... } esp_vfs_select_ops_t; /* ... */ #endif // CONFIG_VFS_SUPPORT_SELECT typedef ssize_t (*esp_vfs_write_ctx_op_t) (void *ctx, int fd, const void *data, size_t size); /*!< Write with context pointer */ typedef ssize_t (*esp_vfs_write_op_t) ( int fd, const void *data, size_t size); /*!< Write without context pointer */ typedef off_t (*esp_vfs_lseek_ctx_op_t) (void *ctx, int fd, off_t size, int mode); /*!< Seek with context pointer */ typedef off_t (*esp_vfs_lseek_op_t) ( int fd, off_t size, int mode); /*!< Seek without context pointer */ typedef ssize_t (*esp_vfs_read_ctx_op_t) (void *ctx, int fd, void *dst, size_t size); /*!< Read with context pointer */ typedef ssize_t (*esp_vfs_read_op_t) ( int fd, void *dst, size_t size); /*!< Read without context pointer */ typedef ssize_t (*esp_vfs_pread_ctx_op_t) (void *ctx, int fd, void *dst, size_t size, off_t offset); /*!< pread with context pointer */ typedef ssize_t (*esp_vfs_pread_op_t) ( int fd, void *dst, size_t size, off_t offset); /*!< pread without context pointer */ typedef ssize_t (*esp_vfs_pwrite_ctx_op_t) (void *ctx, int fd, const void *src, size_t size, off_t offset); /*!< pwrite with context pointer */ typedef ssize_t (*esp_vfs_pwrite_op_t) ( int fd, const void *src, size_t size, off_t offset); /*!< pwrite without context pointer */ typedef int (*esp_vfs_open_ctx_op_t) (void *ctx, const char *path, int flags, int mode); /*!< open with context pointer */ typedef int (*esp_vfs_open_op_t) ( const char *path, int flags, int mode); /*!< open without context pointer */ typedef int (*esp_vfs_close_ctx_op_t) (void *ctx, int fd); /*!< close with context pointer */ typedef int (*esp_vfs_close_op_t) ( int fd); /*!< close without context pointer */ typedef int (*esp_vfs_fstat_ctx_op_t) (void *ctx, int fd, struct stat *st); /*!< fstat with context pointer */ typedef int (*esp_vfs_fstat_op_t) ( int fd, struct stat *st); /*!< fstat without context pointer */ typedef int (*esp_vfs_fcntl_ctx_op_t) (void *ctx, int fd, int cmd, int arg); /*!< fcntl with context pointer */ typedef int (*esp_vfs_fcntl_op_t) ( int fd, int cmd, int arg); /*!< fcntl without context pointer */ typedef int (*esp_vfs_ioctl_ctx_op_t) (void *ctx, int fd, int cmd, va_list args); /*!< ioctl with context pointer */ typedef int (*esp_vfs_ioctl_op_t) ( int fd, int cmd, va_list args); /*!< ioctl without context pointer */ typedef int (*esp_vfs_fsync_ctx_op_t) (void *ctx, int fd); /*!< fsync with context pointer */ typedef int (*esp_vfs_fsync_op_t) ( int fd); /*!< fsync without context pointer */ /** * @brief Main struct of the minified vfs API, containing basic function pointers as well as pointers to the other subcomponents. * *//* ... */ typedef struct { union { const esp_vfs_write_ctx_op_t write_p; /*!< Write with context pointer */ const esp_vfs_write_op_t write; /*!< Write without context pointer */ }{ ... }; union { const esp_vfs_lseek_ctx_op_t lseek_p; /*!< Seek with context pointer */ const esp_vfs_lseek_op_t lseek; /*!< Seek without context pointer */ }{ ... }; union { const esp_vfs_read_ctx_op_t read_p; /*!< Read with context pointer */ const esp_vfs_read_op_t read; /*!< Read without context pointer */ }{ ... }; union { const esp_vfs_pread_ctx_op_t pread_p; /*!< pread with context pointer */ const esp_vfs_pread_op_t pread; /*!< pread without context pointer */ }{ ... }; union { const esp_vfs_pwrite_ctx_op_t pwrite_p; /*!< pwrite with context pointer */ const esp_vfs_pwrite_op_t pwrite; /*!< pwrite without context pointer */ }{ ... }; union { const esp_vfs_open_ctx_op_t open_p; /*!< open with context pointer */ const esp_vfs_open_op_t open; /*!< open without context pointer */ }{ ... }; union { const esp_vfs_close_ctx_op_t close_p; /*!< close with context pointer */ const esp_vfs_close_op_t close; /*!< close without context pointer */ }{ ... }; union { const esp_vfs_fstat_ctx_op_t fstat_p; /*!< fstat with context pointer */ const esp_vfs_fstat_op_t fstat; /*!< fstat without context pointer */ }{ ... }; union { const esp_vfs_fcntl_ctx_op_t fcntl_p; /*!< fcntl with context pointer */ const esp_vfs_fcntl_op_t fcntl; /*!< fcntl without context pointer */ }{ ... }; union { const esp_vfs_ioctl_ctx_op_t ioctl_p; /*!< ioctl with context pointer */ const esp_vfs_ioctl_op_t ioctl; /*!< ioctl without context pointer */ }{ ... }; union { const esp_vfs_fsync_ctx_op_t fsync_p; /*!< fsync with context pointer */ const esp_vfs_fsync_op_t fsync; /*!< fsync without context pointer */ }{ ... }; #ifdef CONFIG_VFS_SUPPORT_DIR const esp_vfs_dir_ops_t *const dir; /*!< pointer to the dir subcomponent */ #endif #ifdef CONFIG_VFS_SUPPORT_TERMIOS const esp_vfs_termios_ops_t *const termios; /*!< pointer to the termios subcomponent */ #endif #if CONFIG_VFS_SUPPORT_SELECT || defined __DOXYGEN__ const esp_vfs_select_ops_t *const select; /*!< pointer to the select subcomponent */ #endif }{ ... } esp_vfs_fs_ops_t; /** * Register a virtual filesystem for given path prefix. * * @param base_path file path prefix associated with the filesystem. * Must be a zero-terminated C string, may be empty. * If not empty, must be up to ESP_VFS_PATH_MAX * characters long, and at least 2 characters long. * Name must start with a "/" and must not end with "/". * For example, "/data" or "/dev/spi" are valid. * These VFSes would then be called to handle file paths such as * "/data/myfile.txt" or "/dev/spi/0". * In the special case of an empty base_path, a "fallback" * VFS is registered. Such VFS will handle paths which are not * matched by any other registered VFS. * @param vfs Pointer to esp_vfs_fs_ops_t, a structure which maps syscalls to * the filesystem driver functions. VFS component does not assume ownership of this struct, but see flags for more info * * @param flags Set of binary flags controlling how the registered FS should be treated * - ESP_VFS_FLAG_STATIC - if this flag is specified VFS assumes the provided esp_vfs_fs_ops_t and all its subcomponents are statically allocated, * if it is not enabled a deep copy of the provided struct will be created, which will be managed by the VFS component * - ESP_VFS_FLAG_CONTEXT_PTR - If set, the VFS will use the context-aware versions of the filesystem operation functions (suffixed with `_p`) in `esp_vfs_fs_ops_t` and its subcomponents. * The `ctx` parameter will be passed as the context argument when these functions are invoked. * * @param ctx Context pointer for fs operation functions, see the ESP_VFS_FLAG_CONTEXT_PTR. * Should be `NULL` if not used. * * @return ESP_OK if successful, ESP_ERR_NO_MEM if too many FSes are * registered. *//* ... */ esp_err_t esp_vfs_register_fs(const char *base_path, const esp_vfs_fs_ops_t *vfs, int flags, void *ctx); /** * Analog of esp_vfs_register_with_id which accepts esp_vfs_fs_ops_t instead. * *//* ... */ esp_err_t esp_vfs_register_fs_with_id(const esp_vfs_fs_ops_t *vfs, int flags, void *ctx, esp_vfs_id_t *id); /** * Alias for esp_vfs_unregister for naming consistency *//* ... */ esp_err_t esp_vfs_unregister_fs(const char *base_path); /** * Alias for esp_vfs_unregister_with_id for naming consistency *//* ... */ esp_err_t esp_vfs_unregister_fs_with_id(esp_vfs_id_t id); #ifdef __cplusplus }{...} #endif
Details
Show:
from
Types: Columns:
This file uses the notable symbols shown below. Click anywhere in the file to view more details.