排查采集终端ota失败问题

现象

采集终端ota后发现版本号不对(版本号应变成v1.2.0)

排查过程

此问题是技术支持同事在客户现场安装时发现的,需要尽快解决;采集终端与智慧屏通过蓝牙连接通信,智慧屏将采集终端固件发送给采集终端。问题要不是智慧屏蓝牙程序问题,要不是采集终端程序问题。

将智慧屏蓝牙程序回退到之前的版本,采集终端ota成功,是哪的问题一目了然。只有方向也不行,还需要知道具体是哪里的问题。

智慧屏和采集终端是通过蓝牙进行数据交互的,数据交互靠自定义协议实现。ota功能实现靠自定义协议中的几条。协议格式:数据域+校验域

在程序中加入调试打印信息,分析打印信息,发现通信过程中没有丢包,每包数据校验都通过,但是最后对整个bin文件校验(采集终端校验的数据)与智慧屏对整个bin文件校验两者校验结果不同。

谁校验的不对呢?于是通过crc32在线校验工具,对整个bin文件校验,校验结果是bcbd09e1。智慧屏对整个bin文件校验正确,采集终端校验不对。

既然知道是采集终端校验bin文件数据不对,就看看采集终端是如何校验bin文件的。整个bin文件需要分包传输,采集终端是分包循环校验的,所有包下发完后,才能计算出校验结果。

将每包原始数据打印出来(有bin文件数据,有每包校验数据)。若有ota升级成功时打印信息,与ota失败时打印信息一对比,哪里的问题,清清楚楚了。

经对比发现,是分包传输时bin文件数据错了,第13包填充的bin文件数据错了,导致后面对bin文件循环校验时校验结果就不对了。

结论

不是采集终端固件的问题;看看智慧屏蓝牙程序如何将bin文件分包下发的;

posted @   我爱茜茜公主  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示