|
--易祝兵 9 `; @9 U4 f4 k' B6 S: c
你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览6 j; N/ l& p. Z) {
8 p4 O2 Y/ ^: T) t8 U& c0 v
。9 ~. Q1 y; N' y, ~$ b1 _" h: f
$ S( t, a& x; F6 K& W+ L5 B I3 p
前提:ACPI BIOS ACPI OS,Support S3." a. G: i) w3 \
{7 N9 Z) d) Q
首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。
) W3 k* w) V/ ^
" y2 h2 O8 n- y. v5 Q# ^( X' z( J5 y我们再细讲S3的每个步骤:
. O u: n8 l6 B: C
7 q! {; P1 `& h) K5 T' IHW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。1 N7 i5 i0 x2 M" R
. {7 x! @3 Z* P+ _- R/ B再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)
. O0 D4 N5 E& ]5 }" |8 A$ A# Z如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.! a# |* ]' ^9 d- O. d
/ i2 S$ |4 V6 L+ ~如果判断不是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。/ i. }" I% [" m$ Y% s+ P( v
" ?; x! Q5 b1 k2 K7 V/ Q5 E然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。
( x4 Y+ a3 F! M, B- R2 x. k- j9 k% n5 \ b, H; o6 Y
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.
; X2 v* u" G* F5 P8 k8 l- D! G0 _2 K( ?1 c8 Y( u g$ E. B
至此,打完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)等方法...9 A7 r" g7 l/ a& S3 [
( \* I- ?; r7 L0 X( R9 w, t
就此打住,请听下回分解。1 S7 {# ~# d, M( {8 [0 \% u0 j
^* I( ]% a% @: H
S3软件这部分的流程图(图片点击可放大)
- M: e1 \6 n2 p, ^' y2 T/ q
|
|