找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 19194|回复: 0

[原创]Tracking ACPI/ASL Using WinDbg

[复制链接]
发表于 2009-5-14 16:01:19 | 显示全部楼层 |阅读模式
Tracking ACPI/ASL Using WinDbg
% h* `( u' _8 E$ [3 g( Y3 s

$ Z+ s/ l" B% U- Q$ P1. Preface' X- |$ }2 L( ?& t
+ f4 c* H: u7 M* F* k6 A% k7 d
ACPI
BIOSOS之间沟通的主要手段,所以有些系统相关的问题,都跟ACPI asl code有很大的关系,如果能够直Debug ACPI asl code那将会对解决这类问题提供很好的帮助。这篇文章的目的就是讲解如何使用WinDbg实现ACPI/ASL code源码级别的调试。
( Z6 p7 ?0 ?9 H: A  w

+ Y8 o  ]% k) N; Q1 y; D% [2. Configuration of Debugger & Debuggee
5 G* @/ _; z" U# i( e6 _

$ x7 K: I  g9 i  q" x* qDebug ACPI
最好是双机调试,一台主机Debugger和一台目标机器DebuggeeWinDbg支援COM1394USB2.0三种不同的连接方式。它们的配置方法都大同小异,我使用的1394,所以我将介绍1394的配置方式。
6 q& Z- \' S/ s1 f" G* T9 s- O
a)设置Debuggee为调试模式5 J/ x, l1 E; r/ C2 n
启动Debuggee进入OS,点击开始菜单选择运行,然后输入msconfig然后选择BOOT.INIèAdvanced Optionsè/DEBUG剩下的具体方式如下图1所示,其中/CHANEL选择可以随便指定,但是要和Debugger端设置的要一致。. l  n# U4 `; y+ ?! A

2 i# a) j3 h1 T6 Q! |/ `+ |* g! z

