问题:“当我们按下电源开关时,电源开始供电,芯片组撤去RESET信号,CPU马上就从地址FFFF0H处开始执行指令,这个地址在系统BIOS的地址范围内,无论是Award BIOS还是AMI BIOS,放在这里的只是一条跳转指令,跳到系统BIOS中真正的启动代码处。”

我想知道这个地址(FFFF0H)是内存的地址 还是主板BIOS地址?
我自己是这样想的:
1、系统硬件(系统bios、显卡bios、内存.....)的编址是把他们放在一起统一分配地址(即一个占用一段)?
2、还是 只给内存编址了 而其他硬件在内存地址中相应占据一段范围?
还是其他方式 ?这些地址是怎么个关系?

还有 如果不插内存 或是内存坏了 还能找到上边的那个地址吗?

回答:

0~640KB 基本内存
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(rong:全局描述符表、中断描述符表)将更改段选择子的字段,此时地址转换就不是 段地址左移4位 + 偏移地址,而是CS的Base字段+偏移地址。

下面是一个例子:

当系统加电后,系统会复位。此时在386以前的系统下CS=F000H,IP=FFF0H,Bios地址为段地址左移4位 + 偏移地址挤即 F0000H + FFF0H = FFFF0H。
在386以前系统可寻址范围为1MB,即 00000H~FFFFFH。
在386下CS=F000H,IP=FFF0H,这是不变的,但是这时,CS中的内容为:
Selector = F000H (这个就是你可以看到的那部分内容)。
这时隐藏的部分(注1)是不能用的,因为在实地址模式下,所以Bios地址与386以前的地址一样,但是386可寻址范围为4GB 即 00000000H~FFFFFFFFH,如果以这个地址(000FFFF0H)作为Bios地址的话,系统内存不连续,因此,386使用硬件置1的方式将A20~A31地址线置1,就变成FFFFFFF0H,并以此作为Bios地址。

这个置1的结果是,隐藏的部分的一个字段Base=FFFF0000H(rong:F000H左移4位F0000H,然后A20~A31置1。),这个操作不是由更改描述符表实现的,因为还没有进入保护模式,而且描述符表还没有建立。这是硬件实现的,而且当进行一次段间跳转后,由于置1的结果就不能保存,因为硬件设计是从会将其置0,所以当执行完FFFFFFF0H处的指令 jmp ,Base=00000000H,这时,Bios就使用1M以下内存。

注1

============================

段寄存器分为可见部分与不可见部分:可见部分就是那个16位的寄存器,而不可见部分包括基址、限长、属性等关键字段。
跨段寻址是根据段寄存器的不可见部分计算的。

实模式下:
给一个段寄存器赋值时,
对于不可见部分的基址字段,设为那个16位段地址左移4位的值。
对于不可见部分的限长字段,设为FFFF。
对于不可见部分的属性字段,根据寄存器的不同(CS/SS/DS/ES/FS/GS)设置不同的属性。
保护模式下:
给一个段寄存器赋值时,用该选择子对应的描述符给于不可见部分赋值。

这样做的好处:
寻址部件不需要考虑实模式/保护模式区别,直接可以从不可见部分得到关键数据,同时还可以提高效率。
在CPU复位时,它是直接初始化段寄存器的不可见部分的。

