Add helper to run a function as a routine kmsg
[akaros.git] / kern / include / syscall.h
index 23a3062..304b4e8 100644 (file)
@@ -4,9 +4,11 @@
 #endif
 
 #include <ros/common.h>
+#include <ros/syscall.h>
 #include <process.h>
 #include <kref.h>
 #include <ns.h>
+#include <bitmap.h>
 
 #define SYSTRACE_ON                                    0x01
 #define SYSTRACE_LOUD                          0x02
@@ -19,7 +21,6 @@
 #define MAX_ASRC_BATCH                         10
 
 #define SYSTR_RECORD_SZ                                256
-#define SYSTR_BUF_SZ                           PGSIZE
 #define SYSTR_PRETTY_BUF_SZ                    (SYSTR_BUF_SZ -                            \
                                      sizeof(struct systrace_record))
 struct systrace_record {
@@ -38,6 +39,7 @@ struct systrace_record {
                uint32_t                vcoreid;
                char                    *pretty_buf;
                uint8_t                 datalen;
+               int                             errno;
        };
        uint8_t                 data[SYSTR_RECORD_SZ - sizeof(struct systrace_record_anon)];
 };
@@ -45,13 +47,18 @@ struct systrace_record {
 struct strace {
        bool tracing;
        bool inherit;
+       bool drop_overflow;
        atomic_t nr_drops;
        unsigned long appx_nr_sysc;
        struct kref procs; /* when procs goes to zero, q is hung up. */
        struct kref users; /* when users goes to zero, q and struct are freed. */
        struct queue *q;
+       spinlock_t lock;
+       DECLARE_BITMAP(trace_set, MAX_SYSCALL_NR);
 };
 
+extern bool systrace_loud;
+
 /* Syscall table */
 typedef intreg_t (*syscall_t)(struct proc *, uintreg_t, uintreg_t, uintreg_t,
                               uintreg_t, uintreg_t, uintreg_t);
@@ -78,15 +85,7 @@ void set_cur_errbuf(struct errbuf *ebuf);
 char *get_cur_genbuf(void);
 void __signal_syscall(struct syscall *sysc, struct proc *p);
 
-/* Tracing functions */
-void systrace_start(bool silent);
-int systrace_trace_pid(struct proc *p);
-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);
-
 /* Utility */
 bool syscall_uses_fd(struct syscall *sysc, int fd);
 void print_sysc(struct proc *p, struct syscall *sysc);
+void kth_panic_sysc(struct kthread *kth);