当机器Power-ON时,x86 real mode的CS:IP=0xFFFF0,指向ROM中的BIOS代码。此时RAM还未初始化,所以BIOS的首要工作是把RAM给用起来,配置RAM当然要靠Memory Controller,PC架构中一个叫“北桥”的东西来完成,北桥的学名是GMCH -- Graphic Memory Controller Hub。BIOS中的代码需要通过GMCH来检测RAM的型号及容量。这个工作只能由ROM中的BIOS来完成,因为OS此时连毛都看不到,在如此原始的环境下。BIOS把RAM给弄起来后,会把它的数据和代码加载到RAM中(因为继续在ROM中运行的话很快就会遇到困难,比如一些变量无法更改等等, 另外执行速度方面的考虑),当然还会有其他板卡上的BIOS代码被加载到RAM中去,比如Video BIOS (VBIOS)。当然系统BIOS还会在0--0x3FF这个RAM空间处建立中断向量表,等等。它也通过MCH将0xA000--0xFFFFF处的RAM设置为"Read ONLY",总之,前1MB的RAM会被分成几个区域,前640K可以看作正常RAM,后面的大约384KB被BIOS的代码及其他Option ROMS所占据。

PC BIOS的内存检测及其他之第一弹-LMLPHP
PC BIOS的内存检测及其他之第一弹-LMLPHP

DMI: Direct Media Interface used to link NB and SB on a computer motherboard.
所以如果要模拟一个pc,首先要把GMCH的东西给模拟出来,这样虚拟PC的BIOS会检测到RAM,对于虚拟化而言,故事才刚刚开始。。。。。
02-05 19:53