8#ifndef ZEPHYR_INCLUDE_FS_FS_H_
9#define ZEPHYR_INCLUDE_FS_FS_H_
67#define FS_MOUNT_FLAG_NO_FORMAT BIT(0)
69#define FS_MOUNT_FLAG_READ_ONLY BIT(1)
75#define FS_MOUNT_FLAG_AUTOMOUNT BIT(2)
84#define FS_MOUNT_FLAG_USE_DISK_ACCESS BIT(3)
149#define FS_O_READ 0x01
151#define FS_O_WRITE 0x02
153#define FS_O_RDWR (FS_O_READ | FS_O_WRITE)
155#define FS_O_MODE_MASK 0x03
158#define FS_O_CREATE 0x10
160#define FS_O_APPEND 0x20
162#define FS_O_FLAGS_MASK 0x30
165#define FS_O_MASK (FS_O_MODE_MASK | FS_O_FLAGS_MASK)
198#define FSTAB_ENTRY_DT_MOUNT_FLAGS(node_id) \
199 ((DT_PROP(node_id, automount) ? FS_MOUNT_FLAG_AUTOMOUNT : 0) \
200 | (DT_PROP(node_id, read_only) ? FS_MOUNT_FLAG_READ_ONLY : 0) \
201 | (DT_PROP(node_id, no_format) ? FS_MOUNT_FLAG_NO_FORMAT : 0) \
202 | (DT_PROP(node_id, disk_access) ? FS_MOUNT_FLAG_USE_DISK_ACCESS : 0))
210#define FS_FSTAB_ENTRY(node_id) _CONCAT(z_fsmp_, node_id)
220#define FS_FSTAB_DECLARE_ENTRY(node_id) \
221 extern struct fs_mount_t FS_FSTAB_ENTRY(node_id)
uint8_t fs_mode_t
Definition: fs_interface.h:49
#define MAX_FILE_NAME
Definition: fs_interface.h:42
struct _dnode sys_dnode_t
Doubly-linked list node structure.
Definition: dlist.h:55
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_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
Enumeration for directory entry types.
Definition: fs.h:31
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:246
static void fs_file_t_init(struct fs_file_t *zfp)
Initialize fs_file_t object.
Definition: fs.h:232
int fs_truncate(struct fs_file_t *zfp, off_t length)
Truncate or extend an open file to a given size.
@ FS_EXT2
Identifier for in-tree Ext2 file system.
Definition: fs.h:60
@ FS_LITTLEFS
Identifier for in-tree LittleFS file system.
Definition: fs.h:57
@ FS_TYPE_EXTERNAL_BASE
Base identifier for external file systems.
Definition: fs.h:63
@ FS_FATFS
Identifier for in-tree FatFS file system.
Definition: fs.h:54
@ FS_DIR_ENTRY_DIR
Identifier for directory entry.
Definition: fs.h:35
@ FS_DIR_ENTRY_FILE
Identifier for file entry.
Definition: fs.h:33
__SIZE_TYPE__ ssize_t
Definition: types.h:28
__INTPTR_TYPE__ off_t
Definition: types.h:36
flags
Definition: parser.h:96
__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:77
Structure to receive file or directory information.
Definition: fs.h:115
enum fs_dir_entry_type type
File/directory type (FS_DIR_ENTRY_FILE or FS_DIR_ENTRY_DIR)
Definition: fs.h:119
size_t size
Size of file (0 if directory).
Definition: fs.h:123
char name[MAX_FILE_NAME+1]
Name of file or directory.
Definition: fs.h:121
File System interface structure.
Definition: fs_sys.h:22
File object representing an open file.
Definition: fs_interface.h:63
File system mount info structure.
Definition: fs.h:89
const struct fs_file_system_t * fs
Pointer to File system interface of the mount point.
Definition: fs.h:104
const char * mnt_point
Mount point directory name (ex: "/fatfs")
Definition: fs.h:95
void * storage_dev
Pointer to backend storage device.
Definition: fs.h:99
void * fs_data
Pointer to file system specific data.
Definition: fs.h:97
int type
File system type.
Definition: fs.h:93
size_t mountp_len
Length of Mount point string.
Definition: fs.h:102
uint8_t flags
Mount flags.
Definition: fs.h:106
sys_dnode_t node
Entry for the fs_mount_list list.
Definition: fs.h:91
Structure to receive volume statistics.
Definition: fs.h:132
unsigned long f_bsize
Optimal transfer block size.
Definition: fs.h:134
unsigned long f_frsize
Allocation unit size.
Definition: fs.h:136
unsigned long f_blocks
Size of FS in f_frsize units.
Definition: fs.h:138
unsigned long f_bfree
Number of free blocks.
Definition: fs.h:140