Zephyr Project API  3.4.0
A Scalable Open Source RTOS
fs.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2016 Intel Corporation.
3 * Copyright (c) 2020-2021 Nordic Semiconductor ASA
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
8#ifndef ZEPHYR_INCLUDE_FS_FS_H_
9#define ZEPHYR_INCLUDE_FS_FS_H_
10
11#include <sys/types.h>
12
13#include <zephyr/sys/dlist.h>
15
16#ifdef __cplusplus
17extern "C" {
18#endif
19
26struct fs_file_system_t;
27
33};
34
49enum {
52
55
58};
59
61#define FS_MOUNT_FLAG_NO_FORMAT BIT(0)
63#define FS_MOUNT_FLAG_READ_ONLY BIT(1)
69#define FS_MOUNT_FLAG_AUTOMOUNT BIT(2)
78#define FS_MOUNT_FLAG_USE_DISK_ACCESS BIT(3)
79
92struct fs_mount_t {
94 int type;
95 const char *mnt_point;
96 void *fs_data;
98 /* fields filled by file system core */
99 size_t mountp_len;
100 const struct fs_file_system_t *fs;
102};
103
116struct fs_dirent {
119 size_t size;
120};
121
134 unsigned long f_bsize;
135 unsigned long f_frsize;
136 unsigned long f_blocks;
137 unsigned long f_bfree;
138};
139
140
146#define FS_O_READ 0x01
148#define FS_O_WRITE 0x02
150#define FS_O_RDWR (FS_O_READ | FS_O_WRITE)
152#define FS_O_MODE_MASK 0x03
153
155#define FS_O_CREATE 0x10
157#define FS_O_APPEND 0x20
159#define FS_O_FLAGS_MASK 0x30
160
162#define FS_O_MASK (FS_O_MODE_MASK | FS_O_FLAGS_MASK)
171#ifndef FS_SEEK_SET
173#define FS_SEEK_SET 0
174#endif
175#ifndef FS_SEEK_CUR
177#define FS_SEEK_CUR 1
178#endif
179#ifndef FS_SEEK_END
181#define FS_SEEK_END 2
182#endif
187/*
188 * @brief Get the common mount flags for an fstab entry.
189
190 * @param node_id the node identifier for a child entry in a
191 * zephyr,fstab node.
192 * @return a value suitable for initializing an fs_mount_t flags
193 * member.
194 */
195#define FSTAB_ENTRY_DT_MOUNT_FLAGS(node_id) \
196 ((DT_PROP(node_id, automount) ? FS_MOUNT_FLAG_AUTOMOUNT : 0) \
197 | (DT_PROP(node_id, read_only) ? FS_MOUNT_FLAG_READ_ONLY : 0) \
198 | (DT_PROP(node_id, no_format) ? FS_MOUNT_FLAG_NO_FORMAT : 0) \
199 | (DT_PROP(node_id, disk_access) ? FS_MOUNT_FLAG_USE_DISK_ACCESS : 0))
200
205#define FS_FSTAB_ENTRY(node_id) _CONCAT(z_fsmp_, node_id)
206
213#define FS_FSTAB_DECLARE_ENTRY(node_id) \
214 extern struct fs_mount_t FS_FSTAB_ENTRY(node_id)
215
225static inline void fs_file_t_init(struct fs_file_t *zfp)
226{
227 *zfp = (struct fs_file_t){ 0 };
228}
229
239static inline void fs_dir_t_init(struct fs_dir_t *zdp)
240{
241 *zdp = (struct fs_dir_t){ 0 };
242}
243
275int fs_open(struct fs_file_t *zfp, const char *file_name, fs_mode_t flags);
276
288int fs_close(struct fs_file_t *zfp);
289
304int fs_unlink(const char *path);
305
331int fs_rename(const char *from, const char *to);
332
349ssize_t fs_read(struct fs_file_t *zfp, void *ptr, size_t size);
350
370ssize_t fs_write(struct fs_file_t *zfp, const void *ptr, size_t size);
371
390int fs_seek(struct fs_file_t *zfp, off_t offset, int whence);
391
407
428int fs_truncate(struct fs_file_t *zfp, off_t length);
429
446int fs_sync(struct fs_file_t *zfp);
447
462int fs_mkdir(const char *path);
463
478int fs_opendir(struct fs_dir_t *zdp, const char *path);
479
499int fs_readdir(struct fs_dir_t *zdp, struct fs_dirent *entry);
500
512int fs_closedir(struct fs_dir_t *zdp);
513
541int fs_mount(struct fs_mount_t *mp);
542
557int fs_unmount(struct fs_mount_t *mp);
558
574int fs_readmount(int *index, const char **name);
575
592int fs_stat(const char *path, struct fs_dirent *entry);
593
608int fs_statvfs(const char *path, struct fs_statvfs *stat);
609
621int fs_mkfs(int fs_type, uintptr_t dev_id, void *cfg, int flags);
622
638int fs_register(int type, const struct fs_file_system_t *fs);
639
651int fs_unregister(int type, const struct fs_file_system_t *fs);
652
658#ifdef __cplusplus
659}
660#endif
661
662#endif /* ZEPHYR_INCLUDE_FS_FS_H_ */
ZTEST_BMEM int index[(3)]
Definition: main.c:32
Doubly-linked list implementation.
uint8_t fs_mode_t
Definition: fs_interface.h:36
#define MAX_FILE_NAME
Definition: fs_interface.h:30
struct _dnode sys_dnode_t
Definition: dlist.h:49
int fs_opendir(struct fs_dir_t *zdp, const char *path)
Directory open.
int fs_unregister(int type, const struct fs_file_system_t *fs)
Unregister a file system.
int fs_statvfs(const char *path, struct fs_statvfs *stat)
Retrieves statistics of the file system volume.
int fs_mkdir(const char *path)
Directory create.
int fs_rename(const char *from, const char *to)
Rename file or directory.
int fs_mount(struct fs_mount_t *mp)
Mount filesystem.
int fs_close(struct fs_file_t *zfp)
Close file.
off_t fs_tell(struct fs_file_t *zfp)
Get current file position.
fs_dir_entry_type
Definition: fs.h:28
int fs_mkfs(int fs_type, uintptr_t dev_id, void *cfg, int flags)
Create fresh file system.
int fs_seek(struct fs_file_t *zfp, off_t offset, int whence)
Seek file.
int fs_stat(const char *path, struct fs_dirent *entry)
File or directory status.
int fs_register(int type, const struct fs_file_system_t *fs)
Register a file system.
int fs_open(struct fs_file_t *zfp, const char *file_name, fs_mode_t flags)
Open or create file.
ssize_t fs_write(struct fs_file_t *zfp, const void *ptr, size_t size)
Write file.
int fs_closedir(struct fs_dir_t *zdp)
Directory close.
int fs_readmount(int *index, const char **name)
Get path of mount point at index.
int fs_readdir(struct fs_dir_t *zdp, struct fs_dirent *entry)
Directory read entry.
int fs_unlink(const char *path)
Unlink file.
ssize_t fs_read(struct fs_file_t *zfp, void *ptr, size_t size)
Read file.
int fs_unmount(struct fs_mount_t *mp)
Unmount filesystem.
int fs_sync(struct fs_file_t *zfp)
Flush cached write data buffers of an open file.
static void fs_dir_t_init(struct fs_dir_t *zdp)
Initialize fs_dir_t object.
Definition: fs.h:239
static void fs_file_t_init(struct fs_file_t *zfp)
Initialize fs_file_t object.
Definition: fs.h:225
int fs_truncate(struct fs_file_t *zfp, off_t length)
Truncate or extend an open file to a given size.
@ FS_DIR_ENTRY_DIR
Definition: fs.h:32
@ FS_DIR_ENTRY_FILE
Definition: fs.h:30
@ FS_LITTLEFS
Definition: fs.h:54
@ FS_TYPE_EXTERNAL_BASE
Definition: fs.h:57
@ FS_FATFS
Definition: fs.h:51
__SIZE_TYPE__ ssize_t
Definition: types.h:28
__INTPTR_TYPE__ off_t
Definition: types.h:36
flags
Definition: parser.h:96
void * ptr
Definition: printk.c:120
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINTPTR_TYPE__ uintptr_t
Definition: stdint.h:105
Directory object representing an open directory.
Definition: fs_interface.h:67
Structure to receive file or directory information.
Definition: fs.h:116
enum fs_dir_entry_type type
Definition: fs.h:117
size_t size
Definition: fs.h:119
char name[MAX_FILE_NAME+1]
Definition: fs.h:118
File System interface structure.
Definition: fs_sys.h:44
File object representing an open file.
Definition: fs_interface.h:53
File system mount info structure.
Definition: fs.h:92
const struct fs_file_system_t * fs
Definition: fs.h:100
const char * mnt_point
Definition: fs.h:95
void * storage_dev
Definition: fs.h:97
void * fs_data
Definition: fs.h:96
int type
Definition: fs.h:94
size_t mountp_len
Definition: fs.h:99
uint8_t flags
Definition: fs.h:101
sys_dnode_t node
Definition: fs.h:93
Structure to receive volume statistics.
Definition: fs.h:133
unsigned long f_bsize
Definition: fs.h:134
unsigned long f_frsize
Definition: fs.h:135
unsigned long f_blocks
Definition: fs.h:136
unsigned long f_bfree
Definition: fs.h:137
Definition: stat.h:92