位置: IT常识 - 正文

关于BIOS的入口地址0xFFFF0的介绍(bios设置的完整说法)

编辑:rootadmin
有网友问“BIOS程序是由0xFFFF0来执行的”该怎么理解呢?开机时内存中不是什么都没有,其实BIOS程序的入口地址恰恰就是0xFFFF0 !也就是说,BIOS程序的第一条指令就设计在这个位置上,... 17-03-25

推荐整理分享关于BIOS的入口地址0xFFFF0的介绍(bios设置的完整说法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:bios命令有哪些,bios相关知识,bios入口地址,bios相关知识,介绍bios常用的九个设置,bios入口地址,bios相关知识,关于bios设置,内容如对您有帮助,希望把文章链接给更多的朋友!

一直都说开机加电之后,将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的入口地址0xFFFF0的介绍(bios设置的完整说法)

在计算机系统运行期间,读取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就行了。如果不是我猜的那样,那回头在来补充吧。

本文链接地址:https://www.jiuchutong.com/zhishi/268067.html 转载请保留说明!

上一篇:新版Edge浏览器开启“增强文字对比度”功能(新版edge浏览器兼容ie)

下一篇:excel中在多个单元格中输入相同内容(excel中在多个单原格中输入相同数据)

  • 个人所得税申报操作流程
  • 进项发票已认证,发现发票有问题怎么办
  • 应税和课税是什么意思
  • 营改增后纳税人可以使用的发票种类有
  • 主营业务收入为什么记贷方
  • 技术服务费属于哪个商品编码
  • 小规模核定征收需要做账吗
  • 中小企业对应的是
  • 房地产企业利息资本化条件有哪些
  • 股票盈亏怎么计算app
  • 增值税月末结转摘要写什么
  • 货币的兑换是怎么决定的
  • 税费返还怎么做会计科目
  • 开出产品折扣的发票怎么入账?
  • 防伪税控技术维护费是进项还是销项
  • 附加税退税如何做账
  • 累计已确认收入极可能不会发生重大转回
  • 房产代理公司收客户钱违法
  • 最新土地增值税实施细则
  • 出纳现金日记账怎么记账
  • 支出凭证的日期
  • 个人承包集体企业违法吗
  • 国际工程物资采购网
  • 全年平均职工人数按季度平均公式
  • 返利发票税率
  • 内部调拨账务处理
  • 电子普通发票怎么开
  • 财务费用余额在借方是正数还是负数
  • 收到供应商发票分录应怎么写?
  • 收到生育津贴会计分录
  • win10电脑输入法不见了怎么恢复
  • 浅谈25年Linux内核开发经历总结出来的九条经验
  • 软件产品登记证书官费
  • codeinteger
  • Win10任务栏没有wifi图标
  • 外贸企业出口退税账务处理
  • vue3使用高德地图
  • 财政发票可以报销吗
  • 非营利组织企业所得税免税收入
  • 什么是企业最佳融资方式
  • 房产税城镇土地使用税申报期限
  • 供热企业有哪些
  • 跨域的几种方法
  • 前端手撕代码
  • 利润表所得税费用怎么算
  • 教育费附加免税需要计提吗?
  • 投资收益如何记账
  • 居间协议合同范本完整版
  • 已经红冲的发票显示正常
  • 对企业来说什么是工匠精神
  • 建筑企业小规模纳税人
  • sql2005使用
  • mysql登录报1045
  • 子公司注销母公司投资损失企业所得税
  • 我国现行资源税主要采用什么税率
  • 销售过程中发生的商业折扣计入
  • 承兑汇票的贴现利息
  • 员工用自己的钱买的材料如何做账
  • 体检收据可以入档案吗
  • 发票 发票专用章
  • 企业经营规模小的原因
  • mysql5.6怎么用
  • sqlserver表死锁
  • mac怎么保存网页到桌面
  • linux中w命令详解
  • 在Windows Server 2012中,管理员默认的用户名是
  • adsl怎么设置上网
  • win8.1新建桌面
  • windows重大更新
  • 在指定目录查找的文件
  • ssm vue
  • android shareuid
  • js当前时间格式化
  • jQuery插件封装时如要实现链式编程,需要
  • wxpython中Textctrl回车事件无效的解决方法
  • python如何用pi
  • 深圳国税电子税务局网上办税服务厅
  • 安徽省电子税务局app
  • 地税公职律师招聘
  • 关于企业所得税的说法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设