我所知道的EC====>Battery ( j4 x: Z d0 Y4 @8 c1 H
3 a9 k) P2 {8 G3 d
/ T2 v' c0 u- T5 u( y1.Battery Information( r# s& F+ Y! ]& c* s6 @/ r3 S
4 g4 E9 t( m, \3 h. z
# C! S& F. T; e& G2 r
]7 I' W. Q( M) p& H 探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。
' C2 l4 ^& i, T) ^
" n+ z0 ]% e$ O8 G& J9 [, D' x8 p 7 U, k `8 Z$ ?& A5 E$ u# Y
2.Battery Charge&Discharge Algorithm 7 `. K: _: J+ ~/ r
/ R& Y9 i& m( [
2 }- T* k% v* l1)Charge % M5 D4 g6 a$ o
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
+ n' ]4 i$ w+ k9 ` D2)Discharge - ], ~" }3 L: |
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 g+ F' U( P0 k
6 c0 i* M5 E$ h
0 p u! W3 M) `+ A( b0 \; h7 R9 u2 n
% W! b( g; W0 P" E1 [! H3.LowLed Policy p/ s0 ]% f- j* X" A, ?* `, @
) H/ w* K1 F4 O2 E3 i- o5 N: v( ?# n5 d1 l9 e9 w a' T0 G( L6 L
8 q% O) @ c1 j6 |- m- a
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
7 x3 L2 N* ?4 x& P
* N' H5 G: g; K: i8 i0 L D3 y$ s& ]) T T
4.Battery Event v) x5 j* _/ I: v1 |9 ]) X
3 m' {% S- E v* u# |- U* u4 L2 P$ c* `: M& ?" j& @
$ r% F# K- I, M4 I Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
+ |$ v8 v/ P% x& L4 e+ C! n
7 |, v, V, o/ B! `1)BattChgEvent
5 D5 J$ x0 N; v! k! G1 K 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。 7 h5 @6 w: t, A
* f$ R. t$ v. s3 N5 [2)BattWarnEvent ) P5 R$ p- a( p
当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 9 t/ |6 K$ a. E+ q. {
, B3 p J! j1 h6 J+ f: M
3)BattLowEvent
9 [0 Y: M4 \7 w6 @: x2 y& f 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
. u7 r4 K) C: w% o' n$ M4)BattCrtEvent ( Q! j1 s6 m& X5 t
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还
6 J2 ?3 X/ e' Q+ Z没有shutdown,那么EC将会Emergency Shutdown。1 k K/ n1 P8 I9 P
: c! _: I4 c8 d, Q2 C. ^; S2 ~6 l: x0 T% z
# I! \- k' w; V
X* N$ E' @6 R: \8 X
. ~9 f/ }) ^" l) y5 e; ]1 N9 [
# K4 ~1 v) P, i' K7 B5.How to Debug Battery?
% v& i8 F# e* }; j
( {1 u6 ?0 l: c w, M* f
( z' C- \3 @8 D6 I
; U! \0 ^, u8 H( ]+ f& {% C/ R- d EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
l/ ?, F: C! }1 f+ b1 r+ i/ U1 C) _. {( W8 k- A+ T
# w: g$ Q/ F0 I: M C9 sPeter |