最近遇到一个IEEE1725的验证,
1. 电池电压低于3.0v时, 先接入Battery,再接入power,要求不能正常充电;先接入power,再接入Battery,要求不能正常充电;
2. 挡住NTC pin,要求停止充电;拔掉挡片,要求恢复充电;
看第二条;挡住NTC pin,则被认为电池不在(qcom 8909平台),这个时候,healthd的状态是COLD;temp是25°,默认值;而电池的状态则是discharging,但是看AC adapter上,有1A的电流往手机里灌;
分析,电池的状态显示有两个,一个是status,一个是是否有充电器插入;闪电图标表示有充电器插入,并非表示在充电,而status表示电池的充电状态,discharging,charging,full;电池的health状态,应该是上层显示时,来下层读取的;而是否要disable charging,我是说真正的断开电流,则需要设置;状态的改变只是被某个事件触发了,改变了状态,而起底层硬件状态则需要设置;问题恰恰出在这里;我们挡掉了NTC pin,charger芯片反馈的结果就是remove Battery,但是remove Battery之后,有没有去设置充电电流呢? 流程中是没有的
我们需要的正确行为如下:
手机待机,插着充电器,remove Battery,手机应该正常工作,线上提供工作电流,手机不重启; 挡住NTC,应停止向电池充电,线上提供电流;我使用qpnp_lbc_charger_enable接口,来使能充电,能够满足”挡住NTC,停止充电“,但是拔掉电池,则会导致机器直接掉电重启!
高通参考设计关于batt_id,如果没有电池id,检测脚是接死的。这种设计之下,拔掉电池与挡住NTC连接,两种场景下,寄存器的值是一样的,0x1208寄存器 bit0都是1。也就是说,软件无法区分电池remove与NTC disconnect。
而在0x1049中, 要么允许Battery charging,要么禁止Battery charging,由于无法分辨remove与NTC disconnect,则无法对此做设置;如强行设置,则出现电池拔掉,又强制走电池供电,系统就会掉电。