声明:文章是个临时起意的小科普文,不是很严谨,建议多看文中提及的参考资料或者亲自扒Linux源码。
一、8086机器启动过程
该部分参考资料:
王爽《汇编语言》
李忠、王晓波《x86汇编语言:从实模式到保护模式》
于渊《一个操作系统的实现》
刘超《趣谈Linux操作系统》
1.1 CPU加电复位
CPU加电复位,主要是预置处理器中寄存器的初始状态。
在8086CPU中其中除了CS全部置一之外,其他的13个寄存器全部置零。这样操作的目的是为了灵活的进行jmp转移执行系统ROM(不写死,换了不同的系统或体系,只需要jmp到不同的地址即可)。
1.2 系统ROM(主板BIOS)
执行系统ROM程序的目的有三个:
- 一是硬件的自检;
- 二是初始化系统BIOS(这一部分主要是主板BIOS,除了系统BIOS之外,还有网卡和显卡的BIOS),准备好实模式中断服务;
- 三是初始化了系统BIOS之后,具备了IO能力,然后将硬盘的0面0道1扇区(即主引导扇区MBR,共512字节)加载到0x07c00处并执行主引导记录MBR。