|
|
|
--易祝兵
' X+ ?' C; L& V, D0 k# ]你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览
( T& x+ X f$ _; J2 ]; {* Z& g H* j) ]# C& F
。( \1 N% A) Z; @) J9 r& E1 h
/ ?" U+ P3 d9 h- v- t8 N4 U
前提:ACPI BIOS ACPI OS,Support S3.
3 a1 m2 Q5 `1 R1 X4 j1 o0 E1 m
& l1 U9 \4 x4 t1 c2 L: ~6 H* q* @首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。! O* j2 L, k# r+ O
; p9 X1 v* u) h
我们再细讲S3的每个步骤:, i: ~, v2 u1 `0 @& ^8 I
2 f2 ^( f S- q3 D- U, ?
HW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。) r1 l2 Y$ p4 [+ x& }0 U/ m: }. n# M
* _! v& @; G+ K7 T* q, N9 Z4 T再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)
2 s' x6 L$ A6 _如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.' L4 c) ^/ _+ V' f9 K& \
/ X2 C, D0 M1 Q0 d& o8 [! ^, I如果判断不是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。
" Y* ~3 |0 c' T9 {4 X( m, g2 w+ k/ j$ `0 p H6 i
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。
3 G3 c" L' j; b. w; M$ i3 U
4 @; d; ]6 q+ q1 Y" ROS 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.! R( p. u* B) _# w0 m6 c" a/ V
J9 o8 k& b3 V7 x/ x" 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)等方法...2 r& n( S1 y8 H+ l3 g9 g J
8 B, Y# r9 V$ @& g就此打住,请听下回分解。* ?* X4 e- l9 q4 O# b
) p) ?" i [8 c; g
S3软件这部分的流程图(图片点击可放大)
* F( A; x/ |% ~: L# e5 z
|
|