parlib: Add a syscall lookup table (XCC)
[akaros.git] / user / parlib / include / parlib / parlib.h
1 // Main public header file for our user-land support library,
2 // whose code lives in the lib directory.
3 // This library is roughly our OS's version of a standard C library,
4 // and is intended to be linked into all user-mode applications
5 // (NOT the kernel or boot loader).
6
7 #pragma once
8
9 #ifndef __ASSEMBLER__
10
11 #include <parlib/common.h>
12 #include <ros/memlayout.h>
13 #include <ros/syscall.h>
14 #include <ros/procinfo.h>
15 #include <ros/procdata.h>
16 #include <signal.h>
17 #include <stdint.h>
18 #include <errno.h>
19 #include <parlib/ros_debug.h>
20 #include <ros/fdtap.h>
21
22 __BEGIN_DECLS
23
24 enum {
25         PG_RDONLY = 4,
26         PG_RDWR   = 6,
27 };
28
29 extern const char *const __syscall_tbl[];
30 extern int __syscall_tbl_sz;
31
32 int         sys_null(void);
33 size_t      sys_getpcoreid(void);
34 int         sys_proc_destroy(int pid, int exitcode);
35 void        sys_yield(bool being_nice);
36 int         sys_proc_create(const char *path, size_t path_l, char *const argv[],
37                             char *const envp[], int flags);
38 int         sys_proc_run(int pid);
39 ssize_t     sys_shared_page_alloc(void **addr, pid_t p2, 
40                                   int p1_flags, int p2_flags);
41 ssize_t     sys_shared_page_free(void *addr, pid_t p2);
42 void        sys_reboot();
43 void            *sys_mmap(void *addr, size_t length, int prot, int flags,
44                       int fd, size_t offset);
45 int                     sys_provision(int pid, unsigned int res_type, long res_val);
46 int         sys_notify(int pid, unsigned int ev_type, struct event_msg *u_msg);
47 int         sys_self_notify(uint32_t vcoreid, unsigned int ev_type,
48                             struct event_msg *u_msg, bool priv);
49 int         sys_halt_core(unsigned long usec);
50 void*           sys_init_arsc();
51 int         sys_block(unsigned long usec);
52 int         sys_change_vcore(uint32_t vcoreid, bool enable_my_notif);
53 int         sys_change_to_m(void);
54 int         sys_poke_ksched(int pid, unsigned int res_type);
55 int         sys_abort_sysc(struct syscall *sysc);
56 int         sys_abort_sysc_fd(int fd);
57 int         sys_tap_fds(struct fd_tap_req *tap_reqs, size_t nr_reqs);
58
59 void            syscall_async(struct syscall *sysc, unsigned long num, ...);
60 void        syscall_async_evq(struct syscall *sysc, struct event_queue *evq,
61                               unsigned long num, ...);
62
63 /* Control variables */
64 extern bool parlib_wants_to_be_mcp;     /* instructs the 2LS to be an MCP */
65 extern bool parlib_never_yield;         /* instructs the 2LS to not yield vcores */
66 extern bool parlib_never_vc_request;/* 2LS: do not request vcores */
67
68 /* Process Management */
69 pid_t create_child(const char *exe, int argc, char *const argv[],
70                    char *const envp[]);
71 pid_t create_child_with_stdfds(const char *exe, int argc, char *const argv[],
72                                char *const envp[]);
73
74 __END_DECLS
75
76 #endif  // !ASSEMBLER