Linux内核下等待队列的使用
1、wait_queue的使用
需要的头文件#include<linux/wait.h>
typedef struct __wait_queue wait_queue_t;
struct __wait_queue {
unsigned int flags;
#define WQ_FLAG_EXCLUSIVE 0x01
void *private;
wait_queue_func_t func;
struct list_head task_list;
};
struct __wait_queue_head {
spinlock_t lock;
struct list_head task_list;
};
typedef struct __wait_queue_head wait_queue_head_t;
Static wait_queue_head_t waitq;
用到的函数:
extern void __init_waitqueue_head(wait_queue_head_t *q, struct lock_class_key *);
#define init_waitqueue_head(q) \
do { \
static struct lock_class_key __key; \
\
__init_waitqueue_head((q), &__key); \
} while (0)
用于初始化一个wait_queue_head_t变量
#define wake_up_interruptible(x) __wake_up(x, TASK_INTERRUPTIBLE, 1, NULL)
#define wake_up(x) __wake_up(x, TASK_NORMAL, 1, NULL)
唤醒waitq里的processes,该操作唤醒所有的processes
用于block的函数:
void interruptible_sleep_on(wait_queue_head_t *q);
void sleep_on(wait_queue_head_t *q);
上面两组中wait_up与wait_up_interruptible()的区别是:
如果你是用 interruptible_sleep_on() 来将 process 放到 wait_queue 时,如果有人送一个 signal 给这个 process,那它就会自动从 wait_queue 中醒来。但是如果你是用 sleep_on() 把 process 放到 wq 中的话,那不管你送任何的 signal 给它,它还是不会理你的。除非你是使用 wake_up() 将它叫醒。sleep 有两组。wake_up 也有两组。wake_up_interruptible() 会将 wq 中使用 interruptible_sleep_on() 的 process 叫醒。至于 wake_up() 则是会将 wq 中所有的 process 叫醒。包括使用 interruptible_sleep_on() block的 process。
使用sleep的步骤
Static wait_queue_head_t waitq;
init_waitqueue_head(&waitq);
wake_up_interruptible(&waitq)
interruptible_sleep_on(&waitq)
注意:以上函数只能在内核层运行,不能在用户层运行。