linux 时间片是按照进程来分配的吗,Linux0.11进程分配时间片的策略

想知道内核什么时候给进程重新分配时间片,最好的办法就是阅读源代码(其中已经打了注释)

/****************************************************************************/

/* 功能:进程调度。*/

/* 先对alarm和信号进行处理,如果某个进程处于可中断睡眠状态,并且收*/

/* 到信号,则把进程状态改成可运行。之后在处可运行状态的进程中挑选一个*/

/* 并用switch_to()切换到那个进程*/

/* 参数:(无)*/

/* 返回:(无)*/

/****************************************************************************/

void schedule(void)

{

int i,next,c;

struct task_struct ** p;

/* check alarm, wake up any interruptible tasks that have got a signal */

// 首先处理alarm信号,唤醒所有收到信号的可中断睡眠进程

for(p = &LAST_TASK ; p > &FIRST_TASK ; --p)

if (*p) {

// 如果进程设置了alarm,并且alarm已经到时间了

if ((*p)->alarm && (*p)->alarm < jiffies) {

// 向该进程发送SIGALRM信号

(*p)->signal |= (1<

(*p)->alarm = 0;// 清除alarm

}

//可屏蔽信号位图BLOCKABLE定义在sched.c第24行,(~(_S(SIGKILL) | _S(SIGSTOP)))

// 说明SIGKILL和SIGSTOP是不能被屏蔽的。

// 可屏蔽信号位图 & 当前进程屏蔽的信号位图 = 当前进程实际屏蔽的信号位图

// 当前进程收到的信号位图 & ~当前进程实际屏蔽的信号位图

//= 当前进程收到的允许相应的信号位图

// 如果当前进程收到允许相应的信号,并且当前进程处于可中断睡眠态

// 则把状态改成运行态,参与下面的选择过程

if (((*p)->signal & ~(_BLOCKABLE & (*p)->blocked)) &&

(*p)->state==TASK_INTERRUPTIBLE)

(*p)->state=TASK_RUNNING;

}

/* this is the scheduler proper: */

// 下面是进程调度的主要部分

while (1) {

c = -1;

next = 0;

i = NR_TASKS;

p = &task[NR_TASKS];

while (--i) {// 遍历整个task[]数组

if (!*--p)// 跳过task[]中的空项

continue;

// 寻找剩余时间片最长的可运行进程,

// c记录目前找到的最长时间片

// next记录目前最长时间片进程的任务号

if ((*p)->state == TASK_RUNNING && (*p)->counter > c)

c = (*p)->counter, next = i;

}

// 如果有进程时间片没有用完c一定大于0。这时退出循环,执行 switch_to任务切换

if (c) break;

// 到这里说明所有可运行进程的时间片都用完了,则利用任务优先级重新分配时间片。

// 这里需要重新设置所有任务的时间片,而不光是可运行任务的时间片。

// 利用公式:counter = counter/2 + priority

for(p = &LAST_TASK ; p > &FIRST_TASK ; --p)

if (*p)

(*p)->counter = ((*p)->counter >> 1) +

(*p)->priority;

// 整个设置时间片过程结束后,重新进入进程选择过程

}

// 当的上面的循环退出时,说明找到了可以切换的任务

switch_to(next);

}

注意到,当系统中现在没有可以投入运行的进程,但是存在就绪态,不过其时间片为0,此时,就需要重新为进程分配时间片。

注意:

分配时间片不是对某一个进程而言的,是对系统中所有的进程而言,除进程0外。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux0.11中,进程是通过进程控制块(Process Control Block,PCB)来描述的。每个进程都有一个唯一的进程标识符(Process ID,PID),PCB 中存储了该进程的各种状态信息,包括进程状态、程序计数器、堆栈指针、资源占用情况等。 Linux0.11采用了基于时间片的轮转调度算法,即每个进程分配一个时间片,当时间片用完后,调度器会把正在运行的进程挂起,把CPU分配给下一个就绪进程。在进程的状态转换中,可发生以下三种情况: 1. 就绪:进程已经准备好运行,但尚未获得CPU。 2. 运行:进程正在运行,占用CPU。 3. 阻塞:进程因为等待某些事件(如I/O操作)而被阻塞。 当一个进程被创建时,它会被加入到就绪队列中,等待CPU分配。当进程被阻塞时,它会被移动到阻塞队列中,等待事件的发生。当事件发生后,进程会被移回就绪队列,等待CPU分配。当进程时间片用完时,它会被移回就绪队列,等待CPU分配。 在Linux0.11中,进程的调度是在时钟中断处理程序中完成的。当时钟中断发生时,调度器会根据就绪队列的优先级和时间片情况,选择下一个要运行的进程,并将CPU分配给它。如果当前进程时间片还没有用完,它会继续运行,直到时间片用完或者被阻塞。如果当前进程被阻塞,调度器会选择下一个就绪进程运行。 总之,Linux0.11采用了简单而高效的轮转调度算法,能够满足基本的进程管理需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值