|
我所知道的EC====>Battery
/ k7 |3 [& C5 G5 y! j
' ]% d u% ^, F/ ?+ N# i) W, {( [( W
" ^, e* i+ n) J. p: ]1.Battery Information6 q5 I( M" L! H7 m" R: e7 w9 w
# v/ f/ I2 V2 C8 l! S
( {' {& U4 s) B& l' ], ]8 u ?3 h4 y, ~( L: Q* {9 v. J- e
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 0 ~7 Y9 F* T, d1 R* Z' \. n% }
. n3 V6 P- t# U
5 H1 _8 P1 p7 ?$ |5 s2.Battery Charge&Discharge Algorithm 8 V; F0 b8 ^( o L) J7 O o1 ~
+ [0 T' m4 i' `" s- c h
- N# ?2 E/ r2 y7 n1)Charge 7 W% P3 i) n, ?4 L& y& B0 X
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。 ' z7 `+ a4 r$ g! c) }( h: M
2)Discharge 0 j' o, y) P; C
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。
. J# y- p, Q- W. I) u- X
" Q% h& S% j- N; r* z* I( J$ N1 v* P0 F2 p
3 _- V2 ^( X# u
3.LowLed Policy
' a% J* d% m% C3 i! E$ [- y
. M" ^5 @; |$ H0 K( S5 H9 w9 o7 D$ r# R
* f9 [% b8 T Z
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
1 l+ U# D& A' U& `" V8 p" R$ R" k3 }4 i- `# l" h
9 L3 r/ I. w% v; h6 G1 W" j4.Battery Event) c' K9 \, ? u3 t
; a/ B/ _0 ]$ [9 {3 o7 F6 D
: h+ w& {: l: `! l6 _
0 R& X9 ]3 ^2 C; { Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
. O. Z- D; {& ?) K. |
- f" S9 ~, f M/ X5 [
1)BattChgEvent
$ H; ?2 z& `% E 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
. l- l2 k2 z m1 E* a% X; @, Y9 i# ?% f- e7 X2 d9 m" ` g5 s4 w
2)BattWarnEvent
. \9 V ~! C; B 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。
* O4 i( X& a6 r, c L0 L( F$ y: f. H6 d, V7 h' }
3)BattLowEvent
/ T! x$ p1 q. I! c4 l2 q 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 7 \) s% n. H# |! R
4)BattCrtEvent
+ G7 ~4 g* E' ]$ U* W 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还, b8 y }2 @$ g9 u2 |. C- e# |! ? v
没有shutdown,那么EC将会Emergency Shutdown。& e: {. x( Q, k! w
' p, f+ u5 o& p6 A K, A
! w: A: w; z) o& | ; ~" \, i1 z) A8 l, m3 L/ r
! r& O, {% X; W$ B4 J+ H6 t$ F4 M" r! \
* w( _' d, _5 I; B! Y! C: {, q5.How to Debug Battery?& S3 ]- u' [ k9 S* k |+ G$ j2 ?
$ h6 `$ R: Z* x9 Z! f2 J6 U
7 M9 s$ ~7 P; b' w# F$ j
* v4 R2 b' q. [ EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
$ f3 O9 A! u, [0 I
2 ]) T! w1 A- D6 @( Y b+ q
0 \ c% i8 A# H) CPeter |