1 #include <lunaix/ds/waitq.h>
2 #include <lunaix/process.h>
3 #include <lunaix/spike.h>
8 waitq_t* current_wq = &__current->waitqueue;
9 assert(llist_empty(¤t_wq->waiters));
11 llist_append(&queue->waiters, ¤t_wq->waiters);
13 // FIXME centralize the state change.
14 __current->state = PS_BLOCKED;
19 pwake_one(waitq_t* queue)
21 if (llist_empty(&queue->waiters)) {
25 waitq_t* wq = list_entry(queue->waiters.next, waitq_t, waiters);
26 struct proc_info* proc = container_of(wq, struct proc_info, waitqueue);
28 assert(proc->state == PS_BLOCKED);
29 proc->state = PS_READY;
30 llist_delete(&wq->waiters);
34 pwake_all(waitq_t* queue)
36 if (llist_empty(&queue->waiters)) {
40 struct proc_info* proc;
42 llist_for_each(pos, n, &queue->waiters, waiters)
44 proc = container_of(pos, struct proc_info, waitqueue);
46 proc->state = PS_READY;
47 llist_delete(&pos->waiters);