Zephyr API Documentation  3.5.0
A Scalable Open Source RTOS
3.5.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
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
36};
37
52enum {
55
58
61
64};
65
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)
85
89struct fs_mount_t {
93 int type;
95 const char *mnt_point;
97 void *fs_data;
100 /* The following fields are filled by file system core */
104 const struct fs_file_system_t *fs;
107};
108
115struct fs_dirent {
123 size_t size;
124};
125
134 unsigned long f_bsize;
136 unsigned long f_frsize;
138 unsigned long f_blocks;
140 unsigned long f_bfree;
141};
142
143
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
156
158#define FS_O_CREATE 0x10
160#define FS_O_APPEND 0x20
162#define FS_O_FLAGS_MASK 0x30
163
165#define FS_O_MASK (FS_O_MODE_MASK | FS_O_FLAGS_MASK)
174#ifndef FS_SEEK_SET
176#define FS_SEEK_SET 0
177#endif
178#ifndef FS_SEEK_CUR
180#define FS_SEEK_CUR 1
181#endif
182#ifndef FS_SEEK_END
184#define FS_SEEK_END 2
185#endif
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))
203
210#define FS_FSTAB_ENTRY(node_id) _CONCAT(z_fsmp_, node_id)
211
220#define FS_FSTAB_DECLARE_ENTRY(node_id) \
221 extern struct fs_mount_t FS_FSTAB_ENTRY(node_id)
222
232static inline void fs_file_t_init(struct fs_file_t *zfp)
233{
234 *zfp = (struct fs_file_t){ 0 };
235}
236
246static inline void fs_dir_t_init(struct fs_dir_t *zdp)
247{
248 *zdp = (struct fs_dir_t){ 0 };
249}
250
282int fs_open(struct fs_file_t *zfp, const char *file_name, fs_mode_t flags);
283
295int fs_close(struct fs_file_t *zfp);
296
311int fs_unlink(const char *path);
312
338int fs_rename(const char *from, const char *to);
339
356ssize_t fs_read(struct fs_file_t *zfp, void *ptr, size_t size);
357
377ssize_t fs_write(struct fs_file_t *zfp, const void *ptr, size_t size);
378
397int fs_seek(struct fs_file_t *zfp, off_t offset, int whence);
398
414
435int fs_truncate(struct fs_file_t *zfp, off_t length);
436
453int fs_sync(struct fs_file_t *zfp);
454
469int fs_mkdir(const char *path);
470
485int fs_opendir(struct fs_dir_t *zdp, const char *path);
486
506int fs_readdir(struct fs_dir_t *zdp, struct fs_dirent *entry);
507
519int fs_closedir(struct fs_dir_t *zdp);
520
548int fs_mount(struct fs_mount_t *mp);
549
564int fs_unmount(struct fs_mount_t *mp);
565
581int fs_readmount(int *index, const char **name);
582
599int fs_stat(const char *path, struct fs_dirent *entry);
600
615int fs_statvfs(const char *path, struct fs_statvfs *stat);
616
628int fs_mkfs(int fs_type, uintptr_t dev_id, void *cfg, int flags);
629
645int fs_register(int type, const struct fs_file_system_t *fs);
646
658int fs_unregister(int type, const struct fs_file_system_t *fs);
659
665#ifdef __cplusplus
666}
667#endif
668
669#endif /* ZEPHYR_INCLUDE_FS_FS_H_ */
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
Definition: stat.h:92