现象
采集终端ota后发现版本号不对(版本号应变成v1.2.0)
排查过程
此问题是技术支持同事在客户现场安装时发现的,需要尽快解决;采集终端与智慧屏通过蓝牙连接通信,智慧屏将采集终端固件发送给采集终端。问题要不是智慧屏蓝牙程序问题,要不是采集终端程序问题。
将智慧屏蓝牙程序回退到之前的版本,采集终端ota成功,是哪的问题一目了然。只有方向也不行,还需要知道具体是哪里的问题。
智慧屏和采集终端是通过蓝牙进行数据交互的,数据交互靠自定义协议实现。ota功能实现靠自定义协议中的几条。协议格式:数据域+校验域
在程序中加入调试打印信息,分析打印信息,发现通信过程中没有丢包,每包数据校验都通过,但是最后对整个bin文件校验(采集终端校验的数据)与智慧屏对整个bin文件校验两者校验结果不同。
谁校验的不对呢?于是通过crc32在线校验工具,对整个bin文件校验,校验结果是bcbd09e1。智慧屏对整个bin文件校验正确,采集终端校验不对。
既然知道是采集终端校验bin文件数据不对,就看看采集终端是如何校验bin文件的。整个bin文件需要分包传输,采集终端是分包循环校验的,所有包下发完后,才能计算出校验结果。
将每包原始数据打印出来(有bin文件数据,有每包校验数据)。若有ota升级成功时打印信息,与ota失败时打印信息一对比,哪里的问题,清清楚楚了。
经对比发现,是分包传输时bin文件数据错了,第13包填充的bin文件数据错了,导致后面对bin文件循环校验时校验结果就不对了。
结论
不是采集终端固件的问题;看看智慧屏蓝牙程序如何将bin文件分包下发的;
标签:bin,文件,排查,ota,校验,采集,终端 From: https://www.cnblogs.com/chino-ll/p/18208605