linux系统启动过程分析下资料_第1页
linux系统启动过程分析下资料_第2页
linux系统启动过程分析下资料_第3页
linux系统启动过程分析下资料_第4页
linux系统启动过程分析下资料_第5页
已阅读5页,还剩36页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

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

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

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

5、A”,这是引导扇区的标志。n它总是放在磁盘的第一个扇区上(0 磁头,0 磁道,1 扇区),因为BIOS 只读第一个扇区。利用BIOS 13 号中断读取磁盘扇区AH 寄存器:存放功能号,为2 的时候,表示使用读磁盘功能DL 寄存器:存驱动器号,表示欲读哪一个驱动器CH 寄存器:存磁头号,表示欲读哪一个磁头CL 寄存器:存扇区号,表示欲读的启始扇区AL 寄存器:存计数值,表示欲读入的扇区数量在设置了这几个寄存器后,我们就可以使用 int 13 这条指令调用BIOS 13 号中断读取指定的磁盘扇区,它将磁盘扇区读入ES:BX 处,因此,在调用它之前,我们实际上还需要设置ES 与BX 寄存器,以指出数

6、据在内存中存放的位置0.01版内核,以软盘启动为例:1 开机2 BIOS 加电自检 ( 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 将内

7、核模块移动到0000:00009 进入保护模式10 读取COMS信息,设置有关表格,然后调用操作系统初始化程序1-5完全由BIOS完成,6-10由 完成其中的目标代码就是MBR(主引导记录Master Boot Record)中的程序操作系统引导流程系统引导过程中内核代码在内存中的位置变化 操作系统引导部分代码的分析n的分析n的分析n的作用n AT&T汇编语言初步操作系统引导部分代码nboot文件夹中的两个汇编语言程序文件的作用n引导装载器,存放在mbr中的一段程序,负责将操作系统加载到内存合适的地方,这一部分的代码运行在实模式中,运行的最后将设置cr0进入保护模式,然后将接着执行中的

8、程序n采用intelx86汇编语法编写,使用8086汇编编译器as86和连接器ld86产生可执行代码。n除了外,linux均使用gnu的as进行编译,这里使用8086的编译器的主要原因是当时gnu不支持生成实模式下的16位的代码程序,内核2.4.x起,这部分代码才完全使用as来编写源代码分析n阅读时应注意的主要重点n实模式的寻址方式n内核代码在内存中的位置n使用bios中断访问软盘n如何为进入保护模式进行初始化设置n开始进入源代码世界源代码分析n的作用n AT&T汇编语言初步的作用n这部分代码工作在保护模式下,主要的作用是为开启分页机制进行设置,开启分页机制后将控制权交给程序进行进一步

9、的初始化工作n采用了AT&T语法的汇编语言语法编写并使用GNU的as(gas)编译器进行编译,由于这种语法和intel8086汇编不同,有必要先学习一下AT&T的汇编语法的分析n阅读时应注意的主要重点nIDT,GDT的设置n如何开启分页机制n分页机制的寻址方式nHEAD完成后内存的布局n开始进入源代码AT&T汇编语言初步nLinux中的汇编代码n使用两种汇编器Linux中的汇编代码Linux中的汇编代码使用两种汇编器nas86 (与之配套的ld86链接器)ngas(as) ( 与之配套的GNU ld链接器 )nLinus仅用as86创建16位的引导扇区程序n早期的asa

10、sas86n语法类似于MASM,NASM等n在linux中使用as86生成引导区程序bootGNU asn内核中除了外所有汇编语言程序(包括c语言产生的汇编程序)均使用gas编译。ngas(现在称为as),汇编器最初是专门用于汇编由gcc产生的中间汇编程序的。因此支持很多c语言特性。(编译c语言时gcc编译器会首先输出一个作为中间结果的as汇编语言文件,然后调用as汇编器进行编译)as基本命令格式nas 选项 -o objfile srcfile.sn比如单独编译as局部符号1: incl %eax movl %eax,0 x000000 cmpl %eax,0 x100000 je 1bas

11、汇编命令n.alignn存储对齐汇编命令,比如.align 3表示把位置计数器值增加后其最右边0的个数为3,就是把位置计数器增加到8的倍数上n.byte .word 分别定义一个字节,字n.fill repeat,size,valuen该汇编命令会产生repeat个大小为size字节的重复拷贝,value是填充的值,默认为0n.guad 定义多个用逗号分开的8字节大数as语法- AT&T 汇编格式n1. 在 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&T中立即数前冠以“$”AT&T的汇编语言语法nIntel与AT&T操作数的方向正好相反。在Intel语法中,第一个操作数是目的操作数,第二个操作数源操作数。而在AT&T中,第一个数是源操作数,第二个数是目的操作数。由此可以看出,AT&

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论