x86_64: save/pop kernel contexts
[akaros.git] / kern / include / syscall.h
index 01cf800..e84ebbe 100644 (file)
@@ -20,6 +20,7 @@
 struct systrace_record {
        uint64_t                timestamp;
        uintreg_t               syscallno;
+       uintreg_t               arg0;
        uintreg_t               arg1;
        uintreg_t               arg2;
        uintreg_t               arg3;
@@ -30,22 +31,21 @@ struct systrace_record {
        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, uintreg_t, uintreg_t);
 struct sys_table_entry {
        syscall_t call;
        char *name;
 };
 const static struct sys_table_entry syscall_table[];
 /* Syscall invocation */
-intreg_t syscall(struct proc *p, uintreg_t num, uintreg_t a1, uintreg_t a2,
-                 uintreg_t a3, uintreg_t a4, uintreg_t a5);
+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 __signal_syscall(struct syscall *sysc, struct proc *p);
 
 /* Tracing functions */
 void systrace_start(bool silent);
@@ -55,7 +55,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 */