如何判断CPU已经开始跑BIOS Code
在Debug阶段,特别是开机无显的情况下如何判断CPU是否已经开始执行BIOS code?有什么信号可以用来区隔这个点? 如果是用信号,方法之一:确认cpu reset信号发出,再拦下SPI ROM或LPC ROM上的信号,确认传过来读的地址是否有ROM的Mapping的最高端的0xFFFFFFF0地址,如果有,就开始跑了,如果没有,就没跑。 小弟愚见,查个debug不久可以知道了吗? 示波器点 LPC 的 FRAME 或者 SPI 的 MOSI。能看到init 的方波。 小弟不才在维修的角度上是,先测量PCIFRAME#LPCFRAME#LAD0-3上的波形数
然后在看SMBUS上有无波去界定
不过像档一些IIC上的代码就无法确定了
还有像IBM T40的档8785代码的安全芯片出错的代码
就无法界定了 示波器点 LPC 的 FRAME 或者 SPI 的 MOSI。能看到init 的方波。
这个INIT的方波在SPI的MOSI上能抓到? http://www.samedisk.com/cht/images/debug_viewer.gif
在我們的工具中, 首先會看到右方的第 8pin vcc 變紅
代表desktop(io)有上電源供應或notebook(ec)電池有接上
接下來如果看到左方command有03或0b變紅
就是io/南橋/ec有發出對x86讀取第一行bios
右方的位址last issued command address
可以看到現在bios讀或寫到哪個位址
會不停地跳動直到停止讀寫bios
第一行會因為架構不同而位址不同
有 xxffc0(SIS) 或 xxfff0 或者 xxff00
server BMI 或 NB EC 會從 000000 開始
因為那是8051或risc發出的
[ 本帖最后由 eject 于 2011-5-4 22:26 编辑 ] 提供一下開機的影片, 幫助大家了解bios開機的實際狀態
http://www.youtube.com/watch?v=Ituk5j8VEnI
在2:20開始
回复 6# 黑马思路 的帖子
據我了解可以量到spi read的波形先cs low -> 0x03 -> address ...
不過在power good之前或關機有可能誤發
页:
[1]