0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于MCU,如何零代码无开发实现OTA差分升级?

嵌入式星球 2020-10-14 17:23 次阅读

随着物联网设备智能化的发展,OTA 升级已经成为了业界公认的基础能力,而 OTA 在设计和实现过程中需要依赖于物联网设备的硬件方案。物联网设备主流的硬件方案为:

1. 直接基于通讯芯片 / 模块开发的方案,用户升级的主要目标是通讯芯片 / 模块。艾拉比在设备端有基于 UA+UC 的方式提供端云一体化的 OTA 解决方案。

2. 通过 MCU/DSP/MPU 等应用处理器 / 控制器和各类通讯模块开发的方案,用户升级的主要目标是这些应用处理器 / 控制器,通讯模块更多是透传管道。

其中,MCU作为主控处理器在物联网领域占着非常高的份额,广泛分布在智能家居、三表、工业等各个领域。在 MCU的 OTA 升级方式上,部分客户实现方式为整包升级,甚至很多 MCU 产品是裸跑,并且是不升级的,当然这也和产品形态、功能特性、行业等相关。而差分升级相较于传统的的整包升级方式,有资源需求低、升级功耗低、升级时间短及下载流量少等诸多优势,越来越多的成为物联网升级的优选方案。举个例子,某客户 MCU 的 Flash 配置为 64KB,自身 APP 固件为 50KB,此时如果需要实现 OTA 升级,大多客户选择的方案是:

1. 外挂一颗 64KB 或者 128KB 的 Flash

2. 选择一颗 128KB Flash 资源的 MCU

而如果通过差分 OTA 升级,则在 64KB Flash 的 MCU 上直接可以实现,再加入 5KB 左右的差分升级算法后,还能剩余 9KB 左右空间来存储几 KB 的差分升级包,不增加硬件成本就可以实现 OTA 升级。


1

差分升级的实现方案

差分升级大多是通过在升级程序(Bootloader 为主)中增加差分升级算法来实现,算法需要占用一些本地 Flash 和 RAM 资源。

差分升级又叫增量升级,顾名思义就是通过差分算法将源版本与目标版本之间差异的部分提取出来制作成差分包,然后在设备通过还原算法将差异部分在源版本上进行还原从而升级成目标版本的过程。差分升级方案不仅可以节省 MCU 内部的资源空间、还可以节省下载流程及下载和升级过程中的功耗。从另一个角度说,通过将差分部分下发到设备保证了版本的安全性。

在过去几年,艾拉比一直致力于将差分升级赋能给更多行业客户,比较主流的差分算法集成的方式是通过 SDK 的形式提供差分升级能力,客户需要将差分升级 SDK 集成到设备 Bootloader 中,有一定的集成开发量。这种方式的好处是客户可以自己根据 API 进行定制开发一些功能,但是 MCU 的碎片化导致这种集成开发方式成本较高,客户集成使用也相对有些要求,适配和测试周期也比较长,因此艾拉比基于大量 MCU 系统的认识、以及对 OTA 的理解推出一种更简便,更易用的,相对标准化的优化方案。


2

MCU 差分升级的优化实现方案 UB 产品
UB(Upgrade Bootloader)产品是艾拉比基于 MCU 推出的独立标准化 bootloader 产品,内部集成了艾拉比最新的差分升级算法,烧录即可以使用,无需开发即可实现差分升级。


UB 通过将差分升级算法在编译 bootloader 阶段集成进去,而这个编译和开发 bootloader 的过程,艾拉比直接提供一种图形化、零开发的云端制作工具来完成,从而使得 MCU 的产品可以用最简单的方式实现差分升级能力。

1.png

