如果内核中一个任务需要发出信号通知另外一个任务发生了某个特定事件,使用完成量completion是两个任得以同步的最简单方法。当任务1需要执行某些工作时,需要等待任务2完成特定操作才能继续执行,那么任务1就会阻塞等待,当任务2的特定操作执行完成之后,通过completion通知任务1并唤醒,这时候任务1可以继续执行。
头文件<linux/completion.h>
①声明一个completion
静态声明,不用初始化
DECLARE_COMPLETION(test_completion);
动态声明,需要初始化
struct completion test_completion;
init_completion(&test_completion);
结构体:
struct completion
{
unsigned int done;
wait_queue_head_t wait;
}
其中的done是用来计数的,每调用一次complet(),这个值就会加1,调用一次wait_for_completion(),这个值就会减1,所以completion是使用计数的机制的。
②任务1等待事件的发生
调wait_for_completion(t&est__completion);
也可以使用等待超时的timeout函数。
③任务2调用complet唤醒等待的任务1
void complete(struct completion *comp)只能唤醒一个等待的进程,而void completion_all(struct completion *comp)唤醒等待该事件的所有进程,由于completion的实现机制是通过计数来实现的,所以complet在wait_for_completion之前调用也可以正常工作。