任务.但需要注意的一种情况是,对不可中断睡眠模式的进程的唤醒呼叫可能会某些原因不会发生,这会使进程无法被终止,从而最终引发问题,惟一的解决方法就是重启系统.一方面,您需要考虑一些细节,不这样做会在内核端和用户端引入 bug.另一方面,您可能会生成永远不会停止的进程(被阻塞且无法终止的进程).
现在,我们在内核中实现了一种新的睡眠方法!
新睡眠状态:TASK_KILLABLE
Linux Kernel 2.6.25 引入了一种新的进程睡眠状态,TASK_KILLABLE:当进程处于这种可以终止的新睡眠状态中,它的运行原理类似于 TASK_UNINTERRUPTIBLE,只不过可以响应致命信号.清单 1 给出了内核 2.6.18 与内核 2.6.26 进程状态(定义在 include/linux/sched.h 中)之间的比较:
清单 1. 2.6.18 和 2.6.26 进程状态之间的比较
Linux Kernel 2.6.18 Linux Kernel 2.6.26
================================= ===================================
#define TASK_RUNNING 0 #define TASK_RUNNING 0
#define TASK_INTERRUPTIBLE 1 #define TASK_INTERRUPTIBLE 1
#define TASK_UNINTERRUPTIBLE 2 #define TASK_UNINTERRUPTIBLE 2
#define TASK_STOPPED 4 #define __TASK_STOPPED 4
#define TASK_TRACED 8 #define __TASK_TRACED 8
/* in tsk->exit_state */ /* in tsk->exit_state */
#define EXIT_ZOMBIE 16 #define EXIT_ZOMBIE 16
#define EXIT_DEAD 32 #define EXIT_DEAD 32
/* in tsk->state again */ /* in tsk->state again */
#define TASK_NONINTERACTIVE 64 #define TASK_DEAD 64
#define TASK_WAKEKILL 128
|
注意,状态 TASK_INTERRUPTIBLE 和 TASK_UNINTERRUPTIBLE 并未修改. TASK_WAKEKILL 用于在接收到致命信号时唤醒进程.
清单 2 展示了状态 TASK_STOPPED 和 TASK_TRACED 的修改之处(以及 TASK_KILLABLE 的定义):
清单 2. 内核 2.6.26 中的新状态定义
#define TASK_KILLABLE (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE)
#define TASK_STOPPED (TASK_WAKEKILL | __TASK_STOPPED)
#define TASK_TRACED (TASK_WAKEKILL | __TASK_TRACED)
|
换句话说,TASK_UNINTERRUPTIBLE TASK_WAKEKILL = TASK_KILLABLE.
使用 TASK_KILLABLE 的新内核 API
让我们来看看这种新状态中的新函数.
●int wait_event_killable(wait_queue_t queue, condition); ●该函数定义在 include/linux/wait.h 中;它将处于可终止睡眠状态的调用进程置于 queue 中,直到 condition 等于 true. ●long schedule_timeout_killable(signed long timeout); ●该函数定义在 kernel/timer.c 中;该例程主要用于将当前任务的状态设置为 TASK_KILLABLE 并调用 schedule_timeout(),它用于让调用任务睡眠 timeout 个 jiffies.(在 UNIX 系统中,jiffy 主要表示两个连续时钟计时单元之间的时间. ●int wait_for_completion_killable(struct completion *comp); ●此例程定义在 kernel/sched.c 中,它用于等待进程在事件完成后变为可终止状态.如果没有等待的致命信号,该函数将调用 schedule_timeout() 维持 MAX_SCHEDULE_TIMEOUT(指定为等于 LONG_MAX)个 jiffies 时间. ●int mutex_lock_killable(struct mutex *lock); ●定义在 kernel/mutex.c 中,该例 |