DFOTA差分算法

本文介绍了FOTA中常用的Vcdiff和Bsdiff差分算法。Vcdiff通过ADD、COPY、RUN等操作生成差分文件,并支持压缩。Bsdiff则依赖文件的稀疏变化和块移动特性,通过后缀排序和二分查找生成高度可压缩的差分信息。
摘要由CSDN通过智能技术生成
固件升级使用FOTA(Firmware Over-The-Air) 方式时,可以采用传输差分包的形式来减小升级包的大小,能够带来空口传输时间减小、降低终端功耗等优势。目前比较常见的算法有xdelta 使用的Vcdiff Bsdiff 等。
Vcdiff
Vcdiff 可以实现文件的差分并压缩的功能,当原文件为空时,则相当于对新的文件直接压缩。Vcdiff 采用差分文件包含:ADD COPY RUN[ NOOP( )] 等操作方式。生成差分文件前,需要首先进行Vcdiff decoding ,具体采用128 进制来重新编码,带来的好处: 一是在不同的系统中统一采用8 比特的字节编码方式,二是对于小数字则可以节省存储空间;在RF3284 给出的示例将123456789 ,经过编码后表示为MSB+58,MSB+111,MSB+26,0+21 ,二进制值为10111010 11101111 10011010 0010101 ,最高位MSB 用来表示数据是否完成,1 时表示下个字节仍属于同一数据块,即123456789 = 128*(128*(58 * 128 + 111) + 26) + 21 。编码完成后的文件生成差分格式包,也可进行压缩后再进行传输。差分包执行过程示例如下, 旧的文件内容为a b c d e f g h i j k l
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值