18#ifndef __VSF_LINUX_INTERNAL_H__
19#define __VSF_LINUX_INTERNAL_H__
30#if VSF_USE_LINUX == ENABLED
32#if VSF_LINUX_CFG_RELATIVE_PATH == ENABLED
48#if defined(__VSF_LINUX_CLASS_IMPLEMENT)
49# define __VSF_CLASS_IMPLEMENT__
50#elif defined(__VSF_LINUX_CLASS_INHERIT__)
51# define __VSF_CLASS_INHERIT__
62#if VSF_KERNEL_CFG_EDA_SUPPORT_ON_TERMINATE != ENABLED
63# error VSF_KERNEL_CFG_EDA_SUPPORT_ON_TERMINATE MUST be enabled to use vsf_linux
66#if VSF_USE_SIMPLE_STREAM != ENABLED
67# error VSF_USE_SIMPLE_STREAM MUST be enabled to use vsf_linux
70#if VSF_USE_HEAP != ENABLED
71# error VSF_USE_HEAP MUST be enabled to use vsf_linux
74#ifndef VSF_LINUX_CFG_STACKSIZE
75# if defined(VSF_KERNEL_CFG_THREAD_STACK_PAGE_SIZE) && defined(VSF_KERNEL_CFG_THREAD_STACK_GUARDIAN_SIZE)
76# if (VSF_KERNEL_CFG_THREAD_STACK_PAGE_SIZE + VSF_KERNEL_CFG_THREAD_STACK_GUARDIAN_SIZE) < 1024
77# define VSF_LINUX_CFG_STACKSIZE 1024
79# define VSF_LINUX_CFG_STACKSIZE (VSF_KERNEL_CFG_THREAD_STACK_PAGE_SIZE + VSF_KERNEL_CFG_THREAD_STACK_GUARDIAN_SIZE)
82# define VSF_LINUX_CFG_STACKSIZE 1024
85#if VSF_LINUX_CFG_STACKSIZE > 0xFFFF
86# if VSF_KERNEL_CFG_THREAD_STACK_LARGE != ENABLED
87# error stacks should be 16-bit if VSF_KERNEL_CFG_THREAD_STACK_LARGE is not enabled
90#if (VSF_LINUX_CFG_STACKSIZE < (VSF_KERNEL_CFG_THREAD_STACK_PAGE_SIZE + VSF_KERNEL_CFG_THREAD_STACK_GUARDIAN_SIZE))\
91 || (VSF_LINUX_CFG_STACKSIZE & (VSF_KERNEL_CFG_THREAD_STACK_PAGE_SIZE - 1))
92# error invalid VSF_LINUX_CFG_STACKSIZE
97#define vsf_linux_thread_get_priv(__thread) (void *)(&(((vsf_linux_thread_t *)(__thread))[1]))
135#if VSF_LINUX_CFG_PLS_NUM > 0 || VSF_LINUX_CFG_TLS_NUM > 0
136typedef struct vsf_linux_localstorage_t {
138 void (*destructor)(
void *
data);
139} vsf_linux_localstorage_t;
141typedef struct vsf_linux_dynlib_mod_t {
147 void (*init)(
void *ctx);
148} vsf_linux_dynlib_mod_t;
150typedef struct vsf_linux_dynlib_t {
164#if VSF_LINUX_CFG_SUPPORT_SIG == ENABLED
173#if VSF_LINUX_CFG_PLS_NUM > 0
177#if VSF_LINUX_CFG_TLS_NUM > 0
183 implement(vsf_thread_t)
184 implement(vsf_thread_cb_t)
198#if VSF_LINUX_CFG_SUPPORT_SIG == ENABLED
201#if VSF_LINUX_CFG_TLS_NUM > 0
204#if VSF_ARCH_USE_THREAD_REG == ENABLED \
205 && VSF_LINUX_USE_SIMPLE_LIBC == ENABLED && VSF_LINUX_USE_SIMPLE_STDLIB == ENABLED\
206 && VSF_LINUX_APPLET_USE_LIBC_STDLIB == ENABLED && !defined(__VSF_APPLET__)
210 } process_reg_backup;
219 unsigned short wantval;
242#if VSF_KERNEL_CFG_EDA_SUPPORT_TIMER == ENABLED
254#if VSF_LINUX_USE_SIMPLE_LIBC == ENABLED && VSF_LINUX_USE_SIMPLE_STDLIB == ENABLED\
255 && VSF_LINUX_SIMPLE_STDLIB_CFG_HEAP_MONITOR == ENABLED
263#ifdef VSF_ARCH_ALLOC_BEFORE_ENTRY
266#if VSF_LINUX_SIMPLE_STDLIB_CFG_HEAP_MONITOR_TRACE_CALLER == ENABLED
275# if VSF_LINUX_SIMPLE_STDLIB_HEAP_MONITOR_MAX == ENABLED
287#if VSF_LINUX_LIBC_USE_ENVIRON == ENABLED
290#if VSF_LINUX_USE_VFORK == ENABLED
291 jmp_buf __vfork_jmpbuf;
296#
if VSF_ARCH_USE_THREAD_REG ==
ENABLED
309#if VSF_KERNEL_CFG_EDA_SUPPORT_TIMER == ENABLED
313#if VSF_LINUX_USE_SIMPLE_LIBC == ENABLED && VSF_LINUX_USE_SIMPLE_STDLIB == ENABLED\
314 && VSF_LINUX_SIMPLE_STDLIB_CFG_HEAP_MONITOR == ENABLED
321#define __VSF_LINUX_PROCESS_HAS_PATH (VSF_LINUX_USE_PROCFS == ENABLED || VSF_LINUX_USE_APPLET == ENABLED || VSF_LINUX_USE_SCRIPT == ENABLED)
322#if __VSF_LINUX_PROCESS_HAS_PATH
326#if VSF_USE_LOADER == ENABLED
342#if VSF_LINUX_CFG_SUPPORT_SIG == ENABLED
356#if VSF_LINUX_USE_VFORK == ENABLED
360#if VSF_LINUX_CFG_PLS_NUM > 0
362 vsf_bitmap(vsf_linux_pls_bitmap) dynlib_bitmap;
367#if VSF_LINUX_CFG_TLS_NUM > 0
379#if VSF_LINUX_USE_APPLET == ENABLED
383#if VSF_LINUX_CFG_PLS_NUM > 0
391# ifndef __VSF_APPLET__
396#if defined(__VSF_APPLET__) && (defined(__VSF_APPLET_LIB__) || defined(__VSF_APPLET_LINUX_FUNDMENTAL_LIB__))\
397 && VSF_APPLET_CFG_ABI_PATCH != ENABLED && VSF_LINUX_USE_APPLET == ENABLED
399#ifndef VSF_LINUX_APPLET_FUNDMENTAL_VPLT
400# if VSF_LINUX_USE_APPLET == ENABLED
401# define VSF_LINUX_APPLET_FUNDMENTAL_VPLT \
402 ((vsf_linux_fundmental_vplt_t *)(VSF_LINUX_APPLET_VPLT->fundmental_vplt))
404# define VSF_LINUX_APPLET_FUNDMENTAL_VPLT \
405 ((vsf_linux_fundmental_vplt_t *)vsf_vplt((void *)0))
409#define VSF_LINUX_APPLET_FUNDMENTAL_ENTRY(__NAME) \
410 VSF_APPLET_VPLT_ENTRY_FUNC_ENTRY(VSF_LINUX_APPLET_FUNDMENTAL_VPLT, __NAME)
411#define VSF_LINUX_APPLET_FUNDMENTAL_IMP(...) \
412 VSF_APPLET_VPLT_ENTRY_FUNC_IMP(VSF_LINUX_APPLET_FUNDMENTAL_VPLT, __VA_ARGS__)
414#if VSF_LINUX_CFG_PLS_NUM > 0
415VSF_LINUX_APPLET_FUNDMENTAL_IMP(vsf_linux_dynlib_ctx_get,
void *,
const vsf_linux_dynlib_mod_t *mod) {
417 return VSF_LINUX_APPLET_FUNDMENTAL_ENTRY(vsf_linux_dynlib_ctx_get)(mod);
419VSF_LINUX_APPLET_FUNDMENTAL_IMP(vsf_linux_dynlib_ctx_set,
int,
const vsf_linux_dynlib_mod_t *mod,
void *ctx) {
421 return VSF_LINUX_APPLET_FUNDMENTAL_ENTRY(vsf_linux_dynlib_ctx_set)(mod, ctx);
429# if VSF_USE_LOADER == ENABLED
438#if VSF_LINUX_CFG_PLS_NUM > 0
439extern void * vsf_linux_dynlib_ctx_get(
const vsf_linux_dynlib_mod_t *mod);
440extern int vsf_linux_dynlib_ctx_set(
const vsf_linux_dynlib_mod_t *mod,
void *ctx);
443#define vsf_linux_dynlib_ctx vsf_linux_dynlib_ctx_get
448# if VSF_USE_LOADER == ENABLED
470#if VSF_LINUX_SIMPLE_STDLIB_CFG_HEAP_MONITOR == ENABLED
472# if VSF_LINUX_SIMPLE_STDLIB_CFG_HEAP_MONITOR_TRACE_CALLER == ENABLED
473# define __malloc_ex(__process, __size) ____malloc_ex((__process), (__size), __FILE__, __FUNCTION__, __LINE__)
474# define __calloc_ex(__process, __n, __size) ____calloc_ex((__process), (__n), (__size), __FILE__, __FUNCTION__, __LINE__)
475# define __realloc_ex(__process, __ptr, __size) ____realloc_ex((__process), (__ptr), (__size), __FILE__, __FUNCTION__, __LINE__)
476# define __strdup_ex(__process, __str) ____strdup_ex((__process), (char *)(__str), __FILE__, __FUNCTION__, __LINE__)
478# define __malloc_ex(__process, __size) ____malloc_ex((__process), (__size), NULL, NULL, 0)
479# define __calloc_ex(__process, __n, __size) ____calloc_ex((__process), (__n), (__size), NULL, NULL, 0)
480# define __realloc_ex(__process, __ptr, __size) ____realloc_ex((__process), (__ptr), (__size), NULL, NULL, 0)
481# define __strdup_ex(__process, __str) ____strdup_ex((__process), (char *)(__str), NULL, NULL, 0)
484# define __malloc_ex(__process, __size) vsf_linux_process_heap_malloc((__process), (__size))
485# define __calloc_ex(__process, __n, __size) vsf_linux_process_heap_calloc((__process), (__n), (__size))
486# define __free_ex(__process, __ptr) vsf_linux_process_heap_free((__process), (__ptr))
487# define __realloc_ex(__process, __ptr, __size) vsf_linux_process_heap_realloc((__process), (__ptr), (__size))
488# define __strdup_ex(__process, __str) vsf_linux_process_heap_strdup((__process), (char *)(__str))
503#if VSF_LINUX_CFG_PLS_NUM > 0
504extern vsf_err_t vsf_linux_library_init(
int *lib_idx,
void *lib_ctx,
void (*destructor)(
void *));
505extern void * vsf_linux_library_ctx(
int lib_idx);
507extern vsf_err_t vsf_linux_dynlib_init(
int *lib_idx,
int module_num,
int bss_size);
511#if VSF_LINUX_CFG_PLS_NUM > 0
512extern int vsf_linux_pls_alloc(
void);
513extern void vsf_linux_pls_free(
int idx);
514extern vsf_linux_localstorage_t * vsf_linux_pls_get(
int idx);
517#if defined(__VSF_LINUX_CLASS_IMPLEMENT) || defined(__VSF_LINUX_CLASS_INHERIT__)
518# if VSF_LINUX_CFG_TLS_NUM > 0
519extern int vsf_linux_tls_alloc(
void (*destructor)(
void *));
520extern void vsf_linux_tls_free(
int idx);
521extern vsf_linux_localstorage_t * vsf_linux_tls_get(
int idx);
528#define __vsf_linux_start_process_internal3(__entry, __argv, __stack_size, __prio)\
529 __vsf_linux_start_process_internal((__entry), (__argv), (__stack_size), (__prio))
530#define __vsf_linux_start_process_internal2(__entry, __argv, __stack_size) \
531 __vsf_linux_start_process_internal3((__entry), (__argv), (__stack_size), VSF_LINUX_CFG_PRIO_LOWEST)
532#define __vsf_linux_start_process_internal1(__entry, __argv) \
533 __vsf_linux_start_process_internal2((__entry), (__argv), 0)
534#define __vsf_linux_start_process_internal0(__entry) \
535 __vsf_linux_start_process_internal1(__entry, NULL)
538#define vsf_linux_start_process_internal(__entry, ...) \
539 __PLOOC_EVAL(__vsf_linux_start_process_internal, __VA_ARGS__)((__entry), ##__VA_ARGS__)
551#if VSF_ARCH_USE_THREAD_REG == ENABLED
562 int stack_size,
void *stack);
591#undef __VSF_LINUX_CLASS_IMPLEMENT
592#undef __VSF_LINUX_CLASS_INHERIT__
#define ENABLED
Definition __type.h:28
vsf_err_t
Definition __type.h:42
Definition vsf_heap.h:139
Definition vsf_linux.h:283
Definition vsf_linux.h:181
Definition vsf_linux.h:160
Definition vsf_simple_stream.h:254
uint64_t vsf_systimer_tick_t
Definition cortex_a_generic.h:70
struct ieee80211_ext_chansw_ie data
Definition ieee80211.h:80
__le16 timeout
Definition ieee80211.h:94
int pid_t
Definition types.h:113
int key_t
Definition types.h:112
#define PATH_MAX
Definition limits.h:11
#define vsf_dcl_class
Definition ooc_class.h:50
#define vsf_class(__name)
Definition ooc_class.h:52
void(* sighandler_t)(int)
Definition signal.h:40
uint32_t uintptr_t
Definition stdint.h:38
unsigned short uint16_t
Definition stdint.h:7
unsigned uint32_t
Definition stdint.h:9
unsigned int uint_fast32_t
Definition stdint.h:27
unsigned char uint8_t
Definition stdint.h:5
Definition vsf_list.h:888
Definition vsf_list.h:883
Definition vsf_linux.h:380
vsf_vplt_info_t info
Definition vsf_linux.h:381
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(vsf_linux_get_cur_process)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(vsf_linux_loader_keep_ram)
Definition vsf_linux.h:273
vsf_dlist_t list
Definition vsf_linux.h:279
size_t usage
Definition vsf_linux.h:274
size_t max_usage
Definition vsf_linux.h:276
int balance
Definition vsf_linux.h:278
Definition vsf_linux.h:130
vsf_dlist_node_t node
Definition vsf_linux.h:131
key_t key
Definition vsf_linux.h:132
Definition vsf_linux.h:111
int argc
Definition vsf_linux.h:112
char const ** argv
Definition vsf_linux.h:113
Definition vsf_linux.h:125
vsf_linux_process_arg_t arg
Definition vsf_linux.h:126
vsf_linux_main_entry_t entry
Definition vsf_linux.h:127
Definition vsf_linux.h:225
void(* sigaction_handler)(int, siginfo_t *, void *)
Definition vsf_linux.h:232
vsf_dlist_node_t node
Definition vsf_linux.h:226
uint8_t sig
Definition vsf_linux.h:227
sighandler_t sighandler
Definition vsf_linux.h:231
sigset_t mask
Definition vsf_linux.h:229
uint32_t flags
Definition vsf_linux.h:228
Definition vsf_linux.h:236
vsf_stream_t * err
Definition vsf_linux.h:239
vsf_stream_t * out
Definition vsf_linux.h:238
vsf_stream_t * in
Definition vsf_linux.h:237
Definition vsf_linux.h:119
void(* on_run)(vsf_thread_cb_t *cb)
Definition vsf_linux.h:121
int priv_size
Definition vsf_linux.h:120
void(* on_terminate)(vsf_linux_thread_t *thread)
Definition vsf_linux.h:122
Definition vsf_linux.h:243
int overrun
Definition vsf_linux.h:246
struct itimerspec value
Definition vsf_linux.h:244
vsf_systimer_tick_t start
Definition vsf_linux.h:248
vsf_callback_timer_t timer
Definition vsf_linux.h:247
struct sigevent evt
Definition vsf_linux.h:245
Definition vsf_linux.h:257
const char * file
Definition vsf_linux.h:268
int line
Definition vsf_linux.h:267
size_t size
Definition vsf_linux.h:261
vsf_dlist_node_t node
Definition vsf_linux.h:258
const char * func
Definition vsf_linux.h:269
void * ptr
Definition vsf_linux.h:260
@ ITIMER_NUM
Definition time.h:39
#define _exit
Definition unistd.h:93
#define dcl_vsf_bitmap(__name, __bit_size)
Definition vsf_bitmap.h:98
#define vsf_bitmap(__name)
Definition vsf_bitmap.h:93
#define VSF_APPLET_VPLT_ENTRY_FUNC_DEF(__NAME)
Definition vsf_cfg.h:156
#define __VSF_VPLT_DECORATOR__
Definition vsf_cfg.h:93
#define VSF_APPLET_VPLT_ENTRY_FUNC_TRACE()
Definition vsf_cfg.h:165
VSF_KERNEL_TIMEOUT_TICK_T vsf_timeout_tick_t
Definition vsf_eda.h:592
@ VSF_EVT_USER
Definition vsf_eda.h:621
uint_fast32_t alignment
Definition vsf_heap.h:172
vsf_prio_t
Definition vsf_kernel_common.h:37
uintptr_t vsf_linux_set_process_reg(uintptr_t reg)
Definition vsf_linux.c:1604
int vsf_linux_trigger_signal(vsf_linux_trigger_t *trig, int sig)
Definition vsf_linux.c:696
int vsf_linux_start_process(vsf_linux_process_t *process)
Definition vsf_linux.c:1377
VSF_CAL_NO_RETURN void vsf_linux_exit_process(int status, bool _exit)
Definition vsf_linux.c:1472
vsf_linux_process_t * vsf_linux_create_process(int stack_size, int heap_size, int priv_size)
Definition vsf_linux.c:1347
int vsf_linux_trigger_pend(vsf_linux_trigger_t *trig, vsf_timeout_tick_t timeout)
Definition vsf_linux.c:716
void vsf_linux_cleanup_process(vsf_linux_process_t *process)
Definition vsf_linux.c:1386
void vsf_linux_thread_on_terminate(vsf_linux_thread_t *thread)
Definition vsf_linux.c:1839
vsf_linux_process_t * __vsf_linux_start_process_internal(vsf_linux_main_entry_t entry, char *const *argv, int stack_size, vsf_prio_t prio)
Definition vsf_linux.c:1610
void vsf_linux_trigger_init(vsf_linux_trigger_t *trig)
Definition vsf_linux.c:687
vsf_linux_process_t * vsf_linux_get_process(pid_t pid)
Definition vsf_linux.c:1631
int vsf_linux_wait_thread(int tid, int *retval)
Definition vsf_linux.c:1904
int vsf_linux_merge_env(vsf_linux_process_t *process, char **env)
Definition vsf_linux.c:655
bool vsf_linux_is_inited(void)
Definition vsf_linux.c:998
int __vsf_linux_process_parse_arg(vsf_linux_process_t *process, vsf_linux_process_arg_t *arg, char *const *argv)
Definition vsf_linux.c:868
void __vsf_linux_process_free_arg(vsf_linux_process_t *process)
Definition vsf_linux.c:855
void vsf_linux_free_env(vsf_linux_process_t *process)
Definition vsf_linux.c:674
vsf_linux_process_t * vsf_linux_get_real_process(vsf_linux_process_t *process)
Definition vsf_linux.c:353
vsf_linux_thread_t * vsf_linux_get_thread(pid_t pid, int tid)
Definition vsf_linux.c:1644
void vsf_linux_detach_process(vsf_linux_process_t *process)
Definition vsf_linux.c:1881
void vsf_linux_detach_thread(vsf_linux_thread_t *thread)
Definition vsf_linux.c:1892
void vsf_linux_delete_process(vsf_linux_process_t *process)
Definition vsf_linux.c:1453
int vsf_linux_fs_get_executable(const char *pathname, vsf_linux_main_entry_t *entry)
Definition vsf_linux.c:3002
int vsf_linux_start_thread(vsf_linux_thread_t *thread, vsf_prio_t priority)
Definition vsf_linux.c:1188
vsf_linux_thread_t * vsf_linux_create_thread(vsf_linux_process_t *process, const vsf_linux_thread_op_t *op, int stack_size, void *stack)
Definition vsf_linux.c:1169
int(* vsf_linux_main_entry_t)(int, char **)
Definition vsf_linux.h:116
void * vsf_linux_process_heap_malloc_aligned(vsf_linux_process_t *process, uint_fast32_t size, uint_fast32_t alignment)
Definition vsf_linux.c:1229
int(* vsf_linux_process_arg_parser_t)(vsf_linux_process_arg_t *arg)
Definition vsf_linux.h:117
void * vsf_linux_malloc_res(size_t size)
Definition vsf_linux.c:973
int vsf_linux_chdir(vsf_linux_process_t *process, char *working_dir)
Definition vsf_linux_fs.c:1683
void * vsf_linux_process_heap_malloc(vsf_linux_process_t *process, size_t size)
Definition vsf_linux.c:1240
@ __VSF_EVT_LINUX_EVENTFD_INC
Definition vsf_linux.h:104
@ __VSF_EVT_LINUX_TERM_RX
Definition vsf_linux.h:105
vsf_systimer_tick_t vsf_linux_sleep(vsf_timeout_tick_t ticks)
Definition vsf_linux.c:3067
char * vsf_linux_process_heap_strdup(vsf_linux_process_t *process, char *str)
Definition vsf_linux.c:1276
vsf_eda_t * vsf_linux_get_kernel_task(void)
Definition vsf_linux.c:925
void * vsf_linux_process_heap_realloc(vsf_linux_process_t *process, void *buffer, uint_fast32_t size)
Definition vsf_linux.c:1208
int vsf_linux_fs_bind_executable(char *path, vsf_linux_main_entry_t entry)
Definition vsf_linux.c:3031
int vsf_linux_fd_bind_executable(int fd, vsf_linux_main_entry_t entry)
Definition vsf_linux.c:3022
void vsf_linux_free_res(void *ptr)
Definition vsf_linux.c:978
int vsf_linux_expandenv(const char *str, char *output, size_t bufflen)
Definition vsf_linux.c:4478
void vsf_linux_loader_keep_ram(void)
Definition vsf_linux.c:4589
size_t vsf_linux_process_heap_size(vsf_linux_process_t *process, void *buffer)
Definition vsf_linux.c:1197
int vsf_linux_generate_path(char *path_out, int path_out_lenlen, char *dir, char *path_in)
Definition vsf_linux.c:788
__VSF_VPLT_DECORATOR__ vsf_linux_fundmental_vplt_t vsf_linux_fundmental_vplt
Definition vsf_linux.c:4840
vsf_linux_process_t * vsf_linux_get_cur_process(void)
Definition vsf_linux.c:1682
void __free_ex(vsf_linux_process_t *process, void *ptr)
Definition vsf_linux_glibc_stdlib.c:122
void vsf_linux_process_heap_free(vsf_linux_process_t *process, void *buffer)
Definition vsf_linux.c:1263
vsf_linux_thread_t * vsf_linux_get_cur_thread(void)
Definition vsf_linux.c:1673
vsf_err_t vsf_linux_init(vsf_linux_stdio_stream_t *stdio_stream)
Definition vsf_linux.c:1011
vsf_linux_process_t * vsf_linux_resources_process(void)
Definition vsf_linux.c:967
void * vsf_linux_process_heap_calloc(vsf_linux_process_t *process, size_t n, size_t size)
Definition vsf_linux.c:1251
#define VSF_LINUX_CFG_FD_BITMAP_SIZE
Definition vsf_linux_cfg.h:38
#define VSF_LINUX_CFG_TLS_NUM
Definition vsf_linux_cfg.h:60
#define VSF_LINUX_CFG_ATEXIT_NUM
Definition vsf_linux_cfg.h:80
#define VSF_LINUX_CFG_PLS_NUM
Definition vsf_linux_cfg.h:56
uint32_t size
Definition vsf_memfs.h:50
uint8_t status
Definition vsf_tgui.h:144
int sig
Definition vsf_thread.h:421