1. 完成量功能描述
指示等待的事件是否完成。初始化时为0。如果为0,则表示等待的事件未完成。大于0表示等待的事件已经完成。
2. 完成量初始化(两种方式)
a. 直接定义并调用init_completion()初始化,init_completion()会将done字段初始化为0,wait字段的自旋锁为未锁,等待队列为空。这说明调用该完成量的进程必须等待某事件完成(即另外一进程必须先调用completiom()唤醒该完成量)。
struct completion completion;
init_completion(&completion);
b. 通过宏初始化
DECLARE_COMPLETION(completion);
3. 等待完成量
a. 直接等待
wait_for_completion()
b. 超时等待
wait_for_completion_timeout()
c. 中断等待,即当前的等待是可以被中断打断,并直接返回
wait_for_completion_interruptible()
d. 中断打断超时
wait_for_completion_interruptible_timeout()
4. 唤醒完成量
completion()
指示等待的事件是否完成。初始化时为0。如果为0,则表示等待的事件未完成。大于0表示等待的事件已经完成。
2. 完成量初始化(两种方式)
a. 直接定义并调用init_completion()初始化,init_completion()会将done字段初始化为0,wait字段的自旋锁为未锁,等待队列为空。这说明调用该完成量的进程必须等待某事件完成(即另外一进程必须先调用completiom()唤醒该完成量)。
struct completion completion;
init_completion(&completion);
b. 通过宏初始化
DECLARE_COMPLETION(completion);
3. 等待完成量
a. 直接等待
wait_for_completion()
b. 超时等待
wait_for_completion_timeout()
c. 中断等待,即当前的等待是可以被中断打断,并直接返回
wait_for_completion_interruptible()
d. 中断打断超时
wait_for_completion_interruptible_timeout()
4. 唤醒完成量
completion()