相较于整包升级大大节省了 Flash 资源,甚至可以省去外挂 Flash 或者更换更大资源 MCU 的物料成本。作为一款标准化的产品,艾拉比提供的在线制作工具可根据用户产品的硬件配置一键生成 UB,省去了繁琐且碎片化的 OTA 适配成本,助力产品快速上市。此外,UB 在确保 OTA 的安全性上还有很多考量。比如采用一芯一码技术,根据 MCU 内出厂不可更改的唯一 ID,生成唯一安全激活码,确保设备差分功能的唯一性和升级过程的安全性。UB 中集成的异常保护支持了防掉电 / 误操作等防变砖机制,确保升级万无一失。

2.png

UB 的生成过程十分简便,用户根据选定的 MCU 型号和基本信息,通过界面化工具按步骤操作直接生成。操作流程如下:配置 mcu 的硬件信息 ->配置 mcu 的分区信息 ->一键生成 UB。

目前艾拉比已经适配了 ST 主流的 MCU 型号。


3

UB 的使用场景
1)作为 Bootloader 的使用场景

该场景用户无需再额外开发一个 Bootloader,直接使用 UB 来引导启动程序,当有版本需要升级时跳转至升级流程,由 UB 来控制跳转。

2)作为独立子系统的使用场景
该场景用户已经根据需求制作出一个 Bootloader,那么可以将 UB 作为一个独立的升级子系统或者是二级 Bootloader,当 MCU 需要升级时由 Bootloader 跳转至 UB 来进行升级。

4

UB 的成功案例—NB IOT 燃气表

我们结合表计行业的成功案例看一下 UB 如何在整表产品中使用:案例中需要升级的是 MCU 上的主控程序。

3.png

STM32 MCU 烧录艾拉比 OTA UB ,一方面可以作为 Bootloader 来引导系统启动,另一方面可以实现差分升级。差分升级包的获取方式有两种情况,一种通过 NB 模块从平台获取;一种通过近场的红外模块将差分升级包传输至设备。

1)通过 NB 模块从平台获取
此种方式需要在应用层集成平台连接组件,其中对网络调用通过 NB-IOT 模块的 AT 指令完成,NB-IOT 模块只进行数据透传实现网络连接。NB-IOT 表计包含应用和历史数据、配置数据等区域,升级过程只升级应用区域,数据区不做任何改变。

2)通过近场模块传输
在艾拉比在线差分平台制作完差分包后下载至本地。然后通过手持红外设备将差分包传输至表记中来实现升级,避免拆表等工作。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    16021

    浏览量

    343674
  • OTA
    OTA
    +关注

    关注

    7

    文章

    525

    浏览量

    34599
