单片机 IAP 功能进阶开发篇之BOOT升级(一)
引言
目的
主要介绍单片机 IAP 开发的设计思路,如何不使用下载烧录器的方式对单片机的程序进行升级,升级区域包括 bootloader 和用户程序的升级,升级方式有 UASRT 通信、CAN 通信和 OTA 升级。
本文目前介绍的是 bootloader 对 Bootloader 程序区升级的开发设计思路。
术语及缩写
BOOT:Bootloader 程序
APP:用户程序
参考资料
详细设计
前言
单片机程序都是在 FLASH(ROM)中,通过 单片机 IAP 功能基础开发篇之APP升级(一) 知道, APP 的程序升级是在 Bootloader 中实现的,那么 Bootloader 的程序升级是在哪实现的呢?还是 Bootloader。
实现方式
通过 Bootloader 升级 Bootloader,方法目前我了解的有两种。
Bootloader 互相升级
通过一个 Bootloader 升级另一个 Bootloader,即该程序中存在两个 Bootloader,严格来说的有三个,只不过其中一个和其他两个 Bootloader 的功能不一样,可以称其 Bootloader 的引导程序。
内存分配图如下:
| MCU 分区 | 内容描述 | 备注 |
|---|---|---|
| 引导程序区 | 中断向量表 | |
| 引导可执行程序 | 决定执行哪一个 Bootloader | |
| Bootloader 1 程序区 | 重定向的中断向量表 | 需要软件配置 |
| BOOT 可执行程序 | ||
| Bootloader 2 程序区 | 重定向的中断向量表 | 需要软件配置 |
| BOOT 可执行程序 | ||
| 用户程序区(APP) | 重定向的中断向量表 | 需要软件配置 |
| APP 可执行程序 | ||
| 数据储存区 | 系统需要下电保存的数据 | 可选择划分该区域 |
执行流程
通过引导程序,检测 Bootloader 1 和 Bootloader 2 的最新状态,校验通过后执行最新的 Bootloader ,然后再进行跳转 APP。其中 Bootloader 1 和Bootloader 2 的功能一致,不同只在于升级 Bootloader 时擦写FLASH的地址不同;
该设计方式较为复杂,需要四个独立的工程,若可实现 Bootloader 的配置,则只需要三个独立的工程即可(Bootloader 的功能相同,其他地址信息不同)
引导程序流程图
Created with Raphaël 2.2.0
开始
系统初始化
BOOT 至少一个有效
BOOT 1 符合
跳转至 BOOT 1 运行
结束
跳转至 BOOT 2 运行
yes
no
yes
no
Boot程序流程图
仅介绍升级 boot 程序的流程图,APP可看 单片机 IAP 功能基础开发篇之APP升级(一) 的 boot 流程图,其中,升级流程一致,不同的是 BOOT 升级或 APP 升级时的校验、擦写 FLASH 地址等信息的不同。
Created with Raphaël 2.2.0
开始
系统初始化
升级请求
根据升级指令分别实现
对BOOT和APP的升级
升级完成
APP 程序存在
BOOT 退出处理
跳转至APP运行
结束
计数超时
yes
no
yes
no
yes
no
yes
no
Bootloader 自升级
通过 Bootloader 升级 Bootloader,即该程序中只存在一个 Bootloader。
内存分配图如下:
| MCU 分区 | 内容描述 | 备注 |
|---|---|---|
| Bootloader 程序区 | 中断向量表 | |
| BOOT 可执行程序 | ||
| 用户程序区(APP) | 重定向的中断向量表 | 需要软件配置 |
| APP 可执行程序 | ||
| 数据储存区 | 系统需要下电保存的数据 | 可选择划分该区域 |
执行流程
由于单片机的程序是在 Flash 中运行的,如果按照普通的做法,通过 Bootloader 自升级,则会出现在收到升级指令后,会将 Bootloader Flash 的程序全部擦除,这样就会导致程序跑飞,最后成了“板砖”。
要实现 Bootloader 自升级,而且需要保证不会因为擦除了FLASH导致程序无法运行,就需要将程序运行在 RAM 中,在 RAM 中擦除 FLASH 的程序,并不影响 RAM 中的程序执行,即在程序启动后,需要将 Bootloader 的程序拷贝至 RAM 中执行。
当然并不是在程序中简单的通过拷贝函数将 FLASH 的程序拷贝到 RAM 中就可以了,而是需要通过修改链接文件,甚至还需要修改启动文件等才能实现该功能
Boot程序流程图
Created with Raphaël 2.2.0
开始
将 Boot FLASH 的程
序拷贝至 RAM 中
系统初始化
升级请求
升级中
升级完成
APP 程序存在
BOOT 退出处理
跳转至APP运行
结束
计数超时
yes
no
yes
no
yes
no
yes
no
实现方式对比
Bootloader 互相升级
优点:
- 系统升级功能稳定,基本不会出现升级失败后成为“板砖”
- 不用担心 RAM 的大小
缺点:
- 实现复杂,至少三个独立工程(如果 boot 不能配置,则四个)
- FLASH 需要较大的内存
使用场景:
- BOOT 升级需求度高,BOOT 的更新迭代相对多一点
- 对 BOOT 升级的稳定性比较严格,OTA 升级等
Bootloader 自升级
优点:
- 适用于 FLASH 不够大的MCU
- 功能实现相对简单,两个独立工程
缺点:
- 系统升级功能不稳定,升级失败后若断电,则会成为“板砖”(只要不断电,就可以反复升级直到成功)
- RAM 太小不适合(bootloader的程序大小小于 RAM 大小,且相关变量也占用了 RAM 空间)
使用场景:
- BOOT 升级需求度低,BOOT 的更新迭代基本不需要
- 对 BOOT 升级的稳定性没有过度严格,每次升级都至少保证现场有开发人员,防止升级失败成“板砖”
单片机 IAP 功能进阶开发篇之BOOT升级(一)的更多相关文章
- ArcGIS Engine开发鹰眼图的功能(代码优化篇)
在上一篇,ArcGIS Engine开发鹰眼图的功能(基础篇) 上一篇的实现效果图如下, 如果仔细观察,会发现一个问题,即在“鹰眼”的区域,只要在红色线框内的注记会被覆盖. 如果红色框包括整张图的话, ...
- ArcGIS Engine开发鹰眼图的功能(基础篇)
鹰眼是用于调节全视域范围内主地图显示范围情况的副地图.它体现了地图整体与详细局部的关系. 用户可以通过鼠标单击或者画框等动作实现鹰眼与主地图的交互情况. 鹰眼功能的原理是通过主地图窗口的地图控件和鹰眼 ...
- Spring Boot上传文件功能的开发
Spring Boot上传文件功能的开发 Spring Boot使用Servlet 3的API javax.servlet.http.Part来支持文件上传.Spring Boot在类Multipar ...
- 老王Python培训视频教程(价值500元)【基础进阶项目篇 – 完整版】
老王Python培训视频教程(价值500元)[基础进阶项目篇 – 完整版] 教学大纲python基础篇1-25课时1.虚拟机安装ubuntu开发环境,第一个程序:hello python! (配置开发 ...
- linux一句话问答(网络无关篇+网络相关篇+程序开发篇+经典图书)
一句话问答(网络无关篇+网络相关篇+程序开发篇+经典图书) --------------------------目录-网络无关篇-目录-------------------------- 0001 修 ...
- STC单片机 IAP(EEPROM)的使用
STC89C51.52内部都自带有2K字节的EEPROM,54.55和58都自带有16K字节的EEPROM,STC单片机是利用IAP技术实现的EEPROM,内部Flash擦写次数可达100,000 次 ...
- 华清远见金牌讲师名家大讲堂Android开发篇成功举办
2014年3月5日.12日华清远见金牌讲师名家大讲堂(以下简称名家大讲堂)在线讲座全新升级开讲,至此拉开了新一年名家大讲堂的序幕! 华清远见名家大讲堂作为业内颇具影响力的公益免 费线上课程,自2009 ...
- nginx模块开发篇 (阿里著作)
背景介绍 nginx历史 使用简介 nginx特点介绍 nginx平台初探(100%) 初探nginx架构(100%) nginx基础概念(100%) connection request 基本数据结 ...
- E8.Net工作流平台开发篇
E8.Net开发篇(一) E8.Net开发框架有哪些源程序模型? E8.Net开发框架为开发企业流程应用系统提供了最佳实践的开发架构.范例及源代码,包括待办事项的组织.流程启动模型.处理模型.母版 ...
- 单片机IAP学习
1.IAP是什么--简介 IAP是In Application Programming的首字母缩写,IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可 ...
随机推荐
- 聚焦业务价值:分众传媒在 Serverless 上的探索和实践
作者 | 吴松(分众传媒研发总监) **关注 Serverless 公众号后台回复 分众 即可获得云原生峰会 PPT! ** 本文总结于分众传媒研发总监吴松在阿里云云原生实战峰会上的分享,从三个方面详 ...
- mybatis-plus数据批量插入
为了提高数据处理效率,大量数据需要插入数据时可以采用批量数据插入的策略提高数据插入的效率. 如下是实现方法 1.代码结构 2.实体类 package little.tiger.one.applicat ...
- freeswitch的mod_xml_curl模块动态获取dialplan
概述 freeswitch是一款简单好用的VOIP开源软交换平台. mod_xml_curl模块支持从web服务获取xml配置,本文介绍如何动态获取dialplan配置. 环境 centos:Cent ...
- 开发人员常用Docker指令
什么是 Docker? Docker 是一个开源的容器化平台,用于构建.打包和运行应用程序.它允许开发者将应用程序及其依赖项打包成一个独立的可移植容器,可以在任何环境中运行,无论是开发环境.测试环境还 ...
- 扒一扒ProcessOn 新功能——一键编号、图形组合、左侧导航、画布水印、表格组件
思维导图.一键编号 思维导图新增 多种全新主题风格,让您的创作赏心悦目 思维导图新增 一键编号 功能 流程图.图形组合 自定义组合图形功能:新增流程图 我的图形 功能,用户可以设置或者上传自己的图形 ...
- Kubernetes APIServer 最佳实践
1. kubernetes 整体架构 kubernetes 由 master 节点和工作节点组成.其中,master 节点的组件有 APIServer,scheduler 和 controller-m ...
- 14-TTL与非门的输入特性和输出特性
TTL与非门的电压传输特性 传输特性 输入电压连续发生变化,输出电压发生什么变化?需要研究输出电压与输入电压之间的关系 输入小的时候,输出大的信号:输入大时候输出小信号 中间有截止和导通,需要过渡过程 ...
- 例2.9 建立一个带头结点的线性链表,用以存放输人的二进制数,链表中每个结点的data域存放一个二进制位。并在此链表上实现对二进制数加1的运算。
1.题目 例2.9建立一个带头结点的线性链表,用以存放输人的二进制数,链表中每个结点的data域存放一个二进制位.并在此链表上实现对二进制数加1的运算. 2.算法分析 3.代码 /* 二进制加1 */ ...
- 【SHELL】查找包含指定字符串的目录、在找出的路径中找出指定格式的文件、并统计出数量
查找包含字符串"skull"的目录.在找出的路径中找出格式".c/.cpp/.h"的文件.并统计出数量 find . -path ./out -prune -o ...
- SQLServer数据库JDBC连接串参数的简单学习
SQLServer数据库JDBC连接串参数的简单学习 背景 前段时间一直跟同事一起处理SQLServer 比其他数据库的deadlock更多的问题. 涉及到了几个驱动的参数. 想着问题基本上告一段落, ...