|
我所知道的EC====>Battery
* c( K1 p; s# t( P2 {6 k% N. Y b. y
% e* Z' c6 P) ^, {. ^& C; |1.Battery Information# p1 S6 ?, P2 S d7 l& u
+ D, m% d k7 Y
. Q( q( {- ~5 T, m& y
# q T" v, L1 `9 J
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。
$ f3 m( ?- y0 y/ `) w. l3 a
8 e; Y1 f' c$ d. q$ n& K9 x% y 2 W; n0 C% E# h; r. {, O0 S2 X
2.Battery Charge&Discharge Algorithm : q; N1 `- Q7 `& t
- t! L. I' g4 }' G! X& |
% T% Z9 f. n3 J
1)Charge $ U, D# T' B% W! @/ X, U' s
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
0 O y' R" @5 [2)Discharge ; {& J- W! h6 I
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 8 {9 ^- z/ R( s7 o' X
1 r g3 ?, I( Y
' X$ I$ [- a* ~( a1 Y5 r
0 r" P, x7 p M% a/ v) e
3.LowLed Policy) I4 {2 D( Y% O. m/ {( j. D: q% L$ F
& f/ i5 i% |3 B
$ }5 B J( p9 b; m5 C9 e
0 C! p4 m! z& I; F
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
- q& |# [9 k, g/ N4 U* c
1 b9 X9 F9 g& b! ~" z% w" n - V: \6 |: w$ m( @
4.Battery Event
) W+ ~) @! T" P, q$ m$ D4 ^( w # P t$ Z9 {+ B5 B! M) d7 F+ Q K
6 U& H, G( I' H( h) {
1 H0 Q2 @6 e6 S Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
( e4 k+ Q7 x- c5 b6 U0 G
% c8 \4 f5 y) v: u) c) g
1)BattChgEvent : K* G R& e8 U# s7 T' x$ g
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
7 C5 b/ @- k. \( [: T9 g
0 y( S$ y' L5 w' d0 e4 H4 L2)BattWarnEvent
; K& g7 {" S+ T) c& F: Y 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。
+ T+ R1 H6 a- g- Y' C! m4 m" M8 Y0 E: }. l6 ^6 Q1 o" m
3)BattLowEvent
4 V0 d/ s: s7 `$ y2 C: G z) ~4 b 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 : D2 G- z9 w# U, j
4)BattCrtEvent
; b: ?9 b) l& t6 w 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还0 U; L) W( N0 I0 W) |
没有shutdown,那么EC将会Emergency Shutdown。
- f& |$ [1 N) e" \
$ d& @5 m3 ]* M
4 V: P. Z! r+ v. y* M, j8 {
8 ^2 F5 E' W# W' X( R
0 ^4 Z* T: u( Z' ?' j0 m+ g
( r1 v& |: @1 {8 D* w; n 0 S9 _0 e7 l7 M( U- \4 f
5.How to Debug Battery?# @: }5 N% i9 t2 j9 b$ t2 x: ~
" E/ I) m$ L7 M# L( F- e
/ V) l, m; w6 D9 y* D
6 n& n+ ^5 a1 H( ~3 k& e: P7 b- u EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。 3 P% n4 V& L \' o! I x
: ]& C. T. s- u+ R+ V% O0 `: a
3 n, x; J$ j6 R& U9 c) MPeter |