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

    文章

    17148

    浏览量

    351212
  • OTA
    OTA
    +关注

    关注

    7

    文章

    580

    浏览量

    35230
收藏 人收藏

    评论

    相关推荐

    基于图遍历的Flink任务画布模式下代码开发实现方案

    的过程。以下是利用Flink的 StreamGraph 通过低代码的方式,来实现StreamGraph的生成,并最终实现 Flink 程序代码
    的头像 发表于 11-05 10:35 702次阅读
    基于图遍历的Flink任务画布模式下<b class='flag-5'>零</b><b class='flag-5'>代码</b><b class='flag-5'>开发</b><b class='flag-5'>实现</b>方案

    2024英飞凌生态创新william hill官网 分享:基于英飞凌安全MCU和Trust M构筑安全OTA业务

    拉比基于英飞凌安全MCU和Trust M构筑的安全OTA业务,副总裁赵毅在下午场william hill官网 发表主题演讲《智能家电软件OTA分升级技术》。 英飞凌
    的头像 发表于 09-23 10:44 432次阅读
    2024英飞凌生态创新william hill官网
分享:基于英飞凌安全<b class='flag-5'>MCU</b>和Trust M构筑安全<b class='flag-5'>OTA</b>业务

    S3N8R16工程代码里面只要调用了wifi、蓝牙、mqtt等相关接口,编译出来的固件拿去ota升级升级不了,为什么?

    碰到个很奇怪的现象,我的工程代码里面只要调用了wifi、蓝牙、mqtt等相关接口,编译出来的固件拿去ota升级升级不了,没有调用就能正常升级
    发表于 07-19 07:31

    请问esp32是否支持分升级

    我现在工程需要适配ota功能,但是鉴于固件体积较大,想请教下是否支持分升级?
    发表于 06-21 08:14

    esp32c3同时打开BLE和WIFI的功能,固件都1MByte了,OTA时可以用分升级吗?

    如题,esp32c3同时打开BLE和WIFI的功能,固件都1MByte了,OTA时可以用分升级吗。 还有就是怎么优化下固件大小?
    发表于 06-18 07:05

    ESP-IDF4.4 OTA升级失败的原因?

    ESP-IDF4.4 OTA 功能,在启动OTA功能后下载固件过程中出现wifiInternet访问,然后很快网络恢复,需要等待很久后OTA升级
    发表于 06-06 08:19

    能否使用cyw43439对MCU(STM32h745ziq)进行OTA升级

    在这个项目中,我需要创建可以使用 WiFi 无线更新的设备。 到目前为止,MCU 已经实现了与路由器的连接。 有可能用 cyw43439 芯片实现 OTA
    发表于 05-24 06:33

    应用笔记|米尔NXP iMX 93开发OTA功能搭建

    1.概述空中下载技术(Over-the-AirTechnology,OTA)是通过移动通信的空中接口实现对移动终端设备及SIM卡数据进行远程管理的技术。本文采用了swupdate的方式进行ota
    的头像 发表于 05-23 08:01 963次阅读
    应用笔记|米尔NXP iMX 93<b class='flag-5'>开发</b>板<b class='flag-5'>OTA</b>功能搭建

    ZDP1440系列小技巧—如何OTA分升级显示素材?

    ZDP1440是一款基于开源GUI引擎的图像显示专用驱动芯片,支持U盘、SD卡本地升级UI固件,同时也支持通过UART/SPI方式进行OTA升级,本文将介绍如何OTA
    的头像 发表于 05-06 14:01 896次阅读
    ZDP1440系列小技巧—如何<b class='flag-5'>OTA</b><b class='flag-5'>差</b><b class='flag-5'>分升级</b>显示素材?

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

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

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

    通过飞凌嵌入式OK3568-C开发板来为大家介绍OTA升级的流程,本地升级程序recovery执行升级的流程及技术细节。
    的头像 发表于 04-20 08:01 1639次阅读
    技术帖 | 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

    分升级方案(上)—全量升级vs分升级的主要特点比较

    MCU固件升级可以通过编程器、调试器或其他设备辅助进行操作,但这种升级方式主要应用于产品研发评估及量产应用阶段。
    的头像 发表于 01-18 17:06 1572次阅读
    <b class='flag-5'>差</b><b class='flag-5'>分升级</b>方案(上)—全量<b class='flag-5'>升级</b>vs<b class='flag-5'>差</b><b class='flag-5'>分升级</b>的主要特点比较