完成量(名称上区别信号量),是根据等待队列实现的,看如下定义,可见它就是一个等待队列另加一个计数器:
struct completion {
unsigned int done; //计数器
struct swait_queue_head wait; //等待队列
};
初始化完成量,函数init_completion(),就是把计数器初始化为0,并初始化等待队列:
static inline void init_completion(struct completion *x)
{
x->done = 0;
init_swait_queue_head(&x->wait);
}
使用完成量,函数对:wait_for_completion() 和 complete() 函数,这俩函数我们不再展开介绍,我们主要看一下这俩函数对completion中的成员done的操作;
每次调用 complete() 时done就加1,
但wait_for_completion()只有在done==0时,进程才进入睡眠,
这就意味着 进程不必要等待已经发生的事件;因为事件发生已经调用了complete() ,此时done已经++,而后在调用wait_for_completion()时,发现done!=0,进程就不会睡眠;这就是完成量与等待队列的差别支持!