6 U( Q" Y& e6 ^& o1 }( R/ R1
8 k* Y1 ?. ?' j: q- G, l9 g: }. @$ J' Y! Z4 h8 p" [
b)安装设置WinDbg3 N, W) }/ u. s' a
5 }; D. g/ Q4 @" k, B, K
WinDbg是微软提供的免费的Debug工具(微软还是不错的J,它非常强大,可以调试各种程序包括ACPIDriverAP而且它甚至可以用于Windows OS Kernel Debug,据说微软自己也使用该程式辅助开发他们的OS, WinDbg在微软网站上有免费下载。如果你在别的机器上已经安装好了WinDbg,那么可以直接copy过来就能使用了。
5 j) ]0 t( g( r, c4 j6 e1 B3 W" W
0 b! h8 `& \$ b3 Z
c)安装Symbol File; T2 @, p! |7 R
. f; K- n; y& a# o  H/ I$ {
什么是symbol文件呢?Symbol文件包含了被调试程序的变量名称,函数名,入口地址以及代码行号等信息。通常以pdb为扩展名。为了能调试debuggeedebugger端使用的Symbol文件一定要和目标机上安装的操作系统的版本要一致。Symbol文件对于WinDbg来说是至关重要的,如果找不到正确的Symbol文件,调试功能就没法使用。安装完Symbol以后Ctrl + S设置WinDbg Symbol路径例如SRV*C:\Symbols*C:\WINNT\Symbols*http://msdl.microsoft.com/download/symbols。最好把微软的Symbols 服务器也写上这样比较保险。WindowsSymbol文件可以在微软网站上免费下载) @, A# G2 M7 V4 Z
5 A" h/ n2 R* R7 X' U
d)安装Checked Acpi.sys0 R, I, Y0 k- t. d

& u. S3 U: k, b- w1 k# _BIOS中的ASL code通过asl.exe这个程序转化为aml文件,进入OS以后,OS通过两个inboxdriver Acpi.sys Smbios.sys解释和执行aml code。而且微软还提供了一个调试工具专门用于调试aml code,它就是Microsoft AMLI Debugger。这个Debugger需要两部分配合才能工作,一部分内建于WinDbg,另一部分则需要Checked Acpi.sys。所以如果要调试ACPI asl code,就必须要安装checked Acpi.sysSymbol文件一样Checked Acpi.sys一定要和目标机安装的操作系统版本要一致。替换debuggeesystem32\drivers下的 Acpi.sys,一定要进入安全模式,如果不仅安全模式你会很惨哦J3 v4 x% W; q" ?! e

5 _" _) s9 h" Oe)Start Kernel Debug 5 T% H+ k# z2 {
打开WinDbg选择FileèKernel Debugè1394(channel 1)èOK- w$ h& r6 N7 V0 q" s" ~, {% P3 r& X
如下图2所示:
, R! M1 s$ p5 N. ^' {2 T: ^0 D  N+ }6 n; |

1 j: P4 Y& W0 v' z' W- S" e
) z7 Y% q, d9 b6 K
: X. X4 d* F1 e4 \! y: n
2

& N8 F$ F/ }8 i: R  V接下来的动作就是Ctrl+Break,断下DebuggeeOS,然后就会出现如下图3所示的界面,这时就可以开始下断点,跟踪
程式,查看程式的上下文,查看寄存器的值等等。想干嘛,随你的便J!

' M7 c, i' ^" z6 ~9 C9 V  f: O
3
; [5 \5 ~" j: _
: F+ V$ |% _9 {8 T: \( s
, Q2 ]- A1 v$ r3 B1 T3.Let’s Begin Fighting It! B* r. Y3 {7 W7 t
/ J" ]7 e( M) E' H3 G1 c; X
空谈误国,实战兴邦。罗嗦了这么多废话,现在要开始行动了。首先我们要先输入!amli debugger 启动amli调试器,第一次可能会失败,报下述错误:AMLI_DBGERR: failed to get debugger flag address。这个错误的原因可能是:
4 o6 m+ p  R! D
1.Checked Acpi.sysAcpi.pdb文件和debuggee版本不符导致的。
8 L% {3 D$ K: k2 F. k+ ]2.WinDbg没有load Acpi符号文件,只要.reload即可。下面我将给出几个小的sample,演示如何debug asl code. V: ~, N+ m; m) b

. A8 g& p& `% M2 z3 Ua)Dump Acpi namespace device objects4 S! m/ P( z+ ?1 n6 S% z

( }6 t% r5 h# w# _- W输入!amli dns /s \_sb.pci0.sbrg.ec 在我的调试环境下将会出现下述内如图4所示,\_sb.pci0.sbrg.ec这是Acpi device
2 {! Y+ V) S( H2 y7 cObject 路径,每个bios的实现可能不同,这里是我的debuggeeEC这个device的路径。嘿嘿怎么样,EC的秘密一览无余了吧。
* t# R, b! @, K# d& L* d* V7 f5 c5 Q5 p- R
8 J3 y6 y. Y8 J( r6 v
7 Y3 w; p5 n# `" A) {. z5 n8 i
4
) B! w9 ?; C8 Q/ u( t, s$ j; k
b)Set breakpoints in Acpi method7 u) h- y" S6 o$ q
) c% B! ?5 B( R% c$ i$ q
输入!amli debugger ègo,然后一旦aml被解释WinDbg就会被断下,这时我们再输入!amli bp\_sb.pci0.sbrg.ec.bat1. _staègo这时我们就在battery _sta这个method下了个断点,一旦该methodcall,那么我们就会hit the breakpoint。那么该方法什么时候会被call呢?Acpi spec有如下描述:* E. q: m: u- b% u) k9 v; z
; I+ `& W' S5 O# T
, v4 M+ [- t$ x' ~( Y8 r
  [# R5 \* S# n) F
5
1 h7 \7 T( K6 t  |$ c8 C
也就是说一旦有device插拔动作该method就会被call,那么我们拔掉battery试试看会怎么样呢?下图6给出了答案,我们的断点被hit了。* A+ S& D0 F% Y: T5 Z% [
, K& x0 e; a4 B* L4 A( [

: Q& p1 m! K2 R  `3 v2 f
: e' C0 s4 p7 ^) K1 H
6

' c9 @. b3 p/ ]3 }, T被断下以后我们可以在WinDbg查看各种信息,例如使用r检查上下文信息,ln列出breakpoints最近的methodp单步查看各个参数的值等等,help yourselfJ
+ Y9 A. ?% ?9 z& [: I* z/ C# a! A* @' C3 s2 p. f
c)Tracking processes of S3/4/5
' }, H5 y0 H: Y* l. D; l& x
- P" z) f, B0 P* S9 |8 U5 Y我一直不清楚当osS3/4/5的时候流程是怎样?会执行哪些 asl code而且我们又时不时的会碰到与之相关的问题,烦不胜烦。怎么办呢?Let’s scratch it。输入!amli debugger ègo,下来输入 set verboseon èset traceonègo,然后我们选择让debuggee 关机进入S5WinDbg将会出现下图7类似的输出。这些就是下S5 Acpi asl code的完整process。我们发现OS先会去获得一些AC,BAT,LID等设备的信息,然后会call\_PTS(0x5) method 0x5就表示S5S5追过了,S3/S4那就如法炮制。
# z, ]( X/ {$ o1 {9 A/ T% V' _
6 ^" ?1 w( p  _( D- [  ]* ^, U

" r4 W  V5 L$ C& C6 @. x

+ [4 Z" q* f" d8 V- Y
" P' I6 |; K2 k7

1 `. E+ K# s( M9 \! lREFF:5 U& Z& C' r1 R8 E4 Q: f3 B
. m% B9 C0 ]* u$ z/ C
1.如何跟踪ACPI代码1 k+ e8 ]8 m/ H( w  `$ d: f
2.如何使用WinDbg跟踪调试ASL/ACPI
7 h1 ]2 x' {5 S5 G. @5 N3 n: G
# H! E; x" h9 jPeter

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?加入计匠网

×
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2026-4-24 22:37 , Processed in 0.058014 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表