stm32 bootloader编写
编写STM32的Bootloader涉及芯片启动流程、内存管理、Flash编程和跳转机制。以下是详细步骤和关键点(以标准库/HAL库为例):
1. 基础概念
- 启动模式:STM32通过BOOT引脚决定启动位置(Flash/系统Bootloader/SRAM)
- 内存映射:
- Flash起始地址:
0x0800 0000 - RAM起始地址:
0x2000 0000 - 中断向量表位置:默认在
0x0800 0000(需在APP中重定向)
- Flash起始地址:
2. Bootloader设计流程
(1) 内存分配规划
| 区域 | 起始地址 | 大小示例 | 用途 |
|---|---|---|---|
| Bootloader | 0x0800 0000 | 16KB | Bootloader代码 |
| 应用程序(APP) | 0x0800 4000 | 剩余Flash | 用户程序 |
| APP中断向量表 | 0x0800 4000 | - | APP的中断向量 |
注:需在链接脚本(
.ld文件)中为APP配置偏移地址(示例地址:0x4000)
(2) Bootloader核心代码
#include "stm32f1xx.h" // 根据芯片型号选择头文件
#define APP_ADDRESS 0x08004000 // APP起始地址
typedef void (*pFunction)(void);
void JumpToApp(void) {
uint32_t *pAppStack = (uint32_t*)APP_ADDRESS;
uint32_t *pAppReset = (uint32_t*)(APP_ADDRESS + 4);
// 检查栈顶地址是否在RAM范围内
if((*pAppStack & 0x2FFE0000) == 0x20000000) {
// 关闭全局中断
__disable_irq();
// 重置所有外设(可选)
RCC->APB2RSTR = 0xFFFFFFFF;
RCC->APB2RSTR = 0x00000000;
// 设置主堆栈指针
__set_MSP(*pAppStack);
// 跳转到APP复位中断服务程序
pFunction AppStart = (pFunction)pAppReset;
AppStart();
} else {
// 错误处理:LED报警或重启
while(1);
}
}
int main(void) {
// 初始化时钟、串口、Flash等
HAL_Init();
SystemClock_Config();
// 检查是否需要固件更新(如串口接收到升级命令)
if(NeedUpdate()) {
UpdateFirmware(); // 通过UART/USB接收新固件并写入APP区域
}
// 跳转到APP
JumpToApp();
}
(3) 固件更新函数(伪代码)
void UpdateFirmware(void) {
FLASH_EraseInitTypeDef erase;
uint32_t sector_error = 0;
// 解锁Flash
HAL_FLASH_Unlock();
// 擦除APP区域(以扇区为单位)
erase.TypeErase = FLASH_TYPEERASE_PAGES;
erase.PageAddress = APP_ADDRESS;
erase.NbPages = 10; // 根据实际大小调整
HAL_FLASHEx_Erase(&erase, §or_error);
// 通过串口接收新固件(如YMODEM协议)
while(接收数据中) {
// 写入Flash(每次写入4字节)
HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, target_addr, data);
}
// 锁定Flash
HAL_FLASH_Lock();
}
(4) 用户程序(APP)关键修改
在APP的main.c开头重定向中断向量表:
// main.c
int main(void) {
// 重定向中断向量表到APP起始地址
SCB->VTOR = FLASH_BASE | 0x4000; // 与链接脚本偏移一致
// ...后续初始化代码
}
在链接脚本(.ld文件)中修改Flash起始地址:
MEMORY {
RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 64K
FLASH (rx) : ORIGIN = 0x8004000, LENGTH = 256K - 16K // 减去Bootloader空间
}
3. 关键注意事项
-
中断处理:
- Bootloader中禁用所有中断,跳转前关闭全局中断(
__disable_irq()) - APP中第一时间重定向中断向量表(
SCB->VTOR)
- Bootloader中禁用所有中断,跳转前关闭全局中断(
-
Flash编程:
- 严格按照芯片页/扇区大小擦除
- 写操作需按字(4字节)对齐
-
通信协议:
- 推荐使用可靠协议(如YMODEM、XMODEM-CRC)
- 包含数据校验(CRC32/MD5)
-
失败恢复:
- 添加超时机制和看门狗
- 保留备份固件区域(双APP切换)
4. 调试技巧
-
Bootloader调试:
- 临时修改跳转地址到SRAM调试APP
#define DEBUG_ADDR 0x20000000 // 在SRAM中调试APP
- 临时修改跳转地址到SRAM调试APP
-
日志输出:
- 通过串口打印关键步骤状态
-
硬件支持:
- 使用LED指示Bootloader状态(闪烁模式)
- 预留按键强制进入升级模式
5. 官方资源参考
- 文档:
- AN2606: STM32系统Bootloader手册
- AN3155: USART协议说明
- 示例代码:
- STM32Cube内置IAP例程(路径:
Projects/STM32xxx_IAP)
- STM32Cube内置IAP例程(路径:
通过以上步骤可实现基础Bootloader。实际项目中需根据芯片型号(如F1/F4/F7)调整Flash操作细节,并严格测试异常处理逻辑。
ARM处理器如何编写Bootloader
前面给大家分享过Bootloader从应用角度执行的相关文章,今天从底层原理来给大家描述ARM处理器如何编写Bootloader,以及底层流程。
2023-07-26 09:10:47
STM32单片机Bootloader的实现
之前一篇的文章中,主要介绍了STM32的启动流程和内存主要空间的分配,这篇文章将在上一篇文章的基础上,来阐述一下STM32 Bootloader
2023-01-11 17:29:44
STM32单片机bootloader扫盲
STM32单片机BootLoader扫盲BootLoader和APP之间的关系APP就是平时写的单片机上的应用程序,而
资料下载
佚名
2021-11-26 18:21:04
STM32系统bootloader应用
嵌入式开发中,经常需要bootloader进行程序固件升级和系统维护,所以bootloader是必不可少的功能。STM32系统自带的系统
资料下载
佚名
2021-11-26 13:36:04
关于M0内核MCU的Bootloader编写
在使用MCU的时候如果要使用程序下载、程序升级或程序备份,那么都需要自己编写Bootloader。那么编写
资料下载
h1654155275.3132
2021-10-28 11:36:16
什么是Bootloader 浅谈STM32中bootloader的内存分配
准备好环境。 2. Bootloader的特点 Bootloader不属于操作系统,一般采用汇编语言和C语言开发。需要针对特定的硬件平台编写。在
2021-02-15 06:10:00
如何编写ARM处理器的Bootloader
作者 | strongerHuang 微信公众号 | strongerHuang 之前从应用的角度给大家分享过Bootloader相关的文章,今天从底层原理来给大家描述ARM处理器如何编写
2020-10-27 11:02:36
STM32系统bootloader的应用有哪些
嵌入式开发中,经常需要bootloader进行程序固件升级和系统维护,所以bootloader是必不可少的功能。STM32系统自带的系统
2020-10-22 12:19:45
换一换
- 如何分清usb-c和type-c的区别
- 中国芯片现状怎样?芯片发展分析
- vga接口接线图及vga接口定义
- 芯片的工作原理是什么?
- 华为harmonyos是什么意思,看懂鸿蒙OS系统!
- 什么是蓝牙?它的主要作用是什么?
- ssd是什么意思
- 汽车电子包含哪些领域?
- TWS蓝牙耳机是什么意思?你真的了解吗
- 什么是单片机?有什么用?
- 升压电路图汇总解析
- plc的工作原理是什么?
- 再次免费公开一肖一吗
- 充电桩一般是如何收费的?有哪些收费标准?
- ADC是什么?高精度ADC是什么意思?
- dtmb信号覆盖城市查询
- EDA是什么?有什么作用?
- 苹果手机哪几个支持无线充电的?
- type-c四根线接法图解
- 华为芯片为什么受制于美国?
- 怎样挑选路由器?
- 元宇宙概念股龙头一览
- 锂电池和铅酸电池哪个好?
- 什么是场效应管?它的作用是什么?
- 如何进行编码器的正确接线?接线方法介绍
- 虚短与虚断的概念介绍及区别
- 晶振的作用是什么?
- 大疆无人机的价格贵吗?大约在什么价位?
- 苹果nfc功能怎么复制门禁卡
- amoled屏幕和oled区别
- 单片机和嵌入式的区别是什么
- 复位电路的原理及作用
- BLDC电机技术分析
- dsp是什么意思?有什么作用?
- 苹果无线充电器怎么使用?
- iphone13promax电池容量是多少毫安
- 芯片的组成材料有什么
- 特斯拉充电桩充电是如何收费的?收费标准是什么?
- 直流电机驱动电路及原理图
- 传感器常见类型有哪些?
- 自举电路图
- 通讯隔离作用
- 苹果笔记本macbookpro18款与19款区别
- 新斯的指纹芯片供哪些客户
- 伺服电机是如何进行工作的?它的原理是什么?
- 无人机价钱多少?为什么说无人机烧钱?
- 以太网VPN技术概述
- 手机nfc功能打开好还是关闭好
- 十大公认音质好的无线蓝牙耳机
- 元宇宙概念龙头股一览