|
我所知道的EC====>Battery
% B8 r, O( @$ O# [% u. |" g. W9 L' R8 l, L7 t
! h& C0 y9 d: E; |1.Battery Information
; i7 _7 U- F9 h9 K w! y4 h$ D2 h4 d0 z7 S
1 A& a, }5 `( z0 P! T" W$ R/ P% @" v1 X @/ E
0 C3 m0 p& Z, a; r8 ?2 p
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 % D5 ]1 U( g6 N5 }- L( f! y( i" _
. l% A6 }: N! ]# D7 z 5 G" C/ ?/ n3 \3 Y1 z
2.Battery Charge&Discharge Algorithm * S' x! T! y2 X' p
5 L4 Z# _* w, G3 _
% z+ y% a2 w, }0 |% X0 c1)Charge
1 Z$ n2 c! @- V6 C5 Y 充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
* P' q, C: e" O* [3 f& h2)Discharge 3 ^; q/ y1 s$ ]; c
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 / l7 g- k, E x
8 f& e3 I# B5 _7 Z2 s* A% m4 w, p; C" W! w O" V' C# V
) {# m( D6 I. k& W+ |, P7 \8 `% B
3.LowLed Policy; ? o( c# j! a0 Q
' t& |: q) {9 Q8 K+ r+ d- O% d4 Y" {" W8 @0 Y6 D' j
3 m/ w7 U! {) N" l" x6 m 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
% G+ g# |1 z8 C; Q" Q+ K k# N( T
" Q f! Y2 R4 L8 E4 S ; Z$ A$ q+ z I. G% q; A1 u7 [
4.Battery Event
( ^0 {9 H* ]0 c* L
. R" B) Q; {3 j( i( s/ O7 S0 W0 c; `7 A& _' R3 g4 _7 z7 @ ^1 N" o
& [- j( Y' d2 L+ Y! n
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
5 u( l, b) _( R+ @
, [) S8 R" x7 X& J1)BattChgEvent ; }! t" i6 E* [) W9 o
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
& ~0 \, q2 M* B# X
0 j, `1 Q* C; ^% J: n3 v2)BattWarnEvent
6 Y$ x# f' w; y 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。
" ~% Q6 J+ Y! Q' d4 L: M" `+ @: ?/ |: @# X
3)BattLowEvent / G. D% @: n- n5 P
当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
5 I) R' f3 a0 Q3 a4)BattCrtEvent & O( {9 y: A. E6 R: B& {
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还
+ h# @, t6 Z. ?6 [$ l* X1 t没有shutdown,那么EC将会Emergency Shutdown。
2 G/ x. t" l5 n C9 g1 { 2 p: j$ r: v) X
& v+ p; w5 \" X8 u7 j
- b0 Z$ V( h+ H
8 [) A; t( Q$ g, j9 Z
& Q8 t& y, J1 g6 c9 |1 W: M% W |$ A1 {: w5 i; A
5.How to Debug Battery?
& `5 J: _/ G' b6 B r ) w& L! t+ B+ I i* B( R7 O
$ k% e% \ @+ i: Z: l6 L" }
I2 @! _$ h% y) F EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。 6 K3 O, O, s$ q: b$ {( }; I
3 J$ x b6 N& T
* N s" v+ g Q: O4 |3 D7 s
Peter |