BIOS入口地址:FFFF:0000是指什么意思?在物理上是指内存条的什么位置?相关推荐

  1. 关于BIOS的入口地址0xFFFF0

    转自:关于BIOS的入口地址0xFFFF0 一直都说开机加电之后,将CS设置为0xFFFF,IP设置为0x0000,这样组成的地址就是0xFFFF0,而这个就是BIOS的入口地址,之后CPU读取这个地 ...

  2. 宝塔php7.1地址在哪里,宝塔Linux面板安全入口地址忘了(方法一)

    现在新安装的宝塔 Linux 面板时都会开启安全入口登录,获得的面板登录地址都会带有一个随机 8 位字符,如http://服务器 IP:8888/abcd1234. 这 8 位字符是可以在面板设置中修 ...

  3. linux 内核入口地址,linux内核的加载地址和入口地址

    编译完内核之后,会产生zImage,而把它直接导入0x30008000,会出现Bad Magic Number. 查明是需要将内核加一个0x40大小的头,由mkimage工具来添加.mkimage在编 ...

  4. 汇编语言上机考试三星题——根据键盘输入调用子程序显示子程序的入口地址

    在多模块设计中,主模块中调用内部模块buf1,buf2,buf3,buf4.主模块根据键盘输入的指令(如:a,b,c,d)调用上述对应的子程序,每个子程序的任务是显示其入口地址.调用后继续等待调用,若 ...

  5. 微信公众平台测试号登录入口地址

    微信公众平台测试号登录入口地址,使用测试号除了没有支付权限外,其他权限全部都有,用起来非常方便 http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?ac ...

  6. linux怎么找宝塔地址,宝塔Linux面板安全入口地址忘了(方法一)

    现在新安装的宝塔 Linux 面板时都会开启安全入口登录,获得的面板登录地址都会带有一个随机 8 位字符,如http://服务器 IP:8888/abcd1234. 这 8 位字符是可以在面板设置中修 ...

  7. 搜索引擎网站提交入口地址

    搜索引擎网站提交入口         对于给位新建站的朋友来说,搜索引擎的收录显得尤为重要.目前国内用户几乎都是通过百度谷歌搜搜等搜索引擎的进入网站,为使搜索引擎快速收录自己的网站,我们可以自己向搜索 ...

  8. 【exe加壳:修改可执行文件的PE头,增加一节,修改程序入口地址为该节】

    一:PE中增加节 使用工具为:LordPE.010Editor.CFF.OD List item 先用 010Editor 查看节表部分是否足够长度加入新的节表目录 从图中看出,节表后面还有空余地方, ...

  9. fiq中断的入口地址_uboot中添加FIQ中断及相关问题

    本文主要说明了在uboot中添加FIQ中断时遇到的问题以及对应的解决办法. 首先交代一下项目的软硬件环境.硬件方面,使用s3c2440作为主控芯片,外接串口.网卡等设备.软件方面,主控芯片上电后运行u ...

最新文章

  1. 利用注解 + 反射消除重复代码(Java项目)
  2. Spring Boot 2.0.5 配置Druid数据库连接池
  3. react学习(22)---需要export
  4. 流媒体测试笔记记录之————阿里云监控、OBS、FFmpeg拉流和推流变化比较记录...
  5. java excel 插件开发工具_程序员常用的15 种开发者工具推荐
  6. Opencv--Mat图像基本操作
  7. 微软 Build 2020 为 WSL 带来的新消息一览:WSL2 即将到来,对 GPU 和 Linux GUI 的支持也不远了
  8. getOutputStream() has already been called for this response解释以及解决方法
  9. 一个不错的下载ABAP程序和表格的程序
  10. android 图层绘画分析,Android-绘图机制总结
  11. java String字符串拼接原理
  12. ArduinoUNO实战-第十五章-液晶LCD1602实验
  13. SpringCloud-粪发涂墙90
  14. openpyxl 获取worksheet颜色
  15. Mac单机多实例Mysql(8.0.16)主从配置
  16. 弘辽科技:什么是淘宝直通车卡位?有哪些卡位技巧?
  17. Shell编程基本指令
  18. c语言程序设计李丽娟pdf,C语言程序设计教程 教学课件 李丽娟 第5章循环结构.pdf...
  19. 一个数组中只有两个数字是出现一次, 其他所有数字都出现了两次,找出这两个数字
  20. lombok @data 忽略属性_Lombok使用指南

热门文章

  1. Python 3,一行代码处理各种时间转换,从此跟datetime,time模块说拜拜 ~ ~ 不收藏算我输!!!
  2. dedecms模板配置大概流程
  3. NETDMIS5.0笛卡尔坐标系和矢量2023
  4. 千兆12光12电工业级环网交换机24口全千兆二层网管型机架式工业以太网交换机
  5. python快速排名seo代码_python打造seo必备工具-自动查询排名
  6. 字幕滚动效果---非常酷哦
  7. Android之Manifest文件
  8. 全量发布与灰度发布(APP版本发布)
  9. 外贸收汇方式你都真的清楚了吗?外贸B2B收款结汇方法详解!
  10. html:checkbox无法uncheck