BIOS入门基础------常用定位手段

11 篇文章 66 订阅

        对于开发而言,更多的时间可能是用于调试定位问题,解决bug,实际coding的时间,也许只占了一小部分。在这里,主要说下BIOS常用的问题定位方法。

       1.串口日志:串口日志可能是所有编程语言中最基本的方法,添加调试打印信息。但是对于刚入门的BIOS工程师而言,可能会觉得有些奇怪,debug模式已经打开了,但是有些信息就是没有输出。对于AMI的code而言,想打印IPMI部分的调试信息,需要额外打开SERVER_IPMI_DEBUG_MESSAGE_SUPPORT,如果想打印USB相关的调试信息,需要额外打开USB_DEBUG_MESSAGE,需要特别注意的是,UBS的调试信息,有个TopDebugLevel和BottomDebugLevel需要设置。

    2.port 80的code:有的时候,由于环境条件的限制,可能并不能使用串口工具,就必须要用到port 80的状态码,这个方法的实质就是往IO口写值,然后通过该值判断BIOS代码是否有运行到该处,常用的函数是IoWrite8(),这个函数的实例挺多的,在这里就不详细列举了。在port 80这块,我个人比较推荐Insyde的code,它比AMI的要详细,Insyde的code一次完整的POST,port码大概是197个,而AMI的,不足50个。Insyde code中,在PostCode.h文件中,有一套非常详细的80 port码,是按照BIOS的启动阶段划分的,强烈推荐大家去看下。

  3.ITP工具:也就是Intel的蓝盒子,这个工具挺好的,就是局限性有点大,一般在实验室使用,需要搭建软件环境,需要从Intel够买工具,还要够买软件的License。除了开板、MCA问题或者其他的疑难杂症,一般不推荐使用。(现在市面上可能还有A公司的白盒子)

    关于BIOS代码调试这块,串口调试是最基本的,port 80也是很快捷的,ITP工具就更有效了,但是最核心的,还是要多看代码,看规范文档,这个是要持续一辈子的事(如果真想做好BIOS的话)。

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值