|
我所知道的EC====>Battery
! q$ M. }# K% b/ P
# b, D% [+ ?8 N
' \& U. i. Z' E; a9 J* X1.Battery Information" v5 L& t* d* Q9 y) b a
. O/ }& g' ]0 i4 ~; y1 W& ^
. {9 C9 {8 ~- B9 m( C; U3 A7 K- c. d# q4 M0 B
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 7 o: ~8 }2 D0 M7 R: N
# t0 k) k# R0 c" z1 h/ h e: ~) X, u0 s$ ]
2.Battery Charge&Discharge Algorithm 1 E4 R0 A- g; \8 u/ D
( \ G& M. F0 W; c/ ^. ^* p& w' S
, K' u" R% ]5 l
1)Charge 9 x" X P# K2 H- o T1 s
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。 ' l, z7 D; q7 R9 @5 u
2)Discharge
; N* F$ f; s- u! d7 r/ |) S AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 $ E9 z) C8 y" Z( h7 _: I1 d
5 [! V) \ m# J
7 B8 ]) x+ m3 C, K
; T. n6 B% Q3 P$ P1 l4 z+ ?( v8 R3.LowLed Policy- e3 E. R! c2 J, w5 L& x$ a! c
, R' Z0 i8 R V7 b2 m$ |$ p1 \' z
3 Y1 j6 [3 Z7 m3 t1 I2 W. b/ E
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 + A/ g& b& U3 N2 z
1 e* B" u7 L0 {( J0 C
; \2 y8 {4 D: Z3 r# i" p4.Battery Event. |1 ^, Q* Q: o* Q
! x7 a( k, j6 e$ q/ y7 h3 p1 F
8 m) c, r% E1 G" i- a3 s7 a) i( h* D- o) u5 h
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。 4 v" M6 W. ^# M# B, U0 F3 h2 Q
. y. y" c' u$ y* Q1)BattChgEvent
1 v# A. E+ r- u% b, I 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
& b5 r, u5 l0 y2 h! i9 L
* u4 ~6 c+ b$ @7 s) R. C/ j2)BattWarnEvent
3 `. Q/ L+ \) b( k 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 ( N, W3 y% ^8 c* \# b. u. t
, S2 _) [1 w. Q- M3)BattLowEvent ) w% P4 B# w7 j3 Y
当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
# D+ \! I3 w- Z r8 `+ O( _# s0 C4)BattCrtEvent
2 g q) h8 O f; u2 k P8 Y% D2 G6 b 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还
: M" l* d/ l4 |% G1 T5 | O没有shutdown,那么EC将会Emergency Shutdown。
7 s, ~+ \9 S, S3 _
# A* d1 |: H7 s6 ~2 d/ d" I* Q9 U0 S% i; W/ Y, g
9 ]- k8 z$ E+ m4 |
+ Q" a' Y2 A+ E- @% j6 H" Z+ \
6 u) G5 Y4 X1 [8 g" o* k, u
' J; }, n: z. g% r& _# r5.How to Debug Battery?8 `6 H* w, k/ r4 v2 D
8 \$ B2 \7 G' u, m: F9 X% j; Z+ Z) s
6 ]; X- G& K8 H* N) b: o
EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
5 I* P, a; Z) _: f* D5 C+ A7 n0 O: M3 G# w4 g6 P3 d1 v+ N1 ? d
6 M$ }* h5 B Q. \3 ^Peter |