当你按下开机键的那一刻,在主板上提前写死的固件程序BIOS会将硬盘启动区中的512(B)的数据,原封不动地复制到内存中的0x7c00这个位置,并跳转到那个位置:
下面我们针对每一步做详细介绍.
开机后初始化指向BIOS
CPU中有一个PC寄存器,里面存储这将要执行的指令在内存中的地址,当按下开机键后,CPU就会有一个初始化PC寄存器的过程,然后CPU按照PC寄存器中的数值,去内存中对应的地址寻找这条指令,然后执行之。
初始化的值是多少呢?Intel手册规定,开机后PC寄存器要初始化为0xFFFF0,也就是说从这个内存开始,执行CPU的第一条指令。这个值其实就是intel强行规定而已。
接下来你可能有一个疑问,不是说根据这个地址值去内存中找吗?怎么现在到BIOS里了?
其实这个地方我说的并不严谨,并不是去内存(RAM)中去找,二十把0xFFFF0作为CPU的地址线信号输出出去,去这个地址线对应的位置找。
哦?难道CPU的地址线连接的不仅仅是内存?没错,CPU地址线连接的有RAM(也就是常说的内存),有ROM(也就是上图中的BIOS),还有一些外设的IO端口,叫做Memory-Mapped IO,我们暂时不会涉及,参见下图: