基于BSDIFF算法固件差分升级方案

前言

随着运行时间的增加,物联网终端在使用过程中会暴露出各种问题,技术人员需要对其进行维护或升级,而终端设备逐渐小型化和空间分布广的特点使其拆卸不便,采用固件远程在线升级技术可使固件升级更加便利。

BSDIFF简介

bsdiff算法是较为成熟的增量更新算法,由于该算法生成的补丁文件较小,因此而得到广泛应用。

系统框图

Boot工作原理

不管用的是什么MCU,要实现固件升级都离不开BootLoader,BootLoader是一个统称,它是一段引导程序,在MCU启动的时候会先运行这段代码,判断是否需要升级,如果不需要升级就跳转到APP分区运行用户代码,如果需要升级则先通过一些硬件接口接收和搬运要升级的新固件,然后再跳转到APP分区运行新固件,从而实现固件升级。以下是Boot流程图:

FLash分区

采用将Flash区域划分成Boot区、Patch区、old区、new区,这种分区方式比较万能,优点是新固件存放在patch区,如果搬运过程中出现异常中断情况,也不会造成数据丢失。而缺点是需要划分单独的分区,占用较大资源变相减少了old区资源。

BootLoader制作

  1. 分区定义,先把各个分区内存起始地址和大小定义好。
  2. 程序跳转,BootLoader作为引导程序,最重要的是通过内存跳转至用户程序。
  3. 处理函数,读取patch区的升级标志位,如果需要升级则解析Patch区内容,对版本进行校验,比对旧文件的信息与差分包旧文件是否一致,计算是否能放下new文件,如果可以放下则通过差分还原算法将Patch区与old区内容进行合并写入new区。最后将old文件擦除,将合并后的文件复制到old区,最后boot跳转old起始地址开始运行升级后的程序。

APP实现原理

App区实现自己的功能,具体流程图如下

差分升级算法是用于在软件版本升级时,通过比较旧版本和新版本的差异来减少升级包的大小,从而减少下载和安装的时间和带宽消耗。bsdff和hdiff是两种常用的差分升级算法bsdff算法是一种基于二进制的差分算法,它通过将新旧版本进行二进制比较,找出它们之间的差异,并生成一个差分文件。这个差分文件中只包含了需要修改的部分内容,因此相对于整个新版本的升级包,它的大小更小。在升级时,只需将差分文件与旧版本文件进行合并,就可以得到完整的新版本文件。bsdff算法在处理二进制文件时非常高效,因此在很多软件升级中被广泛使用。 hdiff算法是一种基于压缩的差分算法,它采用了压缩和哈希技术来减少差异数据的大小和提高匹配效率。与bsdff算法不同,hdiff算法生成的差分文件不仅包含了需要修改的内容,还包含了一些辅助信息,比如哈希表。这样在升级时,需要将差分文件与旧版本文件和辅助信息一起使用,才能得到完整的新版本文件。hdiff算法在处理文本文件时效果较好,特别是对于较大的文件或者稍有复杂度的文件。 综上所述,bsdff算法和hdiff算法都可以实现差分升级的功能,但它们在处理文件类型和效率上有所差异。在选择使用哪种算法时,需要考虑到具体的应用场景和需求,综合评估使用二进制比较还是压缩和哈希技术更适合。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值