DragonOS/kernel/process/wait_queue.c

65 lines
1.5 KiB
C
Raw Normal View History

#include "wait_queue.h"
#include <sched/sched.h>
#include <process/process.h>
/**
* @brief
*
* @param wait_queue
* @param pcb pcb
*/
void wait_queue_init(wait_queue_node_t *wait_queue, struct process_control_block *pcb)
{
list_init(&wait_queue->wait_list);
wait_queue->pcb = pcb;
}
/**
* @brief
*
* @param wait_queue_head
*/
void wait_queue_sleep_on(wait_queue_node_t *wait_queue_head)
{
wait_queue_node_t wait;
wait_queue_init(&wait, current_pcb);
current_pcb->state = PROC_UNINTERRUPTIBLE;
list_append(&wait_queue_head->wait_list, &wait.wait_list);
sched_cfs();
}
/**
* @brief ()
*
* @param wait_queue_head
*/
void wait_queue_sleep_on_interriptible(wait_queue_node_t * wait_queue_head)
{
wait_queue_node_t wait;
wait_queue_init(&wait, current_pcb);
current_pcb->state = PROC_INTERRUPTIBLE;
list_append(&wait_queue_head->wait_list, &wait.wait_list);
sched_cfs();
}
/**
* @brief
*
* @param wait_queue_head
* @param state
*/
void wait_queue_wakeup(wait_queue_node_t * wait_queue_head, int64_t state)
{
if(list_empty(&wait_queue_head->wait_list))
return;
wait_queue_node_t * wait = container_of(list_next(&wait_queue_head->wait_list), wait_queue_node_t, wait_list);
// 符合唤醒条件
if(wait->pcb->state & state)
{
list_del(&wait->wait_list);
process_wakeup(wait->pcb);
}
}