X86 结构的CPU在加电的时候,寄存器CS内的初始值为0xffff,IP寄存器中的值为0,所以CPU开始从地址0XFFFF0处开始取指令执行。
在LINUX中 运行 cat /proc/imom 可以得到如下信息:
00000000-00001fff : System RAM
00002000-00005fff : reserved
00006000-0009f7ff : System RAM
0009f800-0009ffff : reserved
000a0000-000bffff : Video RAM area
000c0000-000c7fff : Video ROM
000d0000-000d0fff : Adapter ROM
000d1000-000d3fff : pnp 00:0d
000e0000-000effff : pnp 00:0d
000f0000-000fffff : reserved
000f0000-000fffff : System ROM
00100000-7dcdffff : System RAM
00100000-00592206 : Kernel code
00592207-007a4dc7 : Kernel data
00851000-008e0f17 : Kernel bss
可见地址为0XFFFF0位于system ROM中,即BIOS中
BIOS做的工作就是检测设备,然后读取硬盘的第一个扇区(MBR)中的512个字节,拷贝到地址为0x7c00处,即system RAM中。
开始执行MBR程序,MBR代码跳转到引导程序(grub)
引导程序把内核映像(bootsect,setup,vmlinux)读入内存中,其中setup位于0x90200处,然后执行setup
setup引导linux内核vmlinux.bin