|
--易祝兵 6 a& S. Q h7 l6 L/ N" R6 r
你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览+ r5 q! I L3 D# I
7 \0 k, Y: l( a
。
5 ]1 Y; J& s0 W: ?% t5 [% G
4 \. {. I" `( M: C; e前提:ACPI BIOS ACPI OS,Support S3.
5 ]+ H i0 N! a* @0 J+ g: Q/ y9 J
1 E; Z) m0 h* r- e T: @首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。
4 y; ~, i! [" f( n' `* A! h" K+ Z! x; b* F9 o' X0 Y! x
我们再细讲S3的每个步骤:
& l6 E- i5 y/ A! W0 b4 B) H( ~# L- [5 q
HW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。) [: v) o) n! O. _$ z" h2 g
4 x) _" ]5 ]7 L" z再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)$ R8 d* b. a2 `+ C; m) R7 [
如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.
0 _2 w7 ?5 _! U- W. ^
3 r6 h+ k) w# r& R如果判断不是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。
2 v& L4 F) k6 k5 G) J! i ~3 N9 c, E) r: p6 R# T! p$ d9 g1 G4 s
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。/ U; t4 F( N. b
8 [+ q2 S4 \" W# B
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.
, J5 P5 ?7 v; p- t8 F
; Y. V" c3 }8 h/ I8 ?至此,打完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)等方法...
! k! n/ `- N8 w. }4 J* h+ S! p
0 u6 C/ E8 N% f" U& x- d8 Y就此打住,请听下回分解。
. A b9 k' s) Q7 H' b
2 {8 F Q' F2 P1 y5 B1 cS3软件这部分的流程图(图片点击可放大)
$ x( n: I! p0 V2 e8 b9 w% O- [6 U, ?
|
|