Kernel alarm tchains use locks
[akaros.git] / kern / include / syscall.h
index cbab190..13bf72b 100644 (file)
 struct systrace_record {
        uint64_t                timestamp;
        uintreg_t               syscallno;
+       uintreg_t               arg0;
+       uintreg_t               arg1;
+       uintreg_t               arg2;
+       uintreg_t               arg3;
+       uintreg_t               arg4;
+       uintreg_t               arg5;
        int                             pid;
        uint32_t                coreid;
        uint32_t                vcoreid;
 };
 
-struct sys_return {
-       uint32_t *returnloc;
-       uint32_t *errno_loc;
+/* Syscall table */
+typedef intreg_t (*syscall_t)(struct proc *, uintreg_t, uintreg_t, uintreg_t,
+                              uintreg_t, uintreg_t, uintreg_t);
+struct sys_table_entry {
+       syscall_t call;
+       char *name;
 };
-
-intreg_t syscall(struct proc *p, uintreg_t num, uintreg_t a1, uintreg_t a2,
-                 uintreg_t a3, uintreg_t a4, uintreg_t a5);
+const static struct sys_table_entry syscall_table[];
+/* Syscall invocation */
+void prep_syscalls(struct proc *p, struct syscall *sysc, unsigned int nr_calls);
+void run_local_syscall(struct syscall *sysc);
+intreg_t syscall(struct proc *p, uintreg_t sc_num, uintreg_t a0, uintreg_t a1,
+                 uintreg_t a2, uintreg_t a3, uintreg_t a4, uintreg_t a5);
+void set_errno(int errno);
+void set_errstr(char *errstr, ...);
+char *current_errstr(void);
+struct errbuf *get_cur_errbuf(void);
+void set_cur_errbuf(struct errbuf *ebuf);
+void __signal_syscall(struct syscall *sysc, struct proc *p);
 
 /* Tracing functions */
 void systrace_start(bool silent);
@@ -41,7 +59,4 @@ int systrace_dereg(bool all, struct proc *p);
 void systrace_print(bool all, struct proc *p);
 void systrace_clear_buffer(void);
 
-/* direct returnval and errno handling */
-void set_errno(uint32_t errno);
-void set_retval(uint32_t retval);
 #endif /* !ROS_KERN_SYSCALL_H */