|
我所知道的EC====>Battery 0 X3 q3 R. q {% ~; ^
- E4 \$ E6 P; f/ y
# R& {% e4 K2 p& K1.Battery Information$ g P1 m8 r/ B. U
' \8 M" L+ x2 a P$ _6 E8 ~# ]
0 h+ y) S$ |; P3 {2 A
. v0 b+ H% D% v 探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 4 `7 f! Z5 }$ R T; B; C% z" [6 A E' y& }
1 o2 [! c) t$ i+ Z8 D6 w: ~ , s: B5 I, {' O& B
2.Battery Charge&Discharge Algorithm 6 _5 z5 M5 i, w- a
0 B6 j) A% X$ Y( k3 y
* n$ A2 X9 j7 ~7 h) g; v1)Charge + i: R. b. s0 D9 t3 y y
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。 2 z( }6 J; p; x4 `" o8 v, K% g9 O
2)Discharge
+ K0 h( u: ~& t7 W( T. ~& f- x AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 # `, _8 b, Q5 R& n# ^" S
& c# E6 m! h4 Q' z+ |6 i0 a
- }; i5 S( ]/ I0 D4 h, C- i
/ ?5 d' X# E. F+ a$ K3.LowLed Policy
$ U7 P' p+ ?- M6 U
9 q+ ?1 [8 F8 g# z) ~, `& {
/ Z7 |0 L8 ~4 m$ M
" W2 t4 V" G$ O/ H 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 4 C: z( Q" W' p2 I5 ?7 l
9 b; s. w+ u6 f! o6 ]# S$ B
r# `! v7 U' L
4.Battery Event
, ]% O4 u- A2 t8 ?# q4 @7 Q Q& B
' F) f( J+ c6 z' |. \9 E* f: w9 Y7 F9 ?( J7 H& Q+ {
6 M* N" G4 n4 B6 m Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
, o3 M0 N/ |3 d1 r I" G. ?2 s7 l A2 c. O: [6 _
1)BattChgEvent , I. j. W4 H) `0 @$ o
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。
( ?7 \9 V: L/ d5 `3 P$ |* u2 z" y% ?8 b
2)BattWarnEvent r6 O' n' N8 {& o
当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。
$ Y" ^0 U+ f! @1 l4 y, r% {) R
3)BattLowEvent
: x4 l* }# K6 w5 V; o+ S3 H1 L 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 % G' R0 ~' L6 a, W
4)BattCrtEvent $ y# H0 w9 ]0 c) ^9 K& c' c, ?
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还
5 b% S3 |" _& f5 `没有shutdown,那么EC将会Emergency Shutdown。% u3 Y8 W% {* V! x4 o2 X& a3 _
1 c+ H) f/ R4 L6 o, Q8 S$ I k7 z) c# I( |6 @
- b3 Q: D! w& w+ B. {) v
- F) B1 ^/ Y0 T6 J+ P/ b
0 a* p5 H# k+ }/ C4 D9 N # ?! O- N0 ~: {
5.How to Debug Battery?
$ v2 u/ P. g! ~ + j5 e0 V( A6 T5 U- v# }5 z" J
/ H% K! a' w# _( h' b7 c; k8 s
- `. H2 F3 r' J2 H( } EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
! ?8 p5 O* \ q- P4 T
, m4 [2 O' Q8 O7 b( G8 e/ r+ x / y) o4 b/ X. o" H: `
Peter |