void schedule(void)
{
int i,next,c;
struct task_struct ** p; //任务结构数组指针
//检测alarm(进程的报警定时值),唤醒任何已得到信号的可中断任务
for(p = &LAST_TASK ; p > &FIRST_TASK ; --p) //从任务结构数组中从后向前依次遍历数组
if (*p) {
// 如果设置过任务的定时值alarm,并且已经过期(alarm<jiffies),则在信号位图中置SIGALRM 信号,
// 即向任务发送SIGALARM 信号。然后清alarm。该信号的默认操作是终止进程。
// jiffies 是系统从开机开始算起的滴答数(10ms/滴答)。定义在sched.h 第139 行。
if ((*p)->alarm && (*p)->alarm < jiffies) {
(*p)->signal |= (1<<(SIGALRM-1));
&n
Linux内核0.11版本调度算法深入解析

本文详细分析了Linux内核0.11版本中的schedule()函数,探讨了如何检测和处理任务的报警定时值,以及如何根据任务的信号位图和状态进行调度。通过对任务结构数组的遍历,找出counter值最大并进行切换,同时更新所有任务的counter值,确保系统的任务调度公平和高效。
最低0.47元/天 解锁文章
508

被折叠的 条评论
为什么被折叠?



