1 #include <lunaix/ds/waitq.h>
2 #include <lunaix/process.h>
3 #include <lunaix/spike.h>
9 // prevent race condition.
10 cpu_disable_interrupt();
12 waitq_t* current_wq = &__current->waitqueue;
13 assert(llist_empty(¤t_wq->waiters));
15 llist_append(&queue->waiters, ¤t_wq->waiters);
20 cpu_enable_interrupt();
24 pwake_one(waitq_t* queue)
26 if (llist_empty(&queue->waiters)) {
30 waitq_t* wq = list_entry(queue->waiters.next, waitq_t, waiters);
31 struct proc_info* proc = container_of(wq, struct proc_info, waitqueue);
33 assert(proc->state == PS_BLOCKED);
34 proc->state = PS_READY;
35 llist_delete(&wq->waiters);
39 pwake_all(waitq_t* queue)
41 if (llist_empty(&queue->waiters)) {
45 struct proc_info* proc;
47 llist_for_each(pos, n, &queue->waiters, waiters)
49 proc = container_of(pos, struct proc_info, waitqueue);
51 assert(proc->state == PS_BLOCKED);
52 proc->state = PS_READY;
53 llist_delete(&pos->waiters);