- 论坛徽章:
- 0
|
以下是代码部分
#define __wait_event_interruptible(wq, condition, ret) \
do { \
DEFINE_WAIT(__wait); \
\
for (; { \
prepare_to_wait(&wq, &__wait, TASK_INTERRUPTIBLE); \
if (condition) \
break; \
if (!signal_pending(current)) { \
schedule(); \
continue; \
} \
ret = -ERESTARTSYS; \
break; \
} \
finish_wait(&wq, &__wait); \
} while (0)
我标红字的部分,首先判断是否有信号要处理,没有的话重新调度,进程进入休眠
当再次被wake_up或信号唤醒后,接着应该执行 continue那句吗?这样的话ret = -ERESTARTSYS;这句一定会被执行,而这句的含义是告诉fs层信号函数处理完毕,重新执行信号函数前的某个系统调用。
我觉得应该改成
if (signal_pending(current)){
ret = -ERESTARTSYS;
break;}
schedule(); |
|