stm32进阶-OTA升级功能的完善

1、以往简单的实现

以前自己也做了IAP升级,但是以往的流程是

应用层选择程序进行串口升级

  1. 串口接收完毕后存放到指定分区后断电
  2. 断电,判断是否有升级标记位
  3. 不升级就跳转到正常运行区,升级就开始复制数据到运行区
  4. 跳转前检查是否有运行成功标记位,有的话才跳转
  5. 没有运行成功标记位则报错,提示单片机启动失败
  6. 跳转运行成功,赋值成功标记位
  7. 跳转失败程序已经跑飞,也恢复不了,只能关机从2开始再次执行

这里面的缺点就是对于数据没有保护

网上看了一下,主要看这篇博客OTA远程升级固件安全验证流程,

2、添加加密算法

准备工作就是windows先生成密钥对,下位机存储公钥数据

添加以后的流程大概就是:

  1. 上位机对升级文件进行计算生成哈希值
  2. 上位机对生成的哈希值进行加密生成数字签名
  3. 上位机执行升级命令,将发送数字签名和升级文件
  4. 下位机接收完成后存储重启
  5. 重启以后先检查标记位,查看是否有升级命令
  6. 有升级则取出公钥进行验签,通过则跳转,不通过继续执行之前的代码
  7. 无升级就进行运行区的内容计算校验,查看是否存在存储损坏,某一个bit跳变的情况
  8. 一切正常则跳转,跳转后设置程序当前运行区和启动状态

在启动过程中,上下位机需要建立及时的通讯机制以及报错机制,在出现问题时帮助其他工程师排除问题

3、具体实现

Flash分了五个区,

  1. bootloader,
  2. App1,
  3. App2
  4. publickey
  5. config

每次假设运行区在App1,接收的升级数据就存放在App2中,相关的数字签名就存放在Config区,验签所需要的公钥存储在publickey区

因为跟项目相关就不贴代码了,但是把代码的执行流程说一下

3.1、上电启动,执行时钟和外设初始化

3.2、进入while循环,等待上位机程序启动成功

3.3、收到上位机启动成功后程序开始运行命令

3.4、开始运行,先查看上次的启动状态标记位是否正常启动

3.4.1、未正常启动,查看未启动成功次数,

  • 如果超过三次就停止跳转,等待重新升级,同时上报错误
  • 未超过三次则继续跳转到上次的启动区域

3.4.2、如果是启动成功,则判断config区是否有升级标记位更新

假设此时App1有升级标记位,则进行数据验签,

  • 通过则跳转到App1的地址运行,同时记录当前的运行区域,更改标记位,当前App1的Flash内容的校验和存储进Config区,避免遇到内存损坏
  • 未通过则上报错误,询问上位机是等待升级还是重新运行上一个区域,等待上位机返回

3.5、跳转前将启动状态标记位改为异常,等到正常的App启动以后改为正常,等待App启动

3.6、App启动成功

在bootloader里面最好每一个功能步骤都向上位机发送一个状态位

相关推荐
cmpxr_5 分钟前
【单片机】位域非原子写的风险
单片机·嵌入式硬件
FPGA-ADDA37 分钟前
第二篇:RFSoC芯片架构详解——处理系统(PS)与可编程逻辑(PL)
嵌入式硬件·fpga开发·信号处理·fpga·47dr
恒森宇电子有限公司2 小时前
南麟LN1151 超低静态功耗 CMOS 低压差线性稳压器 多种封装形式
单片机·嵌入式硬件
九鼎创展科技3 小时前
国产高性能 MCU 开发板新标杆:PICO2 主板深度解析
单片机·嵌入式硬件
LCG元4 小时前
STM32实战:基于STM32F103的LCD1602液晶屏(并口/模拟时序)驱动
stm32·单片机·嵌入式硬件
可乐鸡翅好好吃4 小时前
从四个 ble_evt_handler 看 Nordic BLE 架构:模块化解耦与优先级控制
单片机·嵌入式硬件
匿名了匿名了5 小时前
直流无刷与直流有刷电机
stm32·嵌入式硬件·mcu
水果里面有苹果5 小时前
26-MT41J64M16LA-187E 美光科技DDR3 SDRAM 1Gb
嵌入式硬件
三佛科技-187366133975 小时前
LPK8717省外围无需启动电阻,12W自供电PSR控制芯片恒压恒流方案
单片机·嵌入式硬件
陶瓷好烦5 小时前
智能编码助手:VSCode+Keil+Kilo Code打造自然语言编程环境
vscode·stm32·单片机