|
|
|
--易祝兵 8 o, ]3 T( f/ o
你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览
( |7 w2 m. m8 @, v4 j/ U3 A
5 E- ~7 g `, ^. ?2 D% ?。3 B4 {0 D! q+ `" p3 H3 s
8 Z6 N9 |9 o5 n$ C
前提:ACPI BIOS ACPI OS,Support S3.* P$ A+ G9 Y8 A4 z- S i* j
1 ~( p. X0 j: D% L
首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。9 v" e. o. R, i2 c4 K+ q L
, G6 N6 E" B& w
我们再细讲S3的每个步骤:
" ~: s# `5 v& D
7 f) q2 g7 g5 e; L w) |1 ?0 yHW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。
' b1 V) o1 X* R2 A
) W ~2 ]' c, Z' ?; m0 I再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)
4 O4 I" R5 S1 g( ^! D如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.4 f G8 t O2 c7 E8 ~2 L& z
4 s. U, i# i- 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。
?" C9 k! o! O1 I4 d3 H9 K W4 Y6 h; { U; z2 l" G
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。# v4 R \3 i: B, f
# z e: n8 P+ x# y; z4 ~0 n8 y: x& j1 j
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.
( L' q" S0 Z4 A$ Q" P4 g6 |
2 y1 R- e# h3 R# ^0 R3 W* v% A: O至此,打完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)等方法...
+ s1 W5 R' x8 h; w6 M2 V: j9 o; e( a4 h+ A, L, G4 d4 q
就此打住,请听下回分解。
' Z7 J7 y- y9 o4 e- j# R, j5 t/ K) `2 m7 D
S3软件这部分的流程图(图片点击可放大)6 [$ t/ B2 s) Y7 ^# ]6 H9 t ~
|
|