您的位置:首页 > 大数据 > 人工智能

completion和wait_for_event的区别

2016-11-09 22:54 399 查看
mutex和completion是一种同步机制,用于在两个进程之间其同步作用:

A进程调用wait_for_completion(&data->prev_finished);

 等待其他进程对data->prev_finished执行complete操作。
B进程调用complete(&next->prev_finished);

 通知等待在next->prev_finished上的进程可以继续执行了。

wait_for_event是一种使进程休眠等待的机制,休眠,直到某个事件发生,使进
程可以继续执行:

wait_event(ihost->eventq, condition);

 在休眠前后都对condition进行检查,休眠,直到condition为真,
wake_up(&ihost->eventq);

 唤醒等待在等待队列ihost->eventq上的所有进程,被唤醒的进程都检查
各自的condition,为真的唤醒执行,否则继续休眠。
总结:

completion机制是两个进程间互相同步的工具,而wait_for_event则是让多个进
程在一个等待队列上休眠等待某事件的机制。
completion以一个completion结构体变量为核心,两个进程围绕该变量执行
wait_for_completion和complete操作,以达到实现两个进程同步的目的,
wait_for_event则是一个一个等待队列为核心,N个进程围绕该队列执行
wait_event(将自己加入等待队列)和wake_up(唤醒队列所有等待进程检查唤醒条
件是否满足)操作,以达到使进程在等待条件未满足时保持休眠的目的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: