|
我所知道的EC====> ower Sequence
, F5 S8 N% P, N* W+ `- R 3 g4 c. N' g8 a
1. What’s Power Sequence ?% k' n4 m4 ~$ h0 Y9 I: q" @
Power Sequence 是指HW Device上电的顺序,它的大致顺序如下:% m6 l1 o+ y- b K& \4 ^: t
1)ALWAYS
( ]/ b+ D4 O- s1 K$ ^8 \2 M, E2)SUS_ON% d" D/ e u+ z6 [/ }8 ]) C, l
3)DIMM_ON
% f' h+ b, S% u$ v# t4)RUN_ON; K# s( [6 `9 J/ Y$ z
5)VR_ON
K$ F( y" E* x0 a 这基本上是NB工作需要的所有POWER。插入AC或者DC后,机器内部的开启的电为ALWAYS电,主要用以保证EC的正常运行;系统正常工作进入SO以后,所有的Power都开启。完整的过程其实是这样的:AC或者DC插入以后,EC Reset开始跑code,用户按下Power Switch时,EC拉SUS_ON送给一颗POWER IC,+3VSUS,+5VSUS起来后,POWER IC回EC SUS_OK。接下来EC发给南桥一个称为‘RSMRST#’的信号。这时候南桥的部分功能开始初始化并等待开机信号。这时候的南桥并没有打开全部电源,只有很少一部分的功能可用,比如供检测开机信号的PWRBTN#信号。,在用户按下Power键的时候,EC检测到一个中断,然后duplicate一个开机信号(PWRBTN#)给南桥,南桥收到PWRBTN#信号后依次拉高SLP_S5#,SLP_S4#,SLP_S3#信号,开启了所有的POWER,在V_CORE电起来后,IC会发送ALLSYSPWOK信号给EC这信号表明外围电源正常开启。南桥会发出PCI RST#信号到PCI总线,于是总线上的设备都被初始化(包括北桥),然后CPU RST#信号送出,HOST正式接手并开始工作。/至此,上电时序完成。
( A0 {& u1 [# N8 o7 O
5 U0 Z# \: W$ B! _$ E2. Why Power Sequence ?& Q1 l" G0 O4 u' _* s
3 X1 l6 F" ^6 V8 e ^' P: cI.Why need sequence?(个人猜测,欢迎指教J)/ ~8 Y7 D9 m% ?- b2 L
为什么需要Power Sequence呢?没有Power Sequence直接把所有的电压都供上可以开机吗?答案是YES。直接上电开机是没有问题的,可是没有办法达成省电的功能;另外S3/S4,Long Run也会有问题。系统计入待机的时候(S3),机器内部的电只有SUS&DIMM电,主要是提供DDR的电压,以保证RAM内部的资料不丢失(S3 是将数据Store to Ram,在Resume之后OS从RAM中获得数据,所以DDR的电一定要留着),而S4和关机(S5)的电是一样的,都是Always电(当AC在的时候其实SUS电要留着,目的是加速Resume或者Power On的速度)。
6 M* P6 Q7 V" _) j M; Y+ |: Q1 f `5 J& L0 t+ `# l& A8 @- K" }& M6 w' r
II.S4和S5共用一个信号?! {; Y9 x9 T6 |1 H
6 y. W3 J- f- s) I0 L; R, x4 p
做过EC的同志可能会发现,线路图上S4,S5的信号只会有一个。根据我们的使用经验S4和S5有很大的差异。原因其实是因为S4,S5都只有ALWAYS电,从EC的角度,根本没有必要区分S4,S5所以SB只有一个信号拉到EC。% a+ D7 v4 } \3 m
( G. F1 M$ K3 n' a0 ?& H+ A
: i: y! j2 R9 U' X$ z9 t
Peter
! Z# P: p& k& `6 s+ X! D) _! d* g/ e5 L1 d
|
|