|
--易祝兵
" [8 S" e6 d$ d+ Q9 k. B你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览
$ Q: a% \1 P) ?& s9 |, ?. s1 U+ y4 |4 y0 g9 d# v$ E% B3 U6 N) M ?
。
6 r g) L3 r2 F# g4 E) @8 j9 {0 h) f+ J- |
前提:ACPI BIOS ACPI OS,Support S3.+ _' v" G/ G$ {. u4 c5 K* o
e; T( l6 j' L. K k5 `
首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。1 U0 k+ ~+ @- O/ W, M9 y6 P% _; E
, P6 m7 z) @7 Z7 N我们再细讲S3的每个步骤:
$ c: N( ~ k0 }+ I) C7 _' V1 e; z& ~! }
HW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。
: Y: L! a4 w, e" e8 H# D: @8 Z: n( x' \6 y
再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)* V- l7 e/ R) A0 N) j. ^6 X! X+ a
如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.
' X5 r2 O9 d \( ~- q
$ c( J3 [" `" g# y- I5 j' M如果判断不是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。: Z4 ?9 v# R! d7 o: `5 z
, w3 N$ x K% Y/ Y2 @/ P0 Z
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。
1 m% S7 P: V3 u+ @
- W3 A$ ]2 N; p) T( ^3 tOS 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.
+ I$ _$ z& h$ U9 N. h6 V$ F4 U% Z( m
至此,打完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)等方法...
3 D, l* H# R2 _: i) p B) x5 R$ p& ?& Y' y7 |5 S' J9 b, T1 s. C
就此打住,请听下回分解。* s- D) s: }* q& B7 b
! v) `/ w4 U# w y/ ]+ }% w" d8 e
S3软件这部分的流程图(图片点击可放大)
/ a' m5 G5 }/ P: U6 L( k6 ^
|
|