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里面最好每一个功能步骤都向上位机发送一个状态位

相关推荐
星恒讯工业路由器43 分钟前
MCU+WiFi与CPU+WiFi模块区别
单片机·嵌入式硬件
LCMICRO-1331084774644 分钟前
长芯微LD7940完全P2P替代AD7940,是一款14位、逐次逼近型模数转换器(ADC)
单片机·嵌入式硬件·fpga开发·硬件工程·dsp开发·模数转换器adc
进击的小头2 小时前
20_第20篇:嵌入式外设驱动开发基础:寄存器级开发与库函数开发对比实战
arm开发·驱动开发·单片机
guygg883 小时前
基于STM32的智能小区管理系统设计
stm32·单片机·嵌入式硬件
Deitymoon4 小时前
STM32——震动传感器控制led
stm32·单片机·嵌入式硬件
bubiyoushang8885 小时前
51单片机MPU6050 DMP驱动实现
单片机·嵌入式硬件·51单片机
BT-BOX5 小时前
STM32的温湿度防盗安防报警器仿真_LCD1602显示
stm32·安防·烟雾·防盗·lcd1602显示·dht11温湿度·火焰
Deitymoon5 小时前
STM32——继电器
stm32·单片机·嵌入式硬件
hfdz_00425 小时前
无人机无刷电机(BLDC)无感六步换相与过零点检测
嵌入式硬件·无人机·硬件设计
恶魔泡泡糖6 小时前
stm32F103C8T6标准库外部中断的概念
stm32·单片机·嵌入式硬件