现象:插入适配器后,系统工作一段时间后黑屏死机或插上适配器后约5秒后就黑屏死机。
原因:适配器的瞬时电压超过充电芯片bq25723的ACOV阙值导致bq25723发生ACOV,驱动代码中state.fault_acov的值会被置为1,驱动中有如下一段代码:
可以看到当 state.fault_acov=1时,val->intval没有被赋值。而这个值在power_supply_sysfs.c中会被作为数组的序数传入,因未被赋值且没有初始化,所以当传入到数组中并操作数组时,会发生内存非法操作错误,然后5秒后系统会重启,当再次启动进入kernel后若ACOV仍存在,则会导致死机。因系统没有设置开机logo,所以表现出来的现象就是“黑屏死机”。
解决:
1,根本解决:更改适配器的输入电压或更换耐压值更高的充电芯片。
2,软件优化:在代码中完善代码逻辑,当 state.fault_acov=1时给val->intval赋值,使充电芯片即使发生了ACOV也不会导致系统死机的问题。