您的位置:首页 > 运维架构 > Linux

每日阅读6之linux内核设计与实现——抢占与上下文切换

2013-03-25 20:46 337 查看
上下文切换,即由一个可执行进程切换到另一个可执行线程。

由kernel/sched.c中的context_switch()函数完成,当一个进程准备投入运行时,schedule()调用该函数实现进程切换。

该函数完成二项基本工作

(1)调用<asm/mmu_context.h>中定义的switch_mm(),负责将虚拟内存从上一个进程映射切换到新进程中去。

(2)调用声明在<asm/system.h>中的switch_to(),负责将上一个进程的处理器状态切换到新进程的处理器状态,包括保存/恢复栈信息和寄存器信息。还有其他任何和体系结构相关的信息都必须与进程为对象进行管理和保存。。

内核需要知道什么时候重新进行一次调度schedule(),内核提供了一个标志need_sched来表明是否需要进行一次调度

每次返回用户空间或从中断返回时,内核都会去检查这个变量,已决定是否需要进行一次调度。。。。所以这个变量应该是和进程无关的,全局内核变量。。???

在内核2.2版本之前,也确实如此,是一个全局变量

2.2-2.4之间,将其放在task进程描述符结构体中的一个变量,因为访问速度比全局变量快(通常进程描述符放在高速cache中,why?)

2.6之后,放在thread_info中的一个标志位。。。

当内核从系统调用/中断处理程序返回到用户空间,检测发现need_sched被设置,则发生了用户抢占。

返回路径是体系结构相关的,定义在entry.S汇编语言中。

内核抢占,内核进程必须不持有锁,否则抢占式不安全的?死锁?

下一节实时调度策略。。。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: