linux系统启动过程分析下.ppt

上传人:牧羊曲112 文档编号:5438112 上传时间:2023-07-07 格式:PPT 页数:42 大小:701.50KB
返回 下载 相关 举报
linux系统启动过程分析下.ppt_第1页
第1页 / 共42页
linux系统启动过程分析下.ppt_第2页
第2页 / 共42页
linux系统启动过程分析下.ppt_第3页
第3页 / 共42页
linux系统启动过程分析下.ppt_第4页
第4页 / 共42页
linux系统启动过程分析下.ppt_第5页
第5页 / 共42页
点击查看更多>>
资源描述

《linux系统启动过程分析下.ppt》由会员分享,可在线阅读,更多相关《linux系统启动过程分析下.ppt(42页珍藏版)》请在三一办公上搜索。

1、linux系统启动过程分析(下),第二节 Linux0.01启动分析,引导过程的描述引导流程和内核镜像文件计算机加电过程BIOS程序操作系统引导部分代码的分析Boot.s的分析head.s的分析Head.s的作用 AT&T汇编语言初步,引导过程的描述,引导流程和内核镜像文件计算机加电过程BIOS程序,引导的步骤,一般来说,操作系统的引导过程分两个步骤:首先,计算机硬件经过开机自检(Power On Self-Test,POST)之后,从软盘或硬盘的固定位置装载一小段代码,这段代码一般称为“引导装载器”。然后,由引导装载器负责装入操作系统内核镜像文件并将控制权交给操作系统进行进一步的初始化和运行

2、操作系统引导装载器非常小,一般只有几百个字节,而操作系统庞大而复杂,上述分成两阶段的引导过程,可将计算机中的固化软件保持得足够小,同时也便于实现对不同操作系统的引导。,Linux0.01内核镜像文件,由build.c程序生成写入到磁盘(make disk&dd),计算机加电过程,当机算机的电源键被按下时,同这个键相联的电信号线就会送出一个电信号给主板,主板将此电信号传给供电系统,供电系统开始工作,为整个系统供电,并送出一个电信号给BIOS,通知BIOS 供电系统已经准备完毕。随后BIOS 启动一个程序,进行主机自检,主机自检的主要工作是确保系统的每一个部分都得到了电源支持,内存储器、主板上的其

3、它芯片、键盘、鼠标、磁盘控制器及一些I/O 端口正常可用,此后,自检程序将控制权还给BIOS。接下来BIOS 读取BIOS 设置,得到引导驱动器的顺序,然后依次检查,直到找到可以用来引导的驱动器(或说可以用来引导的磁盘,包括软盘、硬盘、光盘等),然后调用这个驱动器上磁盘的引导扇区进行引导。,基本输入输出系统BIOS,存放在ROM中的BIOS程序执行开机是系统个部分自检,经过一系列操作之后,BIOS会将有关代码和数据存放在内存低端1MB末端的64KB处,然后跳转到这个地方让CPU进入实地址模式工作将内核文件加载到内存后,LINUX不再使用BIOS功能,因此BIOS中断向量表在引导过程中被覆盖。,

4、BIOS 将所检查磁盘的第一个扇区(512B)载入内存,放在0 x0000:0 x7c00 处,如果个扇区的最后两个字节是“55 AA”,那么这就是一个引导扇区,这个磁盘也就是一块可引导盘。通常这个大小为512B 的程序就称为引导程序(boot)。如果最后两个字节不是“55AA”,那么BIOS 就检查下一个磁盘驱动器。,BIOS 是怎么知道或说分辨哪一个磁盘可以用来引导的呢?,引导程序所具有的特点:它的大小是512B,不能多一字节也不能少一字节,因为BIOS 只读512B 到内存中去。它的结尾两字节必须是“55 AA”,这是引导扇区的标志。它总是放在磁盘的第一个扇区上(0 磁头,0 磁道,1

5、扇区),因为BIOS 只读第一个扇区。,利用BIOS 13 号中断读取磁盘扇区,AH 寄存器:存放功能号,为2 的时候,表示使用读磁盘功能DL 寄存器:存驱动器号,表示欲读哪一个驱动器CH 寄存器:存磁头号,表示欲读哪一个磁头CL 寄存器:存扇区号,表示欲读的启始扇区AL 寄存器:存计数值,表示欲读入的扇区数量在设置了这几个寄存器后,我们就可以使用 int 13 这条指令调用BIOS 13 号中断读取指定的磁盘扇区,它将磁盘扇区读入ES:BX 处,因此,在调用它之前,我们实际上还需要设置ES 与BX 寄存器,以指出数据在内存中存放的位置,0.01版内核,以软盘启动为例:1 开机2 BIOS 加

6、电自检(Power On Self Test,POST),内存地址为 0ffff:00003 将软盘第一个扇区(0头0道1扇区,也就是Boot Sector)读入内存地址 0000:7c00 处。4 检查(WORD)0000:7dfe 是否等于 0 xaa55,若不等于则转去尝试其他启动介质,如果没有其他启动介质则显示No ROM BASIC 然后死机。5 跳转到 0000:7c00 处执行 MBR 中的程序。6 MBR将自己移动到9000:00007 将内核模块从软盘读入到1000:00008 将内核模块移动到0000:00009 进入保护模式10 读取COMS信息,设置有关表格,然后调用操

7、作系统初始化程序MAIN.C1-5完全由BIOS完成,6-10由 BOOTBOOT.S HEAD.S完成其中BOOT.S的目标代码就是MBR(主引导记录Master Boot Record)中的程序,操作系统引导流程,Linux0.01系统引导过程中内核代码在内存中的位置变化,操作系统引导部分代码的分析,Boot.s的分析head.s的分析Head.s的作用 AT&T汇编语言初步,操作系统引导部分代码,0.01版源代码树中/boot文件夹中的两个汇编语言程序文件Boot.sHead.s,Boot.s的作用,引导装载器,存放在mbr中的一段程序,负责将操作系统加载到内存合适的地方,这一部分的代码

8、运行在实模式中,boot.s运行的最后将设置cr0进入保护模式,然后将接着执行head.s中的程序Boot.s采用intelx86汇编语法编写,使用8086汇编编译器as86和连接器ld86产生可执行代码。除了boot.s外,linux均使用gnu的as进行编译,这里使用8086的编译器的主要原因是当时gnu不支持生成实模式下的16位的代码程序,内核2.4.x起,这部分代码才完全使用as来编写,Boot.s源代码分析,阅读时应注意的主要重点实模式的寻址方式内核代码在内存中的位置使用bios中断访问软盘如何为进入保护模式进行初始化设置开始进入源代码世界Boot.s,head.s源代码分析,Hea

9、d.s的作用 AT&T汇编语言初步,Head.s的作用,这部分代码工作在保护模式下,主要的作用是为开启分页机制进行设置,开启分页机制后将控制权交给main.c程序进行进一步的初始化工作采用了AT&T语法的汇编语言语法编写并使用GNU的as(gas)编译器进行编译,由于这种语法和intel8086汇编不同,有必要先学习一下AT&T的汇编语法,Head.s的分析,阅读时应注意的主要重点IDT,GDT的设置如何开启分页机制分页机制的寻址方式HEAD完成后内存的布局开始进入源代码head.s,AT&T汇编语言初步,Linux中的汇编代码Linux0.01使用两种汇编器,Linux中的汇编代码,Linu

10、x中的汇编代码,Linux0.01使用两种汇编器,as86(与之配套的ld86链接器)gas(as)(与之配套的GNU ld链接器)Linus仅用as86创建16位的引导扇区程序boot.s早期的as不支持生成16位的代码,2.4版本之后已经全部改为使用as,as86,语法类似于MASM,NASM等在linux中使用as86生成引导区程序bootas86 0 a o boot.o boot.sld86 0 s o boot boot.odd if=boot of=/dev/fd0,GNU as,内核中除了boot.s外所有汇编语言程序(包括c语言产生的汇编程序)均使用gas编译。gas(现在称

11、为as),汇编器最初是专门用于汇编由gcc产生的中间汇编程序的。因此支持很多c语言特性。(编译c语言时gcc编译器会首先输出一个作为中间结果的as汇编语言文件,然后调用as汇编器进行编译),as基本命令格式,as 选项-o objfile srcfile.s比如单独编译boot/head.sas o head.o head.s,as局部符号,1:incl%eax movl%eax,0 x000000 cmpl%eax,0 x100000 je 1b,as汇编命令,.align存储对齐汇编命令,比如.align 3表示把位置计数器值增加后其最右边0的个数为3,就是把位置计数器增加到8的倍数上.b

12、yte.word 分别定义一个字节,字.fill repeat,size,value该汇编命令会产生repeat个大小为size字节的重复拷贝,value是填充的值,默认为0.guad 定义多个用逗号分开的8字节大数,as语法-AT&T 汇编格式,1.在 AT&T 汇编格式中,寄存器名要加上%作为前缀;而在 Intel 汇编格式中,寄存器名不需要加前缀。,AT&T的汇编语言语法,Intel语法 AT&T语法mov eax,8 movl$8,%eaxmov ebx,0ffffh movl$0 xffff,%ebxint 80h int$0 x80,在Intel的语法中,立即数没有前缀。但是在AT

13、&T中立即数前冠以“$”,AT&T的汇编语言语法,Intel与AT&T操作数的方向正好相反。在Intel语法中,第一个操作数是目的操作数,第二个操作数源操作数。而在AT&T中,第一个数是源操作数,第二个数是目的操作数。由此可以看出,AT&T 的语法符合人们通常的阅读习惯。Intel mov eax,ecxAT&T movl%ecx,%eax,内存单元操作数,内存操作数也有所不同。在Intel的语法中,基寄存器用“”括起来,而在AT&T中,用“()”括起来。Intel mov eax,ebx+5AT&T movl 5(%ebx),%eax,AT&T的汇编语言语法,例子,例子的解释,Linux 是

14、一个运行在保护模式下的 32 位操作系统,采用 flat memory 模式,目前最常用到的是 ELF 格式的二进制代码。一个 ELF 格式的可执行程序通常划分为如下几个部分:.text、.data 和.bss,其中.text 是只读的代码区,.data 是可读可写的数据区,而.bss 则是可读可写且没有初始化的数据区。代码区和数据区在 ELF 中统称为 section,根据实际需要你可以使用其它标准的 section,也可以添加自定义 section,但一个 ELF 可执行程序至少应该有一个.text 部分,例子的解释,上面两个汇编程序采用的语法虽然完全不同,但功能却都是调用 Linux 内核提供的 sys_write 来显示一个字符串,然后再调用 sys_exit 退出程序。Linux系统有效的系统调用列表安装在:/usr/man/man2/unistd.h/usr/include/sys/syscall.h./usr/include/asm/unistd.h,可以找到所有系统调用的定义,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号