VSF Documented
vsf_linux_fs.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Copyright(C)2009-2022 by VSF Team *
3 * *
4 * Licensed under the Apache License, Version 2.0 (the "License"); *
5 * you may not use this file except in compliance with the License. *
6 * You may obtain a copy of the License at *
7 * *
8 * http://www.apache.org/licenses/LICENSE-2.0 *
9 * *
10 * Unless required by applicable law or agreed to in writing, software *
11 * distributed under the License is distributed on an "AS IS" BASIS, *
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
13 * See the License for the specific language governing permissions and *
14 * limitations under the License. *
15 * *
16 ****************************************************************************/
17
18#ifndef __VSF_LINUX_FS_INTERNAL_H__
19#define __VSF_LINUX_FS_INTERNAL_H__
20
21/*============================ INCLUDES ======================================*/
22
23// avoid to include vsf.h, include necessary headers only
24// #include "vsf.h"
25
27#include "hal/arch/vsf_arch.h"
28#include "kernel/vsf_kernel.h"
29
30#if VSF_USE_LINUX == ENABLED
31
32#if VSF_LINUX_CFG_RELATIVE_PATH == ENABLED
33# include "../../include/termios.h"
35#else
36# include <termios.h>
37# include <sys/stat.h>
38#endif
39
40#if defined(__VSF_LINUX_FS_CLASS_IMPLEMENT)
41# define __VSF_CLASS_IMPLEMENT__
42#elif defined(__VSF_LINUX_FS_CLASS_INHERIT__)
43# define __VSF_CLASS_INHERIT__
44#endif
45
46#include "utilities/ooc_class.h"
47
48#ifdef __cplusplus
49extern "C" {
50#endif
51
52/*============================ MACROS ========================================*/
53
54#if VSF_USE_FS != ENABLED
55# error VSF_USE_FS MUST be enabled to use fs in linux
56#endif
57
58/*============================ MACROFIED FUNCTIONS ===========================*/
59/*============================ TYPES =========================================*/
60
65
66enum {
68};
69
70typedef struct vsf_linux_fd_op_t {
73 void (*fn_init)(vsf_linux_fd_t *sfd);
74 void (*fn_fini)(vsf_linux_fd_t *sfd);
75 int (*fn_fcntl)(vsf_linux_fd_t *sfd, int cmd, uintptr_t arg);
76 ssize_t (*fn_read)(vsf_linux_fd_t *sfd, void *buf, size_t count);
77 ssize_t (*fn_write)(vsf_linux_fd_t *sfd, const void *buf, size_t count);
79 int (*fn_eof)(vsf_linux_fd_t *sfd);
81 int (*fn_stat)(vsf_linux_fd_t *sfd, struct stat *buf);
82
83 void * (*fn_mmap)(vsf_linux_fd_t *sfd, off64_t offset, size_t len, uint_fast32_t feature);
84 int (*fn_munmap)(vsf_linux_fd_t *sfd, void *buffer);
85 int (*fn_msync)(vsf_linux_fd_t *sfd, void *buffer);
87
90 void *param;
91 void (*cb)(vsf_linux_fd_priv_t *priv, void *param, short events, vsf_protect_t orig);
93
95 protected_member(
96 // target is used in socket_unix to indicate message for sendmsg/recvmsg,
97 // ofc it can be used in other fd types
98 void *target;
99 int flags;
100
101 short status;
102 short events;
103 // sticky_events will not be cleared
104 // use for eg pipe, pipe_tx is closed, pipe_rx will always POLLIN
105 short sticky_events;
106 short user_data;
107
108 vsf_linux_fd_priv_callback_t events_callback[2];
110 private_member(
111 int ref;
112 )
113};
114
116 protected_member(
117 int fd;
118 int fd_flags;
119 int cur_rdflags;
120 int cur_wrflags;
121 const vsf_linux_fd_op_t *op;
123
124 private_member(
125 vsf_dlist_node_t fd_node;
126 void *mmapped_buffer;
127 )
128
129 protected_member(
130 int unget_buff;
132
133 // used while binding fd to something
134 // eg: in popen, fd is binded with the target pid
135 union {
136 pid_t pid;
137 } binding;
139};
140
141#if defined(__VSF_LINUX_FS_CLASS_IMPLEMENT) || defined(__VSF_LINUX_FS_CLASS_INHERIT__)
142# if VSF_LINUX_CFG_FS_CACHE_SIZE > 0
143VSF_STATIC_ASSERT(VSF_LINUX_CFG_FS_CACHE_SIZE <= ((1 << (sizeof(uint16_t) << 3)) - 1));
144VSF_STATIC_ASSERT(VSF_LINUX_CFG_FS_CACHE_SIZE > VSF_LINUX_CFG_FS_CACHE_THRESHOLD);
145# endif
146typedef struct vk_file_t vk_file_t;
147typedef struct vsf_linux_fs_priv_t {
148 implement(vsf_linux_fd_priv_t)
149 vk_file_t *file;
150
151 union {
152 struct dirent dir;
153 struct dirent64 dir64;
154 };
155# if VSF_LINUX_CFG_FS_CACHE_SIZE > 0
156 uint8_t *cache_buffer;
157 uint16_t cache_size;
158 uint16_t cache_offset;
159 uint64_t cache_pos;
160# endif
161} vsf_linux_fs_priv_t;
162
163vsf_dcl_class(vsf_linux_stream_priv_t)
164typedef void (*vsf_linux_stream_on_evt_t)(vsf_linux_stream_priv_t *priv, vsf_protect_t orig, short event, bool is_ready);
165
166vsf_class(vsf_linux_stream_priv_t) {
167 public_member(
168 implement(vsf_linux_fs_priv_t)
169 )
170 protected_member(
171 vsf_stream_t *stream_rx;
172 vsf_stream_t *stream_tx;
173 vsf_linux_stream_on_evt_t on_evt;
174 bool stream_rx_allocated;
175 bool stream_tx_allocated;
176 )
177};
178
179vsf_class(vsf_linux_pipe_priv_t) {
180 protected_member(
181 implement(vsf_linux_stream_priv_t)
182 vsf_linux_pipe_priv_t *pipe_remote;
183 )
184};
185
186typedef struct vsf_linux_term_priv_t {
187 implement(vsf_linux_pipe_priv_t)
188 const vsf_linux_fd_op_t *subop;
189 struct termios termios;
190 char esc_type;
191 bool line_start;
192 bool subop_inited;
193} vsf_linux_term_priv_t;
194
195typedef struct vsf_linux_key_t vsf_linux_key_t;
196vsf_class(vsf_linux_key_priv_t) {
197 public_member(
198 implement(vsf_linux_fd_priv_t)
199 )
200 protected_member(
201 union {
202 struct {
203 unsigned short *semadj_arr;
204 } sem;
205 } u;
206 vsf_linux_key_t *key;
207 void (*fn_fini)(vsf_linux_fd_t *sfd);
208 int (*fn_close)(vsf_linux_fd_t *sfd);
209 )
210};
211#endif
212
213/*============================ GLOBAL VARIABLES ==============================*/
214
215#if defined(__VSF_LINUX_FS_CLASS_IMPLEMENT) || defined(__VSF_LINUX_FS_CLASS_INHERIT__)
221#endif
222
223/*============================ LOCAL VARIABLES ===============================*/
224/*============================ PROTOTYPES ====================================*/
225
226#if defined(__VSF_LINUX_FS_CLASS_IMPLEMENT) || defined(__VSF_LINUX_FS_CLASS_INHERIT__)
227extern int vsf_linux_fd_bind_target_ex(int fd,
228 void *target, const vsf_linux_fd_op_t *op,
231 uint_fast32_t feature, uint64_t size);
232extern int vsf_linux_fd_bind_target(int fd, void *target,
234 vsf_param_eda_evthandler_t peda_write);
235// compatible with file and directory
236extern int vsf_linux_fd_get_target(int fd, void **target);
237extern int vsf_linux_fs_bind_target(const char *pathname, void *target,
239 vsf_param_eda_evthandler_t peda_write);
240extern int vsf_linux_fs_bind_dir_target(const char *pathname, void *target);
241int vsf_linux_fs_bind_target_ex(const char *pathname,
242 void *target, const vsf_linux_fd_op_t *op,
245 uint_fast32_t feature, uint64_t size);
246extern int vsf_linux_fs_get_target(const char *pathname, void **target);
247typedef struct vk_vfs_file_t vk_vfs_file_t;
248extern int vsf_linux_fs_bind_target_relative(vk_vfs_file_t *dir, const char *pathname,
249 void *target, const vsf_linux_fd_op_t *op,
250 uint_fast32_t feature, uint64_t size);
251extern int vsf_linux_fs_bind_pipe(const char *pathname1, const char *pathname2, bool exclusive);
252extern int vsf_linux_create_pty(int num);
253
254extern int vsf_linux_fd_create(vsf_linux_fd_t **sfd, const vsf_linux_fd_op_t *op);
255extern vsf_linux_fd_t * vsf_linux_fd_get(int fd);
256extern void vsf_linux_fd_delete(int fd);
257extern bool vsf_linux_fd_is_block(vsf_linux_fd_t *sfd);
258
259extern int vsf_linux_fd_get_feature(int fd, uint_fast32_t *feature);
260extern int vsf_linux_fd_set_feature(int fd, uint_fast32_t feature);
261extern int vsf_linux_fd_add_feature(int fd, uint_fast32_t feature);
262
263extern int vsf_linux_fd_set_size(int fd, uint64_t size);
264
265// vsf_linux_fd_xx_trigger/vsf_linux_fd_xx_pend MUST be called scheduler protected
272extern short vsf_linux_fd_get_status(vsf_linux_fd_priv_t *priv, short status);
273
274// stream
275// IMPORTANT: priority of stream MUST be within scheduler priorities
276extern vsf_linux_fd_t * vsf_linux_stream(vsf_stream_t *stream_rx, vsf_stream_t *stream_tx);
279
280// pipe
282extern vsf_linux_fd_t * vsf_linux_tx_pipe(vsf_linux_pipe_priv_t *priv_rx);
283#endif
284
285extern int vsf_linux_fs_bind_buffer(const char *pathname, void *buffer,
286 uint_fast32_t feature, uint64_t size);
287extern int vsf_linux_fs_bind_stream(const char *pathname, vsf_stream_t *stream_rx, vsf_stream_t *stream_tx);
288
289#ifdef __cplusplus
290}
291#endif
292
293#undef __VSF_LINUX_FS_CLASS_IMPLEMENT
294#undef __VSF_LINUX_FS_CLASS_INHERIT__
295
296/*============================ INCLUDES ======================================*/
297
298#include "./vfs/vsf_linux_vfs.h"
299
300#endif // VSF_USE_LINUX
301#endif // __VSF_LINUX_FS_INTERNAL_H__
302/* EOF */
#define VSF_STATIC_ASSERT(__COND,...)
Definition __type.h:199
Definition vsf_fs.h:114
Definition vsf_linux_fs.h:94
Definition vsf_linux_fs.h:115
Definition vsf_linux.h:281
Definition vsf_linux.h:158
Definition vsf_queue_stream.h:60
Definition vsf_simple_stream.h:254
union @1017::@1028::@1029 u
int pid_t
Definition types.h:93
long long off64_t
Definition types.h:105
int ssize_t
Definition types.h:71
#define vsf_dcl_class
Definition ooc_class.h:50
#define vsf_class(__name)
Definition ooc_class.h:52
uint32_t uintptr_t
Definition stdint.h:38
unsigned short uint16_t
Definition stdint.h:7
unsigned int uint_fast32_t
Definition stdint.h:27
unsigned long long uint64_t
Definition stdint.h:11
unsigned char uint8_t
Definition stdint.h:5
Definition dirent.h:42
Definition dirent.h:35
Definition stat.h:107
Definition termios.h:205
Definition vsf_list.h:888
Definition vsf_linux_fs.h:70
int(* fn_setsize)(vsf_linux_fd_t *sfd, off64_t size)
Definition vsf_linux_fs.h:80
ssize_t(* fn_write)(vsf_linux_fd_t *sfd, const void *buf, size_t count)
Definition vsf_linux_fs.h:77
int feature
Definition vsf_linux_fs.h:72
int(* fn_msync)(vsf_linux_fd_t *sfd, void *buffer)
Definition vsf_linux_fs.h:85
int priv_size
Definition vsf_linux_fs.h:71
int(* fn_fcntl)(vsf_linux_fd_t *sfd, int cmd, uintptr_t arg)
Definition vsf_linux_fs.h:75
int(* fn_stat)(vsf_linux_fd_t *sfd, struct stat *buf)
Definition vsf_linux_fs.h:81
int(* fn_close)(vsf_linux_fd_t *sfd)
Definition vsf_linux_fs.h:78
int(* fn_eof)(vsf_linux_fd_t *sfd)
Definition vsf_linux_fs.h:79
ssize_t(* fn_read)(vsf_linux_fd_t *sfd, void *buf, size_t count)
Definition vsf_linux_fs.h:76
int(* fn_munmap)(vsf_linux_fd_t *sfd, void *buffer)
Definition vsf_linux_fs.h:84
void(* fn_init)(vsf_linux_fd_t *sfd)
Definition vsf_linux_fs.h:73
void(* fn_fini)(vsf_linux_fd_t *sfd)
Definition vsf_linux_fs.h:74
Definition vsf_linux_fs.h:88
short pendind_events
Definition vsf_linux_fs.h:89
void(* cb)(vsf_linux_fd_priv_t *priv, void *param, short events, vsf_protect_t orig)
Definition vsf_linux_fs.h:91
void * param
Definition vsf_linux_fs.h:90
Definition vsf_linux.h:128
uintalu_t vsf_protect_t
Definition vsf_arch_abstraction.h:53
void(* vsf_param_eda_evthandler_t)(uintptr_t target, vsf_evt_t evt)
Definition vsf_eda.h:658
#define VSF_LINUX_CFG_FS_CACHE_SIZE
Definition vsf_linux_cfg.h:42
int vsf_linux_fs_bind_target_relative(vk_vfs_file_t *dir, const char *pathname, void *target, const vsf_linux_fd_op_t *op, uint_fast32_t feature, uint64_t size)
Definition vsf_linux_fs.c:2803
int vsf_linux_fs_get_target(const char *pathname, void **target)
Definition vsf_linux_fs.c:2791
int vsf_linux_fs_bind_dir_target(const char *pathname, void *target)
Definition vsf_linux_fs.c:2856
vsf_linux_fd_t * vsf_linux_tx_pipe(vsf_linux_pipe_priv_t *priv_rx)
Definition vsf_linux_fs.c:3387
int vsf_linux_fd_bind_target_ex(int fd, void *target, const vsf_linux_fd_op_t *op, vsf_param_eda_evthandler_t peda_read, vsf_param_eda_evthandler_t peda_write, uint_fast32_t feature, uint64_t size)
Definition vsf_linux_fs.c:2764
void vsf_linux_fd_set_events(vsf_linux_fd_priv_t *priv, short events, vsf_protect_t orig)
Definition vsf_linux_fs.c:1209
int vsf_linux_fd_set_feature(int fd, uint_fast32_t feature)
Definition vsf_linux_fs.c:936
int vsf_linux_fs_bind_target(const char *pathname, void *target, vsf_param_eda_evthandler_t peda_read, vsf_param_eda_evthandler_t peda_write)
Definition vsf_linux_fs.c:2843
bool vsf_linux_fd_is_block(vsf_linux_fd_t *sfd)
Definition vsf_linux_fs.c:1132
const vsf_linux_fd_op_t __vsf_linux_stream_fdop
Definition vsf_linux_fs.c:232
int vsf_linux_fd_get_feature(int fd, uint_fast32_t *feature)
Definition vsf_linux_fs.c:924
int vsf_linux_create_pty(int num)
Definition vsf_linux_fs.c:3444
vsf_linux_fd_priv_callback_t * vsf_linux_fd_claim_calback(vsf_linux_fd_priv_t *priv)
Definition vsf_linux_fs.c:1157
int vsf_linux_fd_create(vsf_linux_fd_t **sfd, const vsf_linux_fd_op_t *op)
Definition vsf_linux_fs.c:1078
vsf_linux_fd_t * vsf_linux_rx_stream(vsf_stream_t *stream)
Definition vsf_linux_fs.c:3255
int vsf_linux_fs_bind_pipe(const char *pathname1, const char *pathname2, bool exclusive)
Definition vsf_linux_fs.c:3415
vsf_linux_fd_t * vsf_linux_fd_get(int fd)
Definition vsf_linux_fs.c:900
int vsf_linux_fd_bind_target(int fd, void *target, vsf_param_eda_evthandler_t peda_read, vsf_param_eda_evthandler_t peda_write)
Definition vsf_linux_fs.c:2784
const vsf_linux_fd_op_t vsf_linux_term_fdop
Definition vsf_linux_fs.c:253
int vsf_linux_fd_get_target(int fd, void **target)
Definition vsf_linux_fs.c:2751
void vsf_linux_fd_delete(int fd)
Definition vsf_linux_fs.c:1106
const vsf_linux_fd_op_t vsf_linux_pipe_fdop
Definition vsf_linux_fs.c:242
void vsf_linux_fd_clear_status(vsf_linux_fd_priv_t *priv, short status, vsf_protect_t orig)
Definition vsf_linux_fs.c:1235
int vsf_linux_fd_set_size(int fd, uint64_t size)
Definition vsf_linux_fs.c:955
void vsf_linux_fd_release_calback(vsf_linux_fd_priv_t *priv, vsf_linux_fd_priv_callback_t *callback)
Definition vsf_linux_fs.c:1171
int vsf_linux_fs_bind_target_ex(const char *pathname, void *target, const vsf_linux_fd_op_t *op, vsf_param_eda_evthandler_t peda_read, vsf_param_eda_evthandler_t peda_write, uint_fast32_t feature, uint64_t size)
Definition vsf_linux_fs.c:2825
short vsf_linux_fd_get_status(vsf_linux_fd_priv_t *priv, short status)
Definition vsf_linux_fs.c:1242
short vsf_linux_fd_pend_events(vsf_linux_fd_priv_t *priv, short events, vsf_linux_trigger_t *trig, vsf_protect_t orig)
Definition vsf_linux_fs.c:1176
void vsf_linux_fd_set_status(vsf_linux_fd_priv_t *priv, short status, vsf_protect_t orig)
Definition vsf_linux_fs.c:1224
vsf_linux_fd_t * vsf_linux_stream(vsf_stream_t *stream_rx, vsf_stream_t *stream_tx)
Definition vsf_linux_fs.c:3241
const vsf_linux_fd_op_t vsf_linux_key_fdop
Definition vsf_linux_fs.c:265
vsf_linux_fd_t * vsf_linux_rx_pipe(vsf_queue_stream_t *queue_stream)
Definition vsf_linux_fs.c:3358
vsf_linux_fd_t * vsf_linux_tx_stream(vsf_stream_t *stream)
Definition vsf_linux_fs.c:3260
const vsf_linux_fd_op_t __vsf_linux_fs_fdop
Definition vsf_linux_fs.c:201
int vsf_linux_fd_add_feature(int fd, uint_fast32_t feature)
Definition vsf_linux_fs.c:946
@ VSF_LINUX_FDOP_FEATURE_FS
Definition vsf_linux_fs.h:67
int vsf_linux_fs_bind_buffer(const char *pathname, void *buffer, uint_fast32_t feature, uint64_t size)
Definition vsf_linux_fs.c:2922
int vsf_linux_fs_bind_stream(const char *pathname, vsf_stream_t *stream_rx, vsf_stream_t *stream_tx)
Definition vsf_linux_fs.c:3265
uint64_t offset
Definition vsf_memfs.h:49
uint32_t size
Definition vsf_memfs.h:50
uint8_t status
Definition vsf_tgui.h:144
struct event_t events[32]
Definition vsf_xboot.c:36
Generated from commit: vsfteam/vsf@b2e9e8a