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

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

3天内不再提示

物联网中常用的ota升级方案

嵌入式IoT 来源:嵌入式IoT 作者:嵌入式IoT 2021-03-09 09:48 次阅读

物联网中常用的ota升级方案

说明

在进行物联网开发的过程中,免不了进行ota升级,那么如何做好ota升级又是非常值得思考的问题。

下面从实际应用案例中,剖析一下ota升级的方案。

方案1

最简单的OTA升级,flash布局如下:

其升级的方案是,每个APP的尾部都会记录如下的相关信息,可以作为跳转的标志。

所以可以这样理解,APP0作为运行分区,APP1作为升级分区,当升级分区的标志置位时,将升级分区的代码放到运行分区中执行。

每次都只会跳转到APP0去执行代码。

优点:

该方案设计比较简单,资源占用小。

缺点:

如果升级的过程中出现错误,而校验又没有检测到,则会导致程序起不来。需要加强校验机制,也需要确保下载代码完全的准确性。

也可能在升级之后,出现联网模块不能使用,导致需要去现场解决,这种问题发生后非常严重。

方案2

方案1会存在可能起不来的风险,这时需要去现场进行程序烧录,成本很大。所以第二种是差分升级。

当APP0运行时,将升级的程序放到APP1中,下次BOOT跳转从APP1地址去运行程序。

当APP1运行时,将升级的程序放到APP0中,下次BOOT跳转从APP0地址去运行程序。

这样可以解决一个问题,当模块升级后连接不了网络的问题。如果连接网络失败,可以将失败的原因放到备份SRAM中,多次连接不上,BOOT检测到这个现象,可以跳转到另外一个可以运行的程序进行降级运行。因为两个可以运行的程序没有被破坏。

但是这个问题解决不了由于程序传输错误导致的程序启动不了的问题。

方案3

我曾经也在实际项目中用到过另外OTA方案,如下设计:

该设计的核心在于BOOT中集成联网模块功能,当BOOT下载时,首先会置位相关的标志位。

其设计上采用BOOT主要用于下载功能,当程序运行APP时,需要升级时,会首先将config的标志位置位,然后跳转到BOOT中进行升级,将代码永远放到APP_BAK中,升级完成后,可以校验通过后,将APP_BAK的代码拷贝到APP中,然后再运行APP区代码。

最后一切功能没问题后,再将config设置成正常状态,否则每次boot启动后都会进行OTA请求。

优点:

程序功能可靠有保障,减少可能起不来的风险

缺点:

由于BOOT中集成了比较多的功能,比较复杂,当替换联网模块时,BOOT和APP的代码需要同步修改。

方案4

rt-thread官网上有一种OTA的方案,具体实现如下:

分区名 起始地址 分区大小 分区位置 介绍
app 自定义 自定义 片内 Flash 存储 app 固件
download 自定义 自定义 片内 Flash 或者片外 SPI Flash 存储待升级固件
factory 自定义 自定义 片内 Flash 或者片外 SPI Flash 存储出厂固件
boot -- -- -- boot固件

流程图如下:

解释一下factory分区的实际应用场景。

由于差分升级或者普通的BOOT升级方案都会存在系统启动不了的可能性,所以增加了一个一定可以启动的固件。具体的使用是需要boot中检测一个硬件IO,当该IO被长时间按下后,会进入出厂程序设置。这样减少了设备出问题后,技术人员需要现场升级的烦恼,即使不懂技术的人也能够按下按键进行复位。

优点:

消除设备启动不了的问题,减少程序下载失败的风险

缺点:

资源消耗太大,三个固件起码需要外挂SPI flash才能设计的比较好,完全利用内部flash,资源有点紧张。

责任编辑:lq

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

    关注

    6

    文章

    763

    浏览量

    114631
  • 物联网
    +关注

    关注

    2903

    文章

    44262

    浏览量

    371213
  • OTA
    OTA
    +关注

    关注

    7

    文章

    568

    浏览量

    35141

原文标题:物联网中常用的ota升级方案

