Fixes netlog
[akaros.git] / kern / include / kthread.h
index 6ac725c..e3bd513 100644 (file)
@@ -36,6 +36,7 @@ struct kthread {
        bool                                            is_ktask;       /* default is FALSE */
        char                                            *name;
        char                                            generic_buf[GENBUF_SZ];
+       struct systrace_record          *trace;
 };
 
 /* Semaphore for kthreads to sleep on.  0 or less means you need to sleep */
@@ -63,11 +64,12 @@ struct cond_var {
 
 struct cv_lookup_elm {
        TAILQ_ENTRY(cv_lookup_elm)      link;
+       TAILQ_ENTRY(cv_lookup_elm)      abortall_link;          /* only used in abort_all */
        struct cond_var                         *cv;
        struct kthread                          *kthread;
        struct syscall                          *sysc;
        struct proc                                     *proc;
-       bool                                            abort_in_progress;
+       atomic_t                                        abort_in_progress;      /* 0 = no */
 };
 TAILQ_HEAD(cv_lookup_tailq, cv_lookup_elm);
 
@@ -112,8 +114,17 @@ void cv_signal_irqsave(struct cond_var *cv, int8_t *irq_state);
 void cv_broadcast_irqsave(struct cond_var *cv, int8_t *irq_state);
 
 bool abort_sysc(struct proc *p, struct syscall *sysc);
+void abort_all_sysc(struct proc *p);
+int abort_all_sysc_fd(struct proc *p, int fd);
 void __reg_abortable_cv(struct cv_lookup_elm *cle, struct cond_var *cv);
 void dereg_abortable_cv(struct cv_lookup_elm *cle);
 bool should_abort(struct cv_lookup_elm *cle);
 
+/* qlocks are plan9's binary sempahore, which are wrappers around our sems */
+typedef struct semaphore qlock_t;
+#define qlock_init(x) sem_init((x), 1)
+#define qlock(x) sem_down(x)
+#define qunlock(x) sem_up(x)
+#define canqlock(x) sem_trydown(x)
+
 #endif /* ROS_KERN_KTHREAD_H */