|
我所知道的EC====>Battery # W' X6 O3 ]% w, v1 {- F u, j
# P X5 v' |3 Z6 y. j5 T
2 s" {, D; X& p7 E# S
1.Battery Information
; {/ ?+ M) `" `1 P. I; P0 Z 0 B$ k* c: A& L$ I$ M' Y2 x7 |
+ c- W4 k5 S+ A2 @4 S
/ g5 j2 I# `1 s7 z2 E* T 探测Battery的信息是EC一个重要的工作,OS也要通过读取ECRAM中的内容获取电池电量、温度、电压、充、放电电流、Battery是否存在的信息。那么EC如何获得这些信息呢?Battery通常是一个smbus device所以它会接在EC的一组smbus上,而Battery的spec上会给出Battery的smbus的地址以及读取Battery信息相关的命令。EC通过向smbus上送Battery的address,cmd然后就会取得相应的信息了。
: T* E2 f5 ~9 h+ _7 }
0 F$ r: I+ q, D4 ~# m/ V
1 G# ]/ J/ I$ @' O( d% b2.Battery Charge&Discharge Algorithm , F; W% A" K9 k9 V" ~
* A0 j. X* j9 F7 l# a0 R- R: h# e
; D0 C: N1 H: v! J1 q6 o1)Charge ) G e% f2 Z+ j# ~+ {) P) r
充电的过程是这样的,AC in 的状态下Battery插入,这时EC会进入precharge mode进行小电流充电。如果precharge时间过长(通常是指超过一个小时)EC就会停止充电并且认为Battery dead,送给host一个Battery Fail的Event。在precharge mode如果充电电流增大到特定的数值后EC就会进入fastcharge mode快速充电。Battery 充满后停止充电。在这个过程中如果电池温度异常EC也会进行一些处理。这就充电的简单过程。
" d! Z: z2 |4 z7 x5 A. \2)Discharge
& F1 \! ?% I# ^ AC out & Battery in这时Battery开始放电,在放电过程中如果电量小Critical Low,系统处于S0, EC会发Critical Event给host,然后OS紧急关机。系统处S3,EC将会唤醒OS。如果电量小于BattLowLowled将会被点亮(Battery Low Policy会详述)。另外放电温度也会被检测,如果温度过高将会做降频动作等。
2 r5 D7 }) B+ Q% }5 `
; n& s' T+ q' y r0 x) ]$ }% `9 H( ]; ^$ A2 g+ H
9 ?1 q( _; Y& u; j
3.LowLed Policy
/ Y8 x1 {& S, Q0 S; b" S
6 W3 G6 }) n+ X, U. c: V! f" M7 W
( B6 ?: \: u# ^7 z+ T+ o3 g) P6 E! D" _
经常使用NB的话,大家可能会发现有一个led很有趣。插入AC充电时会看到一个黄色的led被点亮,电池没电了会看到一个红色的led亮,有时还会一闪一闪的。其实这就是EC导入的一个Function。黄色的led其实跟这个Function无关,它是充电指示灯,不过它和LowLed摆在一个位置。那么这个红色的LowLed什么时候会恒亮,什么时候会闪烁呢?当Battery的电量很低的时候也就是小于BattLow时,LowLed就会恒亮。当Battery Dead时LowLed就会闪烁,导致Battery Dead的原因有Prechage时间太长温度过高或过低。 Y& v4 F4 G* Y4 C4 q
7 O. o* y, i/ f0 U0 m G" n
' b: p/ A1 d( [6 E5 M4.Battery Event
7 q* W4 n0 i; Y, I7 W 2 E, C s, ^2 z) X
3 L Y! @3 ^. e5 `; V- {! `8 C# f. b" q5 y
Battery在充放电的过程中,因为电量、电流、温度等原因EC需要向host端发送SCI Event,用于host在特定情况下采取相应的补救措施。
+ i5 X p6 N7 C8 e# s1 K1 b$ S5 J
8 i$ ^, s6 X& W w& R2 L" w* O2 ]$ n1)BattChgEvent
( h2 V+ p4 o. ^" l6 {& y( T5 ? 当Battery插入或者拔出时EC会发送BattChgEvent通知Host,这时Host会读取ECRAM获得Battery是否存在的信息并更新系统端的显示。 9 Y0 P: l! W9 n
- G; W @2 E+ t4 L" b" S
2)BattWarnEvent ; Q( A {& k) C5 I: I [6 L
当Battery的剩余电量到达Battery Warning Level时,EC会发送BattWarnEvent通知Host,Host端收到后会给出提示信息。 ) c. I; c# y, a
. t! v' N u8 v
3)BattLowEvent
( v; S3 \5 d+ F: C 当Battery的剩余电量到达Battery Low Level时,EC会发送BattLowEvent通知Host,而且这时LowLed会恒亮。 . h; `0 U0 O6 j# D3 m" Y
4)BattCrtEvent
# z. A ]3 H& }( t 当Battery的剩余电量接近0%时,EC会发送BattCrtEvent通知Host,Host收到后做shutdown动作。如果在很长的一段时间里(几十秒),Host还) t3 ]; D Z d5 u( m% V8 K! t
没有shutdown,那么EC将会Emergency Shutdown。
3 J. o: ~! V {( K% h
2 }- y% v# i+ N' G, Z' p' ]; f6 y" Y% I9 x6 W- ]
6 A7 S% J( l. K
; o( {# \; @$ R. n- y. b4 i) V4 C5 j _# P# L- Y3 O; g8 R
) |" h$ x9 C& ]. h$ ~! `
5.How to Debug Battery?/ w5 q7 p* h0 H1 J
. y* s8 o" O. l. ?$ v+ K/ s$ H: U- B6 U) E
1 Y* A" o" h/ b! L6 \& Q. z EC通过smbus不断的获取电池信息, 所以电池信息在不断的变化之中。有些时候为了澄清问题,或者为了增加新的Function该如何Debu呢?我的做法是使用debug tool将smbus停掉,然后将一些符合条件的值通debug tool写入ECRAM中,然后验证相关的Function是否生效。另外如果是需要给BIOS发SCI Event,我会直接将Event填入SCI queue。然后驱动SCI,让SCI Event被发送出去。
) H$ e' P% H" r6 H6 E9 D" t- _$ l
5 c) w7 B y5 N4 Z4 l. v
Peter |