9 更进一步的 bootloader 架构设计

目录

1.什么样的产品适合外部下载?

1.从成本考虑:

2.从安全性考虑:

3.从功能扩展性考虑:

2.硬件架构:

模块架构:

架构图:

3.软件架构:

Bootloader:

App:

4.升级流程

Bootloader

App


1.什么样的产品适合外部下载?

1.从成本考虑:

如果产品本身对内部 Flash 内存的使用已经接近饱和,且内部 bootloader 下载会进一步占用大量内存导致需要增加昂贵的大容量 Flash 芯片,那么外部 Flash 下载就比较合适。

2.从安全性考虑:

对于那些处理敏感信息( 如金融数据、个人隐私数据、企业机密数据等)的产品,外部 Flash 下载方式能够提供更好的加密机制和访问控制。

3.从功能扩展性考虑:

如果产品需要频繁更新功能或者软件版本 ,并且外部 Flash 可以提供更灵活的存储空间用于新功能的加载和更新。

当产品的更新过程需要频繁擦除和写入大量数据时,外部 Flash 下载可能更合适。因为外部 Flash 可以在不影响内部系统核心功能的情况下进行独立的更新操作。

2.硬件架构:

模块架构:

Stm32F411CEU6:用于存放 Bootloader 代码和 APP 的主控芯片

Key:用于实现 App 和 Bootloader 切换逻辑模块

Led:用于演示 App 代码运行成功

Ch340:用于实现 MCU 与 PC 之间通信的中间模块

PC:使用相关上位机软件进行控制和下载芯片

Jlink:下载代码和 Trace 调试

W25Q64:存放下载备份 App 的代码

HC05:实现远程升级的必备工具,于 PC 端实现蓝牙通信

架构图:

3.软件架构:

Bootloader:

Key_Detect:用于上电时检测 Bootloader 是否进入下载模式

Download_logic:用于管理整个下载流程

Ymodem:基于上位机与 MCU 之间的通信协议

Gpio:外设寄存器层

Uart:外设寄存器层

Flash:外设寄存器层

W25Q_Driver:存放官方 W25Q 驱动库

W25Q_Handler:基于升级流程于 W25Q 之间的协议

App:

Key_Detect:用于 App 层是否需要跳转 Bootloader 命令

Led_Logic:App 逻辑执行,从现象中区分 APP 与 Bootloader

Gpio:外设寄存器层

4.升级流程

Bootloader

App

相关推荐
Jerry丶Li1 小时前
三十七、STM32的SPI
stm32·单片机·嵌入式硬件
一支闲人1 小时前
NRF24L01无线通信模块的快速上手
stm32·单片机·嵌入式硬件·nrf24l01无线通信模块
qq_401700411 小时前
运算放大器电路二、实例分析
单片机·嵌入式硬件
CS_Zero1 小时前
无人机数据链路聚合入门笔记
嵌入式·无人机
杰出的胡兵1 小时前
MCU中PFD(Power Fail Detect)和PVD(Programmable Voltage Detector)的区别?
单片机·嵌入式硬件
jifengzhiling2 小时前
STM32 ADC规则与注入通道全解析
stm32·mcu·工业自动化·电流环·外设驱动
沐欣工作室_lvyiyi2 小时前
基于单片机的校园路灯智能控制系统(论文+源码)
单片机·嵌入式硬件·毕业设计·校园路灯
纳米软件2 小时前
电源芯片的欠压锁定如何测试,需要哪些设备?-纳米软件
自动化测试·单片机·嵌入式硬件
小李做物联网2 小时前
52.1基于单片机stm32物联网嵌入式项目程序开发智体重秤体脂系统
stm32·单片机·嵌入式硬件·物联网·课程设计