|
--易祝兵
& s ?* X# Y. E8 \1 x; ^3 F1 w: k你应该知道ACPI是什么东西了吧? 本小文章讲述一下软件在ACPI S3时的动作,在你看此文章之前,如果不知道这些名词。那就请close或跳到其它地方浏览% `. f1 \# D; @$ \7 Y1 G$ r
# ]" p6 a& V2 V4 I' z3 M' W" N
。- o7 n+ L; \4 U9 q R
3 @: P. p0 a9 ]% L
前提:ACPI BIOS ACPI OS,Support S3.: G# h B0 E: t, ` {3 h5 t( M {
: [9 [2 C1 k6 h首先,我们看一张S3的简图(Follow chart)(文章未尾,注册后可见 [register to see attachment])。: f+ @; t+ x& V7 Y
7 t" H9 v1 W; u1 L0 {我们再细讲S3的每个步骤:. N$ L5 g6 r) v) G" Q, P
/ g8 f! k; L$ x6 S9 U2 l$ _6 P% M- v
HW上电,BIOS跑第一条指令,最先会初始化一些CPU与Chipset必须的register。
5 O H, z b( j7 t. R' e6 q9 N/ w) Y8 v" S: z! ?- l0 z/ r/ F
再判断是否是S3返回,这个如何判断,就看BIOS的做法,也就是BIOS在前一次进入时,把进S3的标识存于何处(CMOS?ACPI IO BASE?)
" s8 p; H6 V* y2 G如果判断是S3返回,那么BIOS就去Restore在前一次save的各Device(PCI/SATA/USB/LAN/SIO/Other...)和chipset(南北桥)的register的值(见红字,绿箭头),此间是否enable acpi需看BIOS的作法.
' k! c+ h1 q' e4 t2 I- Z, U, R, @ g1 c
如果判断不是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 F& ^5 C0 D' [' L4 v
, x6 |( J0 I$ u0 g6 Q1 P; f4 o$ p
然后Boot OS,OS Boot Loader会先判断内存的使用情况(Int 15h, function 0E820h),以及读取ACPI信息为已所用,包括SMI PORT/Enable acpi command等等,然后加载OS的Image,从何处加载,这看OS Loader的做法,因为S4会把内存的Image放至何处呢?OK,先不管OS此阶段的行为。
) p: T+ b/ a& |: j e" h) Z: ~% L( h" |
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.; N3 d# z! h4 ~3 C/ m# |9 a
7 `( h% h9 Z6 \* H; T @5 G至此,打完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)等方法...
( \- o1 C+ W* s( p. w+ M
& T6 q% u: q7 J& T9 F4 b就此打住,请听下回分解。6 D6 O$ f0 k8 c# U2 u0 i5 L u/ ~
8 ]' U5 Q2 Z+ N% ^S3软件这部分的流程图(图片点击可放大)
- d S4 V4 y* W( t/ E
|
|