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(唤醒队列所有等待进程检查唤醒条
件是否满足)操作,以达到使进程在等待条件未满足时保持休眠的目的。