BCV和BEV是个什么鬼?

前段时间在阅读SeaBIOS(即QEMU+KVM解决方案中用到的BIOS程序)的代码遇到了BCV和BEV这两个缩写词,找了半天才搞明白是什么意思。在这里跟大家分享一下。


BCV: Boot Connection Vector,这是一个指针,该指针指向PCI设备的Option ROM内部,该指针是一个程序的入口,BIOS通过该指针入口,可进行PCI设备的初始化、检测PCI设备是否外挂了其他外设(如PCI设备可能外接了SATA硬盘)、并且hook中断13h(即跟中断13h挂钩,即中断13h发生时,就会调用到其提供的callback函数)。BCV指针位于PCI设备Option ROM的PnP Option ROM Expansion Header区域。一个典型的带有BCV的Option ROM的例子就是PnP ISA SCSI Controller。


BEV:Bootstrap Entry Vector,这也是一个指针,同样,该指针也是位于PCI设备Option ROM的PnP Option ROM Expansion Header区域,类似于BCV。只是,该指针提供的入口是为了让系统能够直接加载一个OS,即如果BIOS在找到该入口的时候,如果直接跳转过去执行,则如果一切OK的话,就能够直接加载OS了。如果加载失败的话,则会返回回来。


一般情况下,如果BIOS在获取到PCI设备的Option ROM的时候,会先检查是否有BCV,如果的话,则会先执行BCV,对PCI设备进行一定的初始化(个人猜测,BCV在执行的过程中可能还会创建BEV,还没有去验证)。


如果想要了解更详细的信息的话可以去查找BIOS Boot Specification,这个网上搜一下应该都可以找到。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值