|
我所知道的EC====>Battery
5 A& R! d0 i. c/ P" I1 ]# v' R3 F2 C# n7 O5 z+ k1 k
8 {0 ]- L/ Z6 D/ g7 z3 O& |5 D1.Battery Information
. E; K* ~6 C! F( n# \. y- N & j7 c1 K g' B; X& R
& E7 @, q: O6 g5 w/ z
8 i0 k9 T# Q8 M" ]3 a' ^
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 , s& B/ P+ ?. Q% m+ i4 o' P; O
! q e( a2 l E6 T5 @
7 ~( W0 j4 f( f2.Battery Charge&Discharge Algorithm 6 o9 E4 j, r# ?8 m
: l- B. s Q; t
; I% h9 q2 W% s1 r1)Charge
* f' A, W; ]2 B9 w, M 充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
2 n. Z9 j7 R' t! Z* H4 N/ I2)Discharge
% \- t9 l6 R' E: E3 w* J AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 , v6 V% L: @( y9 g/ q7 T
+ P7 p( F, _% |9 f, h4 d) f# S; _
% r+ ]/ C: V: Q, V9 M4 m7 s 2 r6 q' t. d, w4 M, y
3.LowLed Policy
2 w! K& ~5 W' G6 c0 r
9 O* v9 E3 R3 Z/ A3 q+ S/ d; T8 e* w& _$ @
$ o3 q9 F _6 Z
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 p2 S8 T0 E# G/ Z2 d7 \
1 N3 z1 O }1 G
( [3 D5 @' ~6 o$ n- i9 [8 ]& E4.Battery Event
' ?+ h/ v3 l3 e1 Q9 _- J) E
9 o' p( k6 `0 a: K) b1 }( w- q, f8 e/ }
. M3 u) B5 H, ^( A! t! V _ Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
6 b5 k) K" o: c8 U. V
/ u$ \1 y( d: c" U+ r; q; B) r
1)BattChgEvent
% U+ P% K( N( n3 t' R! ^0 n! W% O 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
( u; i6 T0 [0 U2 N" }& U. ~2 {' V0 S, ] T
2)BattWarnEvent
# D/ C- Z \% G 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 1 T" l5 a( w, q) I# v4 u$ @+ J
4 q/ L7 A4 t- A
3)BattLowEvent
0 J+ b( x$ A2 D5 r' x6 E% H 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
: Z( j# }9 O+ R4)BattCrtEvent
8 t8 K1 C+ b8 ~2 ?. x 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还: `( v/ }$ _& B2 q3 ~
没有shutdown,那么EC将会Emergency Shutdown。3 E- s6 V6 U& r6 C( P9 L
/ c" p6 i. r2 X
/ o+ K0 h' L& O& d( g- ?" |9 @ J
: f3 Y) @9 `- ~0 U0 L0 _% K
3 M; K1 I5 v ~4 ?) C" E8 l P2 F2 Q: t; W# \9 N
- ?8 G+ n6 a2 I; p5 i5.How to Debug Battery?
. u' e& w" [2 {; k2 l' a4 v
7 W0 |7 Q: i& {: [9 q, Z, g1 n0 N+ }2 I6 q! `4 V
1 o3 A# U! t% ~) D3 F) v EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。 + H" }' H4 X/ H
2 Z# G4 g" q; m3 H( j 0 @ P$ Q4 M3 _% j# W8 \4 |
Peter |