文章出处:【微信号:Embeded_IoT,微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    联网系统中常用的低功耗自组网无线传输方案(三)_蓝牙芯片篇

    01 联网系统中为什么要使用蓝牙芯片 联网系统中使用蓝牙芯片的原因主要基于蓝牙芯片在连接性能、数据传输、功耗、安全性以及应用灵活性等方面的优势。以下是详细分析: 低功耗性能 蓝牙芯
    的头像 发表于 09-29 17:11 371次阅读
    <b class='flag-5'>物</b><b class='flag-5'>联网</b>系统<b class='flag-5'>中常用</b>的低功耗自组网无线传输<b class='flag-5'>方案</b>(三)_蓝牙芯片篇

    联网中的Fota是什么,如何使用HTTP来给设备升级

    一 概述 FOTA(Firmware Over-The-Air)移动终端的空中下载软件升级,指通过云端升级技术,为具有连网功能的设备提供固件升级服务。在
    的头像 发表于 09-25 14:35 384次阅读
    <b class='flag-5'>物</b><b class='flag-5'>联网</b>中的Fota是什么,如何使用HTTP来给设备<b class='flag-5'>升级</b>

    【全新课程资料】正点原子《ESP32联网项目实战》培训课程资料上线!

    ,涵盖了环境搭建、编程软件使用、模块基础驱动、联网基础知识和多个实战项目等等。在联网项目的选择上,我们深思熟虑,选择了生活和生产中常用
    发表于 09-24 17:05

    ESP8266 OTA升级不成功的原因?

    我正在使用最新的 RTOS SDK 版本 1.5 ESP8266。我使用自定义服务器进行OTA升级。 有时 OTA 升级成功,有时即使闪烁了正确的图像,
    发表于 07-10 06:14

    esp-ali-smartliving SDK功能OTA升级失败的原因?

    ,使用阿里生活物联网平台OTA升级失败,提示:Not digestSign key in json doc of OTA,如下图 请问如何解决呢?
    发表于 06-28 08:50

    ESP-IDF是否支持基于BLE的OTA升级

    节点需要切换到WiFi才能完成HTTP升级,ESP-IDF是否支持基于BLE的OTA升级
    发表于 06-12 07:49

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

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

    ESP IDF OTA升级失败的原因?

    ESP IDF 5.1.1,官方OTA例程,升级过程中失败,tcp拉取文件中断,有遇到类似情况的吗,日志如下: I (59717) ota: ota url:http://www.x
    发表于 06-05 07:27

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

    说起OTA我们应该都不陌生,它是一种可以为设备无损失升级系统的方式,能将新功能远程部署到产品上。我们不仅可以通过网络下载OTA升级包,也可以通过下载
    的头像 发表于 04-20 08:01 1540次阅读
    技术帖 | RK3568开发板的<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

    汽车ota升级有什么用 汽车ota功能有必要吗

    汽车OTA(Over-The-Air)升级是指通过无线网络进行汽车软件系统的远程更新和升级。传统上,汽车的软件系统需要通过专门的设备或者到车辆所在的服务中心来进行升级,非常不便捷。而
    的头像 发表于 02-18 14:39 1199次阅读

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

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

    深入了解联网设备的OTA升级机制

    OTA(Over-The-Air,空中下载技术)是一种无线传输技术,用于在联网设备之间进行远程更新和配置。OTA指的是通过无线通信网络来远程更新或
    发表于 01-21 10:03 1730次阅读
    深入了解<b class='flag-5'>物</b><b class='flag-5'>联网</b>设备的<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>机制

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

    概述OTA(Over-The-AirTechnology)即空中下载技术,利用OTA技术可以在不接触(接线)的情况下对芯片程序进行升级。AT32WB415的OTA是通过蓝牙的方式实现的
    的头像 发表于 12-20 08:15 804次阅读
    如何通过雅特力AT32WB415的蓝牙模块来进行<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>

    联网解决方案-联网一站式解决方案全视通

    全视通以联网基站为数据总线,以联网统一融合平台为核心,开发统一开放的智慧医院开放平台,将人工智能、
    的头像 发表于 12-19 10:27 865次阅读
    <b class='flag-5'>物</b><b class='flag-5'>联网</b>解决<b class='flag-5'>方案</b>-<b class='flag-5'>物</b><b class='flag-5'>联网</b>一站式解决<b class='flag-5'>方案</b>全视通