收藏 人收藏

    评论

    相关推荐

    通过RK3568开发板进行OTA本地程序升级

    将通过飞凌嵌入式OK3568-C开发板来为大家介绍OTA升级的流程,本地升级程序recovery执行升级的流程及技术细节。 1. 制作
    发表于 04-20 11:23

    技术帖 | RK3568开发板的OTA升级教程

    将通过飞凌嵌入式OK3568-C开发板来为大家介绍OTA升级的流程,本地升级程序recovery执行升级的流程及技术细节。
    的头像 发表于 04-20 08:01 390次阅读
    技术帖 | RK3568<b class='flag-5'>开发</b>板的<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>教程

    请问BlueNRG ota升级ota_sw_activation变量上电是随机值吗?

    最近在看BlueNRG ota升级代码时有一个疑惑,ota_sw_activation变量是一个未初始化的值,按照ram特性上电应该是一个随机值,那么在
    发表于 03-13 08:29

    在CCG5代码中怎么实现DR_SWAP?

    请教个问题,在 CCG5代码中怎么实现DR_SWAP?我们配置了端口 0 作为源对外充电,但是我们希望 PORT0 做了 UFP。我们是这样写的代码:案例 APP_EVT_PD_合同谈判_完成
    发表于 02-26 06:27

    使用PSoC4的launcher+双App模式,当运行的是App1时,此时更新App1代码就会出现MCU重启的现象是怎么回事?

    最近碰到一个问题,我使用PSoC4的launcher+双App模式,当运行的是App1时,此时更新App1代码就会出现MCU重启的现象。 当前运行的App1的版本是1.0,升级App1的程序为1.0
    发表于 02-05 08:23

    ota升级是什么意思 ota升级有什么用

    OTA(Over-the-Air)升级是指通过无线网络,将软件、固件或系统的新版本传输到支持的设备上进行更新和安装的过程。这一技术广泛应用于手机、智能电视、汽车等各类智能设备中。本文将详细介绍OTA
    的头像 发表于 02-02 10:25 2556次阅读

    如何通过雅特力AT32WB415的蓝牙模块来进行OTA升级

    中的蓝牙模块(BLE)接收上位机发送的升级命令和程序代码OTA分为两个部分,用户可以选择OTA升级BLE模块APP,也可以选择
    的头像 发表于 12-20 08:15 293次阅读
    如何通过雅特力AT32WB415的蓝牙模块来进行<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>

    RX系列帮您实现二级MCU OTA升级:FreeRTOS篇

    RX系列帮您实现二级MCU OTA升级:FreeRTOS篇
    的头像 发表于 10-26 18:04 503次阅读
    RX系列帮您<b class='flag-5'>实现</b>二级<b class='flag-5'>MCU</b> <b class='flag-5'>OTA</b><b class='flag-5'>升级</b>:FreeRTOS篇

    AT32 MCU如何使用OTA通过USART实现对固件的在线升级更新

    AT32 MCU如何使用OTA通过USART实现对固件的在线升级更新
    的头像 发表于 10-26 17:09 925次阅读
    AT32 <b class='flag-5'>MCU</b>如何使用<b class='flag-5'>OTA</b>通过USART<b class='flag-5'>实现</b>对固件的在线<b class='flag-5'>升级</b>更新

    手把手教你OTA升级开发

    。具体升级的动作由升级脚本控制。本文将介绍如何针对OpenHarmony L2场景适配updater模式。主要内容包括: *1.OTA升级实现
    发表于 08-22 09:13

    将hbirdv2代码综合后下载到FPGA板上报错怎么解决?

    求助: 将hbirdv2代码综合后下载到FPGA板(不是MCU200T或DDR200T)上,由于板子上没有MCU_FLASH,所以引脚绑定时qspi接口悬空,出现如下错误 本人猜测
    发表于 08-16 08:02

    你知道PCB线路板为什么要做阻抗吗?

    ,flash : 5k 应用场景 : 低速无线,OTA分升级,低功耗无线升级 我爱方案网是一个电子方案开发供应链平台,提供从找方案到研发
    发表于 06-26 15:38

    启明FOTA差分升级 系统级解决方案

    “你的设备远程升级可以不再是升级整个固件。启明提供了一套完整的差分升级算法,升级固件更小、下载速度更快、大大降低网络不稳定造成传输失败概率,同时更节省内存。”众所周知,传统
    的头像 发表于 06-09 09:46 869次阅读
    启明FOTA差<b class='flag-5'>分升级</b> 系统级解决方案

    启明FOTA差分升级 系统级解决方案

    “你的设备远程升级可以不再是升级整个固件。启明提供了一套完整的差分升级算法,升级固件更小、下载速度更快、大大降低网络不稳定造成传输失败概率,同时更节省内存。”
    的头像 发表于 06-05 09:40 1103次阅读
    启明FOTA差<b class='flag-5'>分升级</b> 系统级解决方案

    基于BSDIFF差分算法在TLZ210中控屏的实现

    因项目原因,需要开发差分FOTA升级功能,差分升级优点是节省OTA传输数据量,非常适合LoRa,Zigbee等小无线升级场景,节省功耗等。
    的头像 发表于 05-19 17:11 1074次阅读
    基于BSDIFF差分算法在TLZ210中控屏的<b class='flag-5'>实现</b>