- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux支持SMP,linuxsmp,linuxsmplock.h,linuxsmp调度,linuxbeam.smp,cdlinux支持的网卡,linux支持中文,linux支持的文件系统,linux支持ntfs,linuxapache支持php
Linux 是如何支持SMP 的
陈华才 2006.11
一、三个问题
在SMP 机器上,Linux 的启动过程是怎样的
?
在SMP 机器上,Linux 的进程调度如何进行
?
在SMP 机器中,中断系 有何特点?
华中科技大学 CGCLSCTS 实验室
二、Linux 启动过程(基本概念)
SMP 机器中,有以下几个基本概念:
BSP :也叫BP ,是Bootstrap Processor 的启缩 写,即 缩
CPU ,在操作系 统动过启程的前期,只有BSP 在执行指令
。
AP :Application Processor 的缩写,即应用CPU 。
APIC :高级 可编 程中断控制器,分为 本地APIC 和IO
APIC 。
IPI :处 理器间 中断,用于处 理器之间 的通信。
华中科技大学 CGCLSCTS 实验室
Linux 启动过程(续)
由于BIOS 代码并不是支持多线程的,所以在SMP
中,系统必须让所有AP 进入中断屏蔽状态,不与
BSP 一起执行BIOS 代码。为了达到这一目的,可
以利用两种手段:1 、利用系统硬件本身进行处理
;2 、系统硬件与BIOS 程序一起处理。在后一种
方法中,BIOS 程序将其它AP 置于中断屏蔽状态
,使其休眠,只选择BSP 执行BIOS 代码中的后继
部分。BIOS 要同时完成对APIC 以及其他与MP
相关的系统组件初始化过程,并建立相应的系统配
置表格,以便操作系统使用。
华中科技大学 CGCLSCTS 实验室
Linux 启动过程(主要流程)
1 ,BIOS 初始化(屏蔽AP ,建立系 配置表格)。
2 ,MBR 里面的引缩 程序(Gru ,Lilo 等)将内核加载到内存。
3 ,执行head.S 中的startup_32 函数(最后将调用start_kernel )。
4 ,执行start_kernel ,这个函数相当于应用程序里面的main ,在早期的内核
中,这个函数就叫main 。
5 ,start_kernel 进行一系列初始化,最后将执行
smp_init() // 启动各个AP ,关键的一步
rest_init() // 调用init() 创建1 号进程,自身执行
cpu_idle() 成为0 号进程
6 ,1 号进程即init 进程完成余下的工作。
华中科技大学 CGCLSCTS 实验室
Linux 启动过程(smp_init() 函
数)
static void __init smp_init(void) {
smp_boot_cpus();
smp_threads_ready=1;
smp_commence(); // 让各AP 开始执行指令
}
smp_boot_cpus() 函数初始化各AP ,设置为待命模式(holding pattern ,就是
处于等待BSP 发送IPI 指令的状态),并为之建立0 号进程。
smp_threads_ready=1 表示各AP 的idle 进程已经建立。
smp_commence() 函数让各AP 开始执行指令。
注意:在smp 机器中,有几个CPU ,就有几个idle 进程(0 号进程),但1 号
进程即init 进程只有一个。
华中科技大学 CGCLSCTS 实验室
Linux 启动过程(smp_boot_cpus() 函
文档评论(0)