Fixing syscalls to new seterrno and setretval.
[akaros.git] / kern / include / syscall.h
index 857eab9..cbab190 100644 (file)
@@ -4,17 +4,44 @@
 # error "This is ROS kernel header; user programs should not #include it"
 #endif
 
-#include <ros/syscall.h>
+#include <ros/common.h>
 #include <process.h>
 
+#define SYSTRACE_ON                                    0x01
+#define SYSTRACE_LOUD                          0x02
+#define SYSTRACE_ALLPROC                       0x04
+
+#define MAX_NUM_TRACED                         10
+#define MAX_SYSTRACES                          1024
+
+#define MAX_ASRC_BATCH                         10
+
+/* Consider cache aligning this */
+struct systrace_record {
+       uint64_t                timestamp;
+       uintreg_t               syscallno;
+       int                             pid;
+       uint32_t                coreid;
+       uint32_t                vcoreid;
+};
+
+struct sys_return {
+       uint32_t *returnloc;
+       uint32_t *errno_loc;
+};
+
 intreg_t syscall(struct proc *p, uintreg_t num, uintreg_t a1, uintreg_t a2,
                  uintreg_t a3, uintreg_t a4, uintreg_t a5);
-intreg_t syscall_async(env_t* e, syscall_req_t *syscall);
-intreg_t process_generic_syscalls(env_t* e, size_t max);
 
-intreg_t sys_read(struct proc* p, int fd, void* buf, int len);
-intreg_t sys_write(struct proc* p, int fd, const void* buf, int len);
-intreg_t sys_open(struct proc* p, const char* path);
-intreg_t sys_close(struct proc* p, int fd);
+/* Tracing functions */
+void systrace_start(bool silent);
+void systrace_stop(void);
+int systrace_reg(bool all, struct proc *p);
+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 */