1.背景知识
磁盘
linux第一个程序是写在扇区里面的,并且是一个独特的扇区,叫做MBR。
每个扇区是512字节,这是统一的标准,不管大小。
2.linux的第一个程序
linux作为由c语言和汇编语言组成程序,被编译之后是一堆的二进制代码,
这些代码程序不是放在任意地方就可以启动的。
因为硬件一启动,它不知道你的操作系统程序放在哪里
linux操作系统被编译为二进制文件之后,要从MBR开始放。
MBR:master boot record主引导记录
BootSect.S就是从MBR位置开始存放的
MBR:
0磁头0磁道1扇区(扇区编号不是从0开始的)
0X5511结尾
3.BIOS的加载过程
BOIS如何加载MBR的?
当我们开机的那一瞬间,我们程序指针指向什么地方?
我们的程序计数器(CS:IP)指向的是这个地址(0xFFFF0)
这是8086这个CPU,当然80386CPU也是一样的,
因为一开始两者一通电都处于实模式
电脑刚启动,内存中是一片空白
bios-rom是在主板上,CPU可以通过这个地址去访问主板吗
这里面有一个仲裁器的概念
当系统一启动,我的仲裁器会把这个地址映射到我的ROM里面去
CPU访问的就是bios-rom
bios-rom的程序会把自己加载到内存中
即把bios自身加载到内存中
在内存中,cpu访问速度会比较快
最开始的时候,就是直接在bios-rom中执行所有的命令
后面进行了革新,bios-rom会把自己加载到内存中
现在用的所谓叫做UEFI这样一套机制
但linu0.11是把bios-rom加载到内存中
当把自己加载到内存中,bios开始执行自己的一堆指令
包括对电脑进行一堆检测;
把各个板卡的一些bios也加载到内存中;
(bios不只是主板有,很多板卡都有,比如显卡)
4.BootSect.S执行
最左面一列是linux镜像,其顺序也是在磁盘上分布的顺序
BootSect.S主要作用就是把操作系统从硬盘里面加载到内存里面
bios只是帮你加载第一个扇区
setup.s主要作用是读取很多硬件的参数,
然后保存在内存某个地方,方便其它程序使用,
还会设置GDT一些作用;
head.s是启动操作系统的主体;
前面的bootsect.s和setup.s只是起到搬运和设置作用;
因此head.s中head是程序主体的head
BootSect.S主要是把后面的程序搬运到内存中
首先bios会把BootSect.S加载到地址0x7c00处,
然后BootSect会把自己加载到地址0x90000;
然后BootSect把2到5扇区的setup.s加载到0x90200;
再把head.s及其以后的程序搬到0x10000处,
最后跳转到setup.s程序处即0x90200处去执行setup.s