我所知道的EC====>Battery
$ y0 o& v0 |; {% J9 }# I* f8 A3 e" D/ e) [
: L# i. e& Z9 G5 N* x
1.Battery Information
1 J8 I2 u3 ]) \ , D; j4 f' f; [" h$ G" B6 ~8 _
0 [4 J- N; O. `! t/ l
/ H, a& Y" q0 A6 t3 }' k 探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 3 y' ?! t( s* O# N: |) J0 K
2 X* i% l3 w( `% t
" s2 O, P: m! {+ {2 `2.Battery Charge&Discharge Algorithm 5 i- j% [7 |1 V/ Q% a& f: E
% ~/ L3 Q( g8 M, _
/ |$ Y9 Z+ O3 O3 A0 w5 b
1)Charge ) h) F& ^& a8 {$ X) O# k, v/ Q
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。 ( o/ F5 P, |- A. r& b
2)Discharge
u7 w6 y3 I$ P9 {, }2 g AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。
! Z& B# Y) _. K% U3 ? m3 F0 A0 N A2 \3 u9 F: q
. L5 Q% H) l) a( v
2 ]# m7 S7 @* B7 c1 B, d. B3 n% Z
3.LowLed Policy
W* V c8 j/ c# }6 V& S 2 G: [7 C; |7 E ~& \
4 _+ b+ O) n) x$ z; j
. a5 H8 k% ~6 D H
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
" G* |" ?# w5 j! i8 C( U9 p' I2 V) [
, b9 v+ p' R8 s c7 E/ X5 `
4.Battery Event
4 g1 x$ W* y3 {' F
4 T8 K: l2 g/ ^1 u% F* @/ D) K1 p
3 A# a( x/ |7 G& y4 V% r' z. V: k0 U7 }7 ~- E0 {% F
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。 8 k# S) |4 [: B( {+ J O9 A
: L0 z3 Q4 z6 p, r$ ?! V c, a
1)BattChgEvent
$ D- h# l4 ~( d 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
: N6 h0 p# X" |; u2 G0 e: n- {/ q/ v; ^2 z F! s3 }$ P
2)BattWarnEvent ( u6 j; F1 g& r
当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 , ]- ~7 {9 t: N! {
& t. b' t& n8 ` }5 S& u3)BattLowEvent
- i) L! b$ v' v- M& j7 s d 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。
& X( m+ p: R6 c) ~4)BattCrtEvent
3 W4 _& t9 A& ?0 m' j1 u1 J( W 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还0 F9 D( e+ z% ?' k8 O
没有shutdown,那么EC将会Emergency Shutdown。
. V: S) P6 [! z9 g
+ B) I0 e8 M$ y, e8 k5 Z) Q5 K T) g; E
0 j7 i, _1 H! j4 G% g. ?
" A6 J6 S, l( I d
0 a1 [& a( E# M
. [# [: ^/ }" m. A" k3 F* ?+ ^# ~5.How to Debug Battery?1 ~: R# c4 V+ a- e" \
: O0 w; l) e }1 p/ Y& ?8 m6 p2 a0 D) u" n
5 ^) Y1 j# A- ?' } EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
8 ~3 \3 k$ ?! `, Q. I% }% a
/ Z4 m& y& s4 Q* }! p' l5 Z, q8 B 6 D* P6 r* f% X; l
Peter |