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

    文章

    787

    浏览量

    116235
  • 物联网
    +关注

    关注

    2932

    文章

    46357

    浏览量

    394366
  • OTA
    OTA
    +关注

    关注

    7

    文章

    615

    浏览量

    36725

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    技术笔记 | Ubuntu 系统 OTA 升级全流程详解

    前言:在嵌入式系统设备管理中,OTA(Over-The-Air)升级是实现设备远程维护、功能迭代的核心能力。本文基于Ubuntu系统环境,详细拆解updateEngine工具的OTA升级
    的头像 发表于 07-31 08:32 ?140次阅读
    技术笔记 | Ubuntu 系统 <b class='flag-5'>OTA</b> <b class='flag-5'>升级</b>全流程详解

    蓝牙空中升级(OTA)原理

    1. 概述 所谓DFU(Device Firmware Update),就是设备固件升级的意思,而OTA(Over The Air)是实现DFU的一种方式而已,准确说,OTA的全称应该是OTA
    发表于 07-21 14:50

    东风日产N7开启首次OTA升级

    近日,东风日产举办“NI好 N7首次OTA升级发布会”,并宣布OTA升级即日开启推送。
    的头像 发表于 07-05 13:57 ?522次阅读

    瑞萨电子MCU无感OTA升级功能介绍

    在工业控制、电机驱动乃至联网边缘节点中,固件在线升级OTA)已成为产品生命周期管理的标配。然而传统OTA往往伴随停机、风险与低效。瑞萨电
    的头像 发表于 05-15 14:36 ?847次阅读
    瑞萨电子MCU无感<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>功能介绍

    一文解锁OTA远程升级方案!基于RK3562全国产平台

    通过网络下载固件进行升级,也支持下载固件到SD卡或U盘进行升级。 而且,升级固件可按需定制,既能让设备系统全面革新,也能升级1个或多个功能模块。凭借远程、灵活、便捷的特性,
    的头像 发表于 04-07 10:15 ?461次阅读
    一文解锁<b class='flag-5'>OTA</b>远程<b class='flag-5'>升级</b><b class='flag-5'>方案</b>!基于RK3562全国产平台

    基于Nordic nRF52840无线键盘、鼠标联网解决方案

    方案通过BLE蓝牙模块和联网技术,将传统的有线键盘鼠标升级为无线设备,为用户带来更大的自由度和便利性。该方案使用低功耗蓝牙技术进行连接,可
    发表于 03-25 17:44

    为什么选择蜂窝联网

    的基础设施。 数据传输速率和稳健性: 由于 LPWAN 技术通常用于不频繁发送/接收数据的设备,因此许多技术都针对这种使用情况进行了优化。然而,某些操作(如远程固件更新)需要更高的数据传输速率。这正是蜂窝联网的优势所在,因为它
    发表于 03-17 11:42

    OTA软件升级管理系统

    OTA(Over-the-Air Technology,空中下载技术)是通过空中下载的方式对车辆中的软件进行远程升级。经纬恒润OTA软件升级管理系统基于软件架构、应用架构、业务架构和技
    的头像 发表于 01-13 09:39 ?837次阅读
    <b class='flag-5'>OTA</b>软件<b class='flag-5'>升级</b>管理系统

    联网就业有哪些高薪岗位?

    联网就业有哪些高薪岗位? 联网行业迎来了全面爆发式的发展,众多高薪岗位吸引着人们的目光。联网
    发表于 01-10 16:47

    【正点原子STM32H7R3开发套件试用体验】4G联网工业设备控制网关

    资料,了解STM32H7R3开发套件的功能。 2. 接入Air780E,实现开发板通过4G联网 3. 对接FastBee联网平台,实现数据上报和命令下发 4. 移植OTA功能,实现在
    发表于 12-18 14:14

    OTA升级】无需数据线,一条命令即可完成固件升级

    OTA无线升级过程视频演示:OTA介绍OTA(Over-The-Air,空中升级)是一种通过无线通信技术实现远程更新设备固件或软件的方法。设
    的头像 发表于 12-11 01:00 ?4036次阅读
    【<b class='flag-5'>OTA</b><b class='flag-5'>升级</b>】无需数据线,一条命令即可完成固件<b class='flag-5'>升级</b>!

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

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

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

    联网系统中为什么要使用BLE蓝牙模块 联网系统中使用BLE蓝牙模块的原因主要有以下几点: 低功耗特性 延长设备续航:BLE(Bluetooth Low Energy)蓝牙模块的主要
    的头像 发表于 09-27 16:51 ?1542次阅读
    <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 ?1703次阅读
    <b class='flag-5'>物</b><b class='flag-5'>联网</b>中的Fota是什么,如何使用HTTP来给设备<b class='flag-5'>升级</b>

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

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