|
我所知道的EC====>Battery
& i; ], j- L; H# J- }# y
: S6 B- ^3 o/ Z ^! W * i7 x6 G2 Y- q8 V4 Q+ U' u" {+ Y
1.Battery Information
9 f! H+ L7 h% [+ V% d
3 ~ r. X4 g, g$ B# v: ~1 s0 a$ P" U: Z" A# P- l9 X! v. }5 d
2 F3 B" e+ d7 H: P, a8 y
探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。 & ~( m! d7 H8 N( `& [
/ w% f0 h1 M2 z& @# R: t* O # S4 s3 @% n$ Z3 k4 x
2.Battery Charge&Discharge Algorithm
' ~5 E" J8 v- e1 {2 U, m, e 2 s, Q; ~1 |9 ?7 A
, J, v! n2 `6 v! S; e( }1)Charge . x; ~* y y( P# P* ]3 Q5 h6 t3 D
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。 - D/ K0 I! O ]# e3 Q+ R( H& F
2)Discharge ! F2 k# X9 e/ v! C& P: A7 F6 X+ X2 z
AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。 v0 z* N; D/ w- B1 h9 P) o
5 B: w h \' [
) O& A/ I- O. H! P
0 Q/ B& ~# F4 q8 o' n5 U3.LowLed Policy- z3 `' V9 O+ C+ _
8 x' C5 n5 P4 n* Y1 B- \. y
4 b$ i" I, z- M( U- C
; |4 |$ l. O7 x* \: i/ _$ Z 经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。
9 e$ F/ Y2 \! Y! q% ~2 ?; G
8 ]! j3 D5 p2 {
2 q$ R& K8 s! ^& c! Y1 ?4.Battery Event
" a2 X, E% T/ x1 S5 K
2 j. {. C+ Y2 U: G* i u' z2 X2 M
! Z' U/ _) ~$ L. U+ h; J/ c8 v* ?. v$ j1 r% ?3 q$ ~1 ^3 z
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。 0 g9 A+ c& m8 F# c( I
" e! p+ s) g6 G- p/ y3 d7 r
1)BattChgEvent * H2 I7 `0 B) U+ \0 v, O
当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。 : q$ m) G" g3 p& T5 K
* q; V2 L1 b" P2)BattWarnEvent
6 \. C! Y+ D) H 当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 % M' Z7 E, [/ ^- @
0 w8 H3 L e; [! _
3)BattLowEvent
0 i( U" K( o( G$ H6 I 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 . f( o* p6 x" {) ^$ Q( i; J0 a
4)BattCrtEvent 7 P8 M8 y/ k8 N5 Q: l4 k
当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还- E& b9 x- a4 K6 a2 q& i3 `2 n5 Y" z
没有shutdown,那么EC将会Emergency Shutdown。0 @8 M( a0 o$ Z, t% H
, g) g! K1 [& G: C2 B3 j
6 p0 \. i% {& h3 W( N
1 Y% B6 c2 M! E: x
" q9 T9 @; {% J1 g X$ v
+ r" }, |. k: n8 ]- l
; E$ T# E3 P( T; N: @/ L( L5.How to Debug Battery?6 f, i0 m" {+ I
# D1 s' d- o2 h! G# N
/ s* F# a' G0 V6 Y, _" N2 ]/ H/ w3 j- I3 b& t/ V$ \) h
EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
0 w" e- K8 d$ h; F( |& @" ^7 x
( e; F/ q: n8 D& t 5 \$ ~, ?8 O$ h
Peter |