关于BIOS的入口地址0xFFFF0的介绍
发布时间:2023-05-27 21:44:13
有网友问“BIOS程序是由0xFFFF0来执行的”该怎么理解呢?开机时内存中不是什么都没有,其实BIOS程序的入口地址恰恰就是0xFFFF0 !也就是说,BIOS程序的第一条指令就设计在这个位置上,下面小编就带来关于BIOS的入口地址0xFFFF0的介绍,一起来看看吧
一直都说开机加电之后,将CS设置为0xFFFF,IP设置为0x0000,这样组成的地址就是0xFFFF0,而这个就是BIOS的入口地址,之后CPU读取这个地址的代码,然后就巴拉巴拉的开始执行下去了。
现在想知道这个地址0xFFFF0是在主板上呢,还是在内存上。想着如果是统一编址的话,就可能是去读取主板上的ROM,但是看书上的图,有像是在RAM中,如果是在 内存 中,那是什么时候,由哪段程序将ROM中的程序读取到内存中的。自己猜的话,应该这个过程是固定的硬件实现的,将ROM中的所有内容拷贝到内存中最高位那一段中,之后,0xFFFF0就必然是指内存中的地址了。
百度了一下,有篇文章就是说这个的。
640KB~1MB 上位内存(这个区域的地址分配给ROM,相应的384KB的RAM被屏蔽掉。所谓的影子内存技术,就是把ROM内容读取到对应地址的RAM中,以后系统就从RAM中读取数据,而不是从原来的ROM读取数据,从而提高速度。)
1MB~ 扩展内存
注:
Shadow RAM也称为"影子内存",是为了提高计算机系统效率而采用的一种专门技术,所使用的物理芯片仍然是CMOS DRAM(动态随机存取存储器,参阅本书后面的内容)芯片。Shadow RAM占据了系统主存的一部分地址空间。其编址范围为C0000~FFFFF,即为1MB主存中的768KB~1024KB区域。这个区域通常也称为内存 保留区,用户程序不能直接访问。Shadow RAM的功能就是是用来存放各种ROM BIOS的内容。也就是复制的ROM BIOS内容,因而又它称为ROM Shadow,这与Shadow RAM的意思一样,指得是ROM BIOS的"影子"。现在的计算机系统,只要一加电开机,BIOS信息就会被装载到Shadow RAM中的指定区域里。由于Shadow RAM的物理编址与对应的ROM相同,所以当需要访问BIOS时,只需访问Shadow RAM而不必再访问ROM,这就能大大加快计算机系统的运算时间。通常访问ROM的时间在200ns左右,访问DRAM的时间小于100ns、60ns, 甚至更短。
在计算机系统运行期间,读取BIOS中的数据或调用BIOS中的程序模块的操作将是相当频繁的,采用了Shadow RAM技术后,无疑大大提高了工作效率。
386 之前与386之后,这个地址是不同的,但都在系统内存的最高 地址段。在386下为 FFFFFFF0H。因为CS段是16位的,EIP是32位的,为了得到一个32位地址,386给CS段增加了几个字段,这是隐藏的字段,系统可以通过 GDT,IDT将更改段选择子的字段,此时地址转换就不是 段地址左移4位 + 偏移地址,而是CS的Base字段+偏移地址。
下面是一个例子
当系统加电后,系统会复位。此时在386以前的系统下CS=F000H,IP=FFF0H,Bios地址为段地址左移4位 + 偏移地址挤即 F0000H + FFF0H = FFFF0H
在386以前系统可寻址范围为1MB即 00000H~FFFFFH
在386下CS=F000H,IP=FFF0H,这是不变的,但是这时,CScs中的内容为:
Selector = F000H (这个就是你可以看到的那部分内容)
这时隐藏的部分是不能用的,因为在实地址模式下,所以Bios地址与386以前的地址一样,
但是386可寻址范围为4GB 即 00000000H~FFFFFFFFH,如果以这个地址(000FFFF0H)作为Bios地址的话,系统内存不连续,因此,386使用硬件置1的方式将A20~A31地址线置1,就变成FFFFFFF0H,并以此作为Bios地址。
这个置1的结果是,隐藏的部分的一个字段Base=FFFF0000H,这个操作不是由更改描述符表实现的,因为还没有进入保护模式,而且描述符表还没有 建立。这是硬件实现的,而且当进行一次段间跳转后,由于置1的结果就不能保存,因为硬件设计是从会将其置0,所以当执行完FFFFFFF0H处的指令 jmp ,Base=00000000H,这时,Bios就使用1M以下内存。
关于入口地址的形成,有的文章上说是CS 0xFFFF和IP 0x0000的组成,有的文章上说是 CS 0xF000 和IP 0xFFF0的组合,我猜可能是不同硬件的初始化不同,只要最后形成的入口地址是 0xFFFF0就行了。如果不是我猜的那样,那回头在来补充吧。


