Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7115758
  • 博文数量: 3857
  • 博客积分: 6409
  • 博客等级: 准将
  • 技术积分: 15948
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-02 16:48
个人简介

迷彩 潜伏 隐蔽 伪装

文章分类

全部博文(3857)

文章存档

2017年(5)

2016年(63)

2015年(927)

2014年(677)

2013年(807)

2012年(1241)

2011年(67)

2010年(7)

2009年(36)

2008年(28)

分类: LINUX

2014-04-21 07:41:04

当机器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所占据。




DMI: Direct Media Interface used to link NB and SB on a computer motherboard.
所以如果要模拟一个pc,首先要把GMCH的东西给模拟出来,这样虚拟PC的BIOS会检测到RAM,对于虚拟化而言,故事才刚刚开始。。。。。
阅读(637) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~