基于STM32单片机的差分升级算法移植手册V.3
STM32+BSDiff+LZ77
更新时间:2022-03-10 版本V1.3
同步更新如下:
基于STM32单片机的差分升级(增量升级)算法V1.3移植手册: https://deioi.cn1.quickconnect.cn/ns/sharing/SyKZI
DiffIAP – STM32单片机可用的差分升级(增量升级),适用于物联网车联网IAP升级OTA升级
应用背景
随着目前物联网,车联网,智能设备的增多,需要远程升级设备程序的场景增多,以往的IAP升级和OTA升级都是整包升级,bin文件过大导致升级过程依赖通信的带
宽和延迟,差分升级(增量升级)恰好可以解决这个问题,两者各有优缺点,可以相辅相成.
差分升级介绍
差分升级又叫增量升级,
是通过差分算法将源版本与目标版本之间差异的部分提取出来制作成差分包,再经过压缩算法生成特别小的补丁包,接着不管通过什么方式(网络传输,串
口,232,485,CAN总线,USB总线等)把补丁包下载至设备的Flash存储中,然后在设备通过打补丁还原算法将差异部分在源版本上进行还原从而升级成目标版本的
过程。
差分升级方案不仅可以节省MCU内部的资源空间、还可以节省下载流程及下载和升级过程中的功耗。从另一个角度说,通过将差分部分下发到设备保证了版本
的安全性。
STM32单片机移植差分升级(增量升级)算法
本应用的底层采用开源的差分算法BsDiff和无损压缩算法LZ77,全部使用C语言编写,支持跨平台移植,接口简洁方便移植,已验证成功移植到PC端的QT平台下和
嵌入式端的STM32平台下.
PC端QT平台下测试
制作差分文件
旧文件和新文件大小为174k字节,只更改了LED灯的闪烁频率,经过差分算法后生成的补丁文件只有93个字节,补丁文件大小取决于新旧文件的差异大小(文章末尾有上位机下载连接,用户可自行测试)
1. 移植
移植需要客户自己实现底层4个接口:flash读和写,ram读和写
- flash_api.c里面的flash读和写函数,记得在flash.h里面添加所需的头文件
- flash_api.h里面的ram读和写函数,记得添加所需头文件
- flash.h里面记得添加4个接口所需头文件
2.应用
- bspatch.h里面有三个应用层函数,依次调用就可实现单片机端的差分还原算法
- 分为两种调用方式,一:不校验生成的新文件,
- 二:校验生成的新文件的CRC 一: 不校验生成的新文件二:校验生成的新文件的CRC