12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- #include <common/wait_queue_head.h>
- #include <process/process.h>
- #include <sched/sched.h>
- void wait_queue_head_init(wait_queue_head_t *wait_queue)
- {
- list_init(&wait_queue->wait_list);
- spin_init(&wait_queue->lock);
- }
- void wait_queue_sleep_with_node(wait_queue_head_t *q, wait_queue_node_t *wait)
- {
- BUG_ON(wait->pcb == NULL);
- wait->pcb->state = PROC_UNINTERRUPTIBLE;
- list_append(&q->wait_list, &wait->wait_list);
- sched();
- }
- void wait_queue_sleep_with_node_unlock(wait_queue_head_t *q, wait_queue_node_t *wait, void *lock)
- {
- BUG_ON(wait->pcb == NULL);
- wait->pcb->state = PROC_UNINTERRUPTIBLE;
- list_append(&q->wait_list, &wait->wait_list);
- spin_unlock((spinlock_t *)lock);
- sched();
- }
- void wait_queue_sleep_with_node_interriptible(wait_queue_head_t *q, wait_queue_node_t *wait)
- {
- BUG_ON(wait->pcb == NULL);
- wait->pcb->state = PROC_INTERRUPTIBLE;
- list_append(&q->wait_list, &wait->wait_list);
- sched();
- }
- void wait_queue_wakeup_on_stack(wait_queue_head_t *q, int64_t state)
- {
- if (list_empty(&q->wait_list))
- return;
- wait_queue_node_t *wait = container_of(list_next(&q->wait_list), wait_queue_node_t, wait_list);
-
- if (wait->pcb->state & state)
- {
- list_del_init(&wait->wait_list);
- process_wakeup(wait->pcb);
- }
- }
|