|
--易祝兵
& ]8 F% M& e2 F) ^) K. y1 A& L4 e你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览% C4 {6 \& O! d- }, M- J
' n: v5 b$ R& C/ x' L" o* O! i z, N。
+ r: t. G) h4 @0 |! J( [! \5 I+ y7 ^
前提:ACPI BIOS ACPI OS,Support S3.
" g+ w1 K# ^( `* }* p! O1 b1 I! D D
4 G4 k2 }9 h2 Q. s. Q首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。
' N* B- b$ i9 V+ H$ X' h0 m
' G3 ]4 g) U4 X4 t* t" ]我们再细讲S3的每个步骤:' I3 x N n( {
) Q, \, J. d# D# l+ s! K" x; W! hHW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。
; F; ~4 G% H; U y4 ^5 J ~: U/ l8 c; I
再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)
+ Y1 C7 r* s) Y如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.% K; | e$ J# F$ r* h
2 _, [2 _8 ]4 M2 ^$ Q) {0 U3 X如果判断不是S3返回(也许是S4 & S5),那么BIOS跑正常流程,到Boot OS前,BIOS会做SMM的初始化动作,这个动作会初始化ACPI部分的代码(AML)和Table。同时也会初始化ACPI Enable/Disable的方法。如果BIOS声明Only support ACPI。那么BIOS会 Enable acpi,同时置SCI_EN Bit为1。如果没声明,一般是Disable ACPI,同时设SCI_EN Bit为0。
. g3 r. ~+ H: j9 C4 O% Y2 } A( {% \5 U7 k) K1 H3 G& D
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。$ e6 p( Q9 y( W* V6 k5 l9 r4 t/ V
6 ^) z- j4 E+ z/ g' a4 P; O
OS Load Some Images之后,或从S3 resume回来之前会check acpi 是否是enable,如果不是,那就要打开ACPI Enable,前面也提到,BIOS在Boot OS之前或S3 resume恢复寄存器时,都可以先Enable acpi,如果没有Enable,OS会依ACPI TABLE提供的信息,发送SMI去enable ACPI。Enable ACPI的动作比较繁多....具体见你所开发平台的Porting/Design Guide.
1 F1 Y* F6 C% D7 O, Q5 K. V8 B0 ]; @1 Y0 ~; S
至此,打完ACPI support之后,如果为Sx(ex:s2/s3/s4)返回,那么就会执行TTS,_WAK等方法,同时OS会Notify各driver和application,告诉它他,"Hi Guns, I already resume from Sx!, Wroking now,Good luck!",如果不小心死在这里...你可能会两眼泪汪汪,用windbg吧。如果从正常启动,那么可能会执行一些驱动初始化的方法,如_PDC(Processor Driver Capabilities)等方法...
0 G+ I9 e! c% }' f/ `7 Q
' y0 Q) B# s1 T# L% \" F8 e' W就此打住,请听下回分解。
" i+ j* ?& K7 C7 J3 M. r) ` d/ J9 I/ x( {
S3软件这部分的流程图(图片点击可放大)
8 w5 v$ X6 F. t9 J1 J' x0 p) g- o
|
|