猜你喜欢
- 在Execl中除了可以存储数据、对比数据外,还可以利用函数进行求数据的标准差,接下来是小编为大家带来的如何用excel求标准差的教程,希望对
- 数据模型中的表格可以有多个关系。如果您特意在已经相关的表格之间创建更多关系,或者导入已经在原始数据源中定义了多个关系的表格,可能会出现这种情
- 怎么设置文件夹不能被删除?对于一些很重要的文件,为了避免出现误删等情况,有部分用户会对其进行设置,今天小编将为大家分享Win11建立不能删除
- Win10笔记本快速启动后键盘失灵怎么恢复?一Win10用户在笔记本电脑戴尔Inspiron 5437中,启动了快速启动后,发现笔记本键盘就
- ppt怎么使用SmartArt插入图片?ppt中想要插入图片,该怎么插入自己想要的图片呢?下面我们就来看看SmartArt插入图片的教程,需
- 具体操作如下: 首先插入一个不完整的圆,将其调整25%的饼图效果。如下图所示。 接着复制一份这个圆,然后在
- ehmsas.exe是微软Microsoft Windows媒体中心服务程序进程文件: ehmsas or ehmsas.exe 进程名称:
- 不同的企业就有不同的考勤规定,所以在使用钉钉考勤打卡的过程中,企业是可以自行设置考勤打卡的,如班次管理。在班次管理中,企业可以设置员工上下班
- 如果我们的电脑安装的是win10操作系统的话,有的时候可能需要我们使用快捷方式进行图片的截取。那么有的小伙伴可能就会遇到win10截图之后无
- 使用win10商店有个特殊技能要掌握起来,方便以后进行商品的购买,那就是换区操作。何为换区操作,通俗讲就是更改自己所在的地区。比如更改到美利
- Win8如何使用文件拷贝功能拷贝文件?Win8系统自带很多功能,很多用户都还不是很了解。就拿Win8自带的文件拷贝功能来说吧,大家肯定还是了
- 众所周知,Edge浏览器是Win10系统的最新的默认浏览器,而且想要更好其他浏览器作为默认浏览器,还不能直接在第三方浏览器中设置。那么Win
- 在使用文字编辑器编辑的时候,总是不清楚自己的文档是否有保存,那么如何判断文档是否保存了呢?下面与大家分享个可行的方法MAC用户在使用文字编辑
- 相信很多喜欢玩COGO的小伙伴都有听说过5E对战平台,在玩的时候也经常会使用到5E对战平台,但是在使用的时候难免会遇到CSGO端检测失败的情
- 在Excel把数据录入后,难免要把数据的值给乘起来,而一些初学者或许不知道是如何去做,下面给大家分享Excel2007计算乘法的方法,欢迎大
- 这次微软在Win10系统上对通知中心进行了大量新功能的开发,强化了Win10通知中心的作用。最新的Win10版本的通知中心与此前预览版又有变
- 12月26日消息 Windows 10的下一个大更新计划于2020年发布,将采用一种安装驱动程序的新方法。在Windows 10 Build
- 如何开具京东增值保障服务发票?京东是一个网上购物商城,用户可以在上面购买自己想要的东西。想要开具京东增值保障服务发票,但是不知道具体怎么操作
- 相信大部分用户会遇到编辑文档文件是时候,通常用户会选择使用wps这款办公软件,因为在wps软件中用户在编辑文件的类型上是没有顾虑的,也就是说
- win11用户在使用电脑的时候遇到了“无法找到脚本文件”的提示,像这种情况要怎么办呢?首先点击开始键,然后选择windows终端(管理员)打