|
我所知道的EC====>Battery
# _* i; g; ~0 Q( V1 h" e# I, G0 F! Z* {$ K5 h3 t
& b: G c/ z$ Q9 X- l% r( k1.Battery Information: D5 C) d: v1 e7 w7 W
$ x% q$ z C1 x$ P m! o( U/ \. |
L' o$ R% x) j$ c. @! T
Q6 P) r) y" m' R 探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 " d }4 r# t/ s& w: {, r; h! C2 {% g
9 [- J) K8 u' n) e0 o
6 b* J5 e) t' A* ~3 u2.Battery Charge&Discharge Algorithm
- F" J* x+ C/ [/ H& c( A ?# `4 W 3 H3 F5 u' ]' a& X
7 d1 a2 i, \- L; I7 }) A3 s2 m1 k& m1)Charge - N' ]2 c2 c1 P
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
7 ^' F1 K) }# Y0 O! ^2)Discharge ; {- v/ x% x9 \; b( ~
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 $ @% z! m* Q6 g/ O+ W
5 B& ~7 c ~$ l6 s! m" M' R# _+ c6 R- `( Q% h
/ S+ K+ {( d/ M. E/ S
3.LowLed Policy. [3 X3 q, `/ c0 `* }
: p6 [2 d% h- h) L- I/ h5 P
: n! S/ z5 v# [/ I4 g9 \& O- e. O
8 W" @/ L; {6 q& c$ P+ P9 K# d 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
# |+ x% H; ~( K' T. J8 k. O: E6 V7 `1 G
5 q5 g1 L( v$ }4.Battery Event
) u4 o \3 X8 u0 a$ V q , h6 S; ]2 ?9 T
( Y) u1 ]9 J/ N9 k% o/ K) Q
$ I. J' U9 D! i! d x: C% C, o Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
- G; _3 U9 A( a0 T' I6 t
; A9 l) {9 T$ n8 A7 x3 A: B1)BattChgEvent & b% C4 ~0 J9 V5 g/ P2 l2 h
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
; Z, |4 u) z& F. @
g3 [/ {3 R( y2)BattWarnEvent
9 B$ K' ^7 }9 R4 B' ^) ^ 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 4 e7 k0 v0 C8 t9 s& x
T7 ~: g3 }6 d- T
3)BattLowEvent
, q& i. ]% a2 G 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 " Q% E$ [ P' G r
4)BattCrtEvent 6 W/ N8 I4 J9 z1 H3 Y
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还* q# }$ l. \- X+ U3 ?. p
没有shutdown,那么EC将会Emergency Shutdown。1 Q |# M) }2 D) D4 D
7 R+ l. q- q7 ]* U/ p9 j% _
: a7 Q) B' s+ S7 b* ?( t " G7 u. L! T+ Y; K, t8 o
: l2 l" T1 E( X3 L/ n: B0 s) X
7 [* E, H4 Z. \# J) G0 y7 Z 1 W% I( N6 k+ d: V
5.How to Debug Battery?
- ~3 P' p, Z& B) G0 o# S: X8 R: y) p
/ Q# K- x" t- p2 t0 E- O* p: w6 B- I" J& `* M3 m4 y
# B- \0 o, o4 B8 ]7 d6 m/ R
EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
5 \ G' z$ m L8 {) m5 v* j% g* b& N& V* z/ M! P
' B- {: }+ y% `5 G
Peter |