JEITA规范将锂电池分为cold,cool,good,warm,hot,一般划分如下:
temp < 0 ℃ :cold
0 ℃ < temp < 10 ℃ :cool
10 ℃ < temp < 45 ℃ :good
45 ℃ < temp < 55 ℃ :warm
Temp > 55 ℃ :hot
JEITA规范图如下:
手机电池正常工作在good温度区间可以达到最大的充电电流。其他区间会对充电电流以及电压进行限制,以保护电池的安全。在代码中我们可以首先在xxx.dtsi文件中,设置对应的JEITA温度对应的区间值。如:代码中的JEITA策略的设置
从上述截图设置中,我们看到在warm温度区间设置了限定电压和电流,在cool温度区间设置了充电电流。
在驱动代码中主要是通过电池的health这个变量来体现的。在设备中主要是在电池节点中health路径如下:/sys/class/power_supply/battery/health
驱动代码流程:
在BMS驱动中有获取电池health的打印,如:
BMS: monitor_soc_work: f:2,cv:0,lacc:466,eoc:0,cy:0,lsoc:16,csoc:16,v:3710,I:33,t:303,h:1,s:1,u:1
上述log中,h的值表示电池health的状态值。log从这里开始获取电池health值的
从上面的函数中可以看到,获取电池的health值,最终还是通过获取驱动中battery设备节点的health值,具体是通过power_supply框架中的POWER_SUPPLY_PROP_HEALTH的宏控调用smb23x的驱动中的对应宏控对应具体函数,来获取health值。(要注意函数调用的chip->batt_psy的对象是battery)
POWER_SUPPLY_PROP_HEALTH对应的宏在smb23x驱动文件下函数对应的如下:
在获取电池get_battery_property中的POWER_SUPPLY_PROP_HEALTH宏控
该宏控对应的调用smb23x_get_prop_batt_health函数:
该函数中,首先通过check_battery_status函数检测电池的状态,如:
在该函数中,首先获取电池的温度,如smb23x_get_prop_batt_temp函数
该函数又通过power_supply框架,返回到bms_psy中的宏POWER_SUPPLY_PROP_TEMP宏获取电池的温度。
在qpnp-vm-bms.c中的get_property属性函数中
通过get_batt_therm获取电池的当前的温度。
从上面可以看出,是通过PM8916的采集通道LR_MUX1_BATT_THERM,使用qpnp_vadc_read函数获取当前温度的。将温度返回给batt_temp。
现在回到check_battery_status函数中
通过获取过来的实时电池温度,对比在dtsi中设置的温度阈值,进行对比,从而得出电池在相应的区间值。
通过这个函数将health值返回给调用的函数。
系统层通过读取/sys/class/power_supply/battery/health节点值的向上层进行传递。
至此health值传递流程结束。而系统层的代码目录/system/core/healthd/BatteryMonitor.cpp;该文件打印的log具有kernel的等级,故在kernel log中可以看到一health开通的log,就是该文件打印出来的,如:
healthd: battery l=41 v=3812 t=35.5 h=2 st=2 usbh=0 c=-26 fc=500000 chg=u
================================================================================
而针对电池的jeita进行设置的操作如下
在驱动代码中,有个jeita温度状态的监测函数:
这个函数被放置在smb23x的probe函数中进行初始化:
并在函数reconfig_upon_unplug中进行启用:
并在smb23x_jeita_polling_wrok_fn中进行回调调用:
在该函数中:
先获取电池的温度和电量,再根据温度和电量进行做出相应的操作:
恢复启用jeita之前的状态:
进入jeita的设置:
这两个函数里,就是做一些判断和设置
至此驱动中关于JEITA的相关操作就到此结束。整个JEITA的策略伴随中充电的进程发挥作用。整个充电温升策略的设计,还需要参考电池的规格书的相关参数。