我所知道的EC====>Battery
8 ]. P) ~' T7 L! F; a- I4 [8 S7 g6 P3 V6 _# z" H( H
# {4 g0 u" W2 K: u# S1.Battery Information- s5 w/ z2 v: M2 H) D
$ ^ H7 N/ p7 c' V3 Z
/ d9 y! s: n) W1 w2 B1 @$ F
7 |9 n9 p, {7 o* b6 U# f
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 & I( ?# V f4 o; j, Z$ _
# a/ D+ d* K& a8 j
/ n" t6 ~0 [( s
2.Battery Charge&Discharge Algorithm
/ K' s3 f9 m/ s0 c; T# A( ]$ Z$ |* { 9 u5 t& y; b R& i
0 ?! `* y* r/ i7 A; u4 u) D. e) Y
1)Charge . M0 L: t3 @- J6 n
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
. v3 ~5 a' H2 S" M2)Discharge ; T! Y* _1 Y* h2 V7 G
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 : `& }1 l5 d" E' l" S
! ~! @% i3 j- m" |- \, M. y S5 g1 j# Y8 g& X& k# B
0 q# {% D5 _ c
3.LowLed Policy
5 y! f* o: \; J; w( ^7 n4 {
: v+ x7 X& s6 A' K6 J7 S0 [' ^7 \, ?/ Q5 u7 \1 i
* r1 F0 M L' t2 K8 j 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 3 F4 d# y1 P, n$ R3 ]5 f$ b4 `
, ~' V0 }, k9 r% k # U, S+ \! h* x) v: o
4.Battery Event5 t$ Q, p( c' q; S$ V
6 O5 T" I) @4 x0 j: I8 j
! O; O" q7 z2 l) q
% w: K9 N& @7 x' w& X# _0 f Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
/ ^3 a/ ~; `, e* s9 q9 m- @2 U6 v+ L% Q
1)BattChgEvent + b+ X3 Q7 [3 L0 s
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。 . N1 [. R, R1 G
& @ s8 W% ~. g. }, V$ v
2)BattWarnEvent
" O* e, }: E0 i0 y2 W/ S! }( S 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 2 Q/ k$ L( i) k2 Q7 Q( K
" ^9 T8 i5 }! [" Y7 E+ ]
3)BattLowEvent 8 t2 G. j3 d" P! a, K# e
当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
! j+ H/ d x/ R* P9 K4)BattCrtEvent Q- L# h4 x6 `, s
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还# O0 ^7 B- o+ a
没有shutdown,那么EC将会Emergency Shutdown。; |1 Z/ d# u9 @6 R, M: ~
/ {. z) p6 O' C) n# E1 n( K3 k" |2 |
. s+ S. S/ c1 [3 B" C # B% Y! w6 V z: Z* g F- t, Q
0 @7 \/ P0 M* l4 {% u
. T+ ~* L' Q( n' y3 ~ % \' C2 W' E9 v- a% k0 g
5.How to Debug Battery?5 t4 c; q2 r& w7 s, P
, K, b: ?% l( B' y3 x+ j
" z1 d. ?( T! c5 {. f5 G3 {; Z& v" p5 x. V% h: z/ x
EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。 * p8 k% z" ^" H# R$ _% W4 b& e5 `4 b
M Q5 Z. A4 E" N; O# M
, i" D# S: g; F3 `, y5 U3 h* ^Peter |