我所知道的EC====>Battery
7 R: X- Z* j. I6 q3 s9 [* J) X; t* P& L1 N6 H D( B8 H @ Z
1 Q4 q$ `" ?, s: t1.Battery Information: L5 {5 ^* i1 g, Z: D2 m
8 ?, D! V" \% k. E
6 g. V- U h; c9 @0 ]7 | }) c# U( y) e) I& r
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。
/ C+ j: {& z: ~' z3 G7 D- M2 [7 E; U2 P- ~
: {. [5 L w6 ^5 p# q1 d
2.Battery Charge&Discharge Algorithm & i# v; Z- [/ w
0 e1 a. P) R9 O+ q. [0 c# w# l6 a! b7 o9 A7 }* T: R
1)Charge
2 d% Z9 |: ~2 w- E) K" y 充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
% ~& p7 f3 l% Y5 E2)Discharge * g* R" Z& F& K9 n& T
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。
. l" e% x$ ^2 V5 s7 N
d% s( K! z" `% r/ R' _) d G l; P, ]$ V2 O
: w6 E8 e) y u, K. I3.LowLed Policy0 ]6 Y! {# E" c
1 W5 `0 G) ~! K' E Q
' m: E4 P' z$ S3 v5 K& y
) I* j7 ~: S% |' y; q9 B6 v 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 ! @: |* M. n+ V; T; m) U: L/ @
; ~) [8 l' B) k% Q) |7 r+ ~7 l
& H3 h7 \1 u6 q4.Battery Event
7 F$ C# h" K" w# s
, L5 r" p2 C) W8 c; } Q6 c4 {& c9 V
6 {& |4 ^/ I4 r" l4 I& n1 ]- {; x4 s
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
: x' @% s" G% w9 `5 r: N. C2 s1 Z( @# l& S. _
1)BattChgEvent & J' M' i* h4 d, }, ?. S0 C
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。 8 A8 |4 d4 Y8 `
( H) G% `6 y& i1 [! Z- {2)BattWarnEvent ) W: I( a" ~, z5 e% Q
当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。
" ?# }2 h/ c+ Z, ]$ \! Z8 }( H) `; v5 H5 J9 o! E/ M
3)BattLowEvent 4 ]. i e [* e0 L; a+ K% ^
当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
$ ~% y9 d, p: r2 A0 ~% y* i4)BattCrtEvent
0 d+ i T2 o; S, A( T) C6 H' B0 \ 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还- P! @ \7 c5 c9 n4 C5 O, a
没有shutdown,那么EC将会Emergency Shutdown。+ P Y+ \5 ? _& n$ k0 {" j
9 ^$ Q+ @7 w b9 ?
0 e% c: ]( I9 D$ Z3 b
- e" f0 ^! Q% X% a4 J0 r; [ L# \ 8 M% a6 ^) l# S J
& j# \4 N) C, Y& g
* Z2 v3 ?6 ]3 N+ L: L. n! c
5.How to Debug Battery?
) Y3 t. r+ m" _0 G8 o( W
, y; t* X& O) x: U
1 f4 M5 y l: ?6 k8 _; n
j! Y" M+ b7 u1 M EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。 8 a) }: @0 l' @( V4 _
" _ V7 W% o4 f% c) `
# H- t! P6 }" q# r7 q3 iPeter |