当前位置: 首页 > article >正文

手把手教你给STM32F103ZET6写Bootloader:从串口接收Bin文件到跳转APP的完整流程

STM32F103 Bootloader开发实战从零构建可靠固件升级系统第一次接触嵌入式固件升级功能时我被Bootloader这个概念深深吸引——想象一下不需要拆解设备就能远程更新程序这简直是电子产品的魔法。但真正动手实现时却踩遍了所有可能的坑固件接收不完整、跳转后死机、中断无法响应...本文将用最直白的方式带你完整走通STM32F103ZET6的Bootloader开发全流程。1. Bootloader基础认知与工程准备Bootloader本质上是一段先于主程序运行的特殊代码就像电脑的BIOS系统。对于STM32F103ZET6这类Cortex-M3内核芯片上电后固定从0x08000000地址开始执行。我们的目标是在这个起始位置放置Bootloader而将用户程序安排在后续Flash空间。开发前需要明确几个关键数据STM32F103ZET6的Flash容量为512KB扇区大小前16KB每扇区4KB之后每扇区64KB典型分配方案Bootloader占用前64KB0x08000000-0x0800FFFF用户程序从0x08010000开始在Keil MDK中创建Bootloader工程时需要特别注意以下配置// 链接脚本关键配置 #define FLASH_BASE 0x08000000 #define FLASH_SIZE 0x80000 // 512KB LR_IROM1 FLASH_BASE FLASH_SIZE { ER_IROM1 FLASH_BASE 0x10000 { // Bootloader占用64KB *.o (RESET, First) *(InRoot$$Sections) .ANY (RO) } ER_IROM2 0x08010000 FLASH_SIZE-0x10000 { // 用户程序区域 .ANY (RO) } RW_IRAM1 0x20000000 0x10000 { // SRAM配置 .ANY (RW ZI) } }2. 固件接收与存储实现串口接收二进制文件是Bootloader最常用的升级方式。我们需要解决三个核心问题可靠接收、正确存储、完整性校验。2.1 环形缓冲区设计直接使用全局数组作为接收缓冲区存在溢出风险。更健壮的做法是采用环形缓冲区#define BUF_SIZE 2048 typedef struct { uint8_t buffer[BUF_SIZE]; uint16_t head; uint16_t tail; uint16_t count; } RingBuffer; RingBuffer rx_buf; void USART1_IRQHandler(void) { if(USART_GetITStatus(USART1, USART_IT_RXNE) ! RESET) { uint8_t data USART_ReceiveData(USART1); if(rx_buf.count BUF_SIZE) { rx_buf.buffer[rx_buf.head] data; rx_buf.head (rx_buf.head 1) % BUF_SIZE; rx_buf.count; } } }2.2 Flash编程关键要点STM32的Flash编程有几个易错点需要特别注意解锁顺序必须先写KEY1再写KEY2擦除粒度最小擦除单位是扇区写入对齐必须按半字(16位)写入void FLASH_Write(uint32_t addr, uint8_t *data, uint32_t len) { FLASH_Unlock(); FLASH_ClearFlag(FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPRTERR); uint32_t sector GetSector(addr); FLASH_EraseSector(sector, VoltageRange_3); for(uint32_t i 0; i len; i 2) { uint16_t value data[i] | (data[i1] 8); FLASH_ProgramHalfWord(addr i, value); } FLASH_Lock(); }注意实际工程中应该添加CRC校验在写入前后验证数据完整性3. 应用程序跳转机制从Bootloader跳转到用户程序看似简单实则暗藏多个技术细节。一个完整的跳转流程需要处理以下关键点3.1 栈指针与复位向量用户程序的第一个字是初始栈指针第二个字是复位向量地址。跳转前必须正确设置typedef void (*pFunction)(void); pFunction JumpToApplication; void JumpToApp(uint32_t appAddr) { uint32_t stackPointer *(volatile uint32_t*)appAddr; uint32_t resetHandler *(volatile uint32_t*)(appAddr 4); if(stackPointer 0x20000000 stackPointer 0x20010000) { __set_MSP(stackPointer); // 设置主栈指针 JumpToApplication (pFunction)resetHandler; JumpToApplication(); // 跳转 } }3.2 中断向量表重映射用户程序必须正确配置向量表偏移寄存器(VTOR)否则所有中断都会跳转到Bootloader的中断服务程序// 在用户程序的system_init函数中添加 SCB-VTOR FLASH_BASE | 0x10000; // 用户程序起始地址3.3 外设状态清理跳转前必须关闭所有使用的外设和中断避免状态残留void BeforeJump(void) { __disable_irq(); USART_DeInit(USART1); TIM_DeInit(TIM1); // 其他外设反初始化 SysTick-CTRL 0; SysTick-LOAD 0; SysTick-VAL 0; }4. 用户程序特殊配置要让用户程序能与Bootloader协同工作需要在编译和链接阶段进行特殊配置。4.1 Keil工程设置Target选项卡IROM1 Start: 0x08010000Size: 0x70000 (512KB-64KB)Debug选项卡取消勾选Load Application at Startup在Initialization File中添加以下脚本LOAD %L INCREMENTAL SETPC 0x080100004.2 生成Bin文件在User选项卡中添加Post-build命令fromelf --bin --output.\output\app.bin .\output\app.axf4.3 中断处理优化用户程序的中断服务函数应该放在RAM中执行避免在Flash编程期间被调用__attribute__((section(.ramfunc))) void EXTI0_IRQHandler(void) { // 中断处理代码 EXTI_ClearITPendingBit(EXTI_Line0); }5. 调试技巧与常见问题开发Bootloader过程中以下几个调试工具和技巧能极大提高效率5.1 必备调试工具工具用途备注J-Link直接读写Flash验证编程结果USART转USB固件传输建议使用流控Logic Analyzer分析时序捕获启动序列5.2 典型问题排查问题1跳转后立即HardFault检查用户程序的栈指针是否合法验证复位向量地址是否正确确认VTOR寄存器已正确设置问题2中断不响应检查用户程序的中断向量表位置确认跳转前已禁用所有中断查看NVIC寄存器状态问题3Flash编程失败验证Flash解锁序列检查写入地址是否已擦除测试供电电压是否稳定// 诊断HardFault的实用函数 void HardFault_Handler(void) { uint32_t stacked_r0 ((uint32_t)__get_MSP()); uint32_t stacked_lr *(volatile uint32_t*)(stacked_r0 0x14); while(1) { printf(HardFault at: 0x%08X\r\n, stacked_lr - 2); delay_ms(500); } }6. 进阶优化方向基础功能实现后可以考虑以下增强功能提升Bootloader的可靠性6.1 安全升级机制数字签名验证使用ECDSA验证固件合法性加密传输AES加密固件数据回滚机制保留上一版本固件bool VerifyFirmware(uint8_t *data, uint32_t len) { uint8_t signature[64]; uint8_t hash[32]; // 提取签名和哈希 memcpy(signature, data len - 64, 64); SHA256(data, len - 64, hash); return ECDSA_Verify(hash, signature); }6.2 多协议支持除了串口还可以实现以下升级方式USB DFU通过USB接口升级CAN总线适用于工业环境无线OTA通过Wi-Fi/蓝牙升级6.3 状态管理与故障恢复完善的Bootloader应该包含启动菜单通过按键选择模式状态标志记录升级进度看门狗防止升级过程卡死typedef struct { uint32_t magic; uint32_t version; uint32_t crc; uint32_t status; // 0未开始, 1传输中, 2已完成 } BootInfo; BootInfo boot_info __attribute__((section(.boot_info)));在项目后期我习惯在Bootloader中加入一个简单的命令行界面通过串口可以查看设备信息、手动触发升级等。这虽然增加了代码量但在现场调试时能提供极大便利。

相关文章:

手把手教你给STM32F103ZET6写Bootloader:从串口接收Bin文件到跳转APP的完整流程

STM32F103 Bootloader开发实战:从零构建可靠固件升级系统 第一次接触嵌入式固件升级功能时,我被Bootloader这个概念深深吸引——想象一下,不需要拆解设备就能远程更新程序,这简直是电子产品的"魔法"。但真正动手实现时&…...

python pyre

Pyre这个东西,说实话在国内讨论的并不多。有些人可能把它和Pyright搞混,毕竟名字长得有点像。不过如果你在处理超大型Python项目,或者团队里有那么几个同事总喜欢写一堆动态类型然后跑出奇怪的运行时错误,Pyre可能比你想的有用得多…...

终极Android系统清理指南:无需root权限深度优化你的设备

终极Android系统清理指南:无需root权限深度优化你的设备 【免费下载链接】universal-android-debloater Cross-platform GUI written in Rust using ADB to debloat non-rooted android devices. Improve your privacy, the security and battery life of your devi…...

【2025必学核心能力】:PHP 8.9 Error Handling精准管控——ZEND引擎级错误分流技术首次公开

更多请点击: https://intelliparadigm.com 第一章:PHP 8.9错误处理范式革命:从全局捕获到ZEND级精准分流 PHP 8.9 引入了全新的 zend_error_dispatcher 机制,允许开发者在 Zend Engine 层直接注册错误分流回调,绕过传…...

Visual C++ Redistributable AIO:Windows运行库终极解决方案指南

Visual C Redistributable AIO:Windows运行库终极解决方案指南 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经遇到过软件无法启动&#x…...

PHP 8.9 协程化改造避坑指南(23个生产环境血泪故障清单)

更多请点击: https://intelliparadigm.com 第一章:PHP 8.9 纤维协程的演进本质与定位认知 PHP 8.9 并非官方发布的正式版本(截至 2024 年,PHP 最新稳定版为 8.3),但“PHP 8.9 纤维协程”这一提法常被社区用…...

低代码≠低质量:用.NET 9 Source Generators实现编译期校验的强类型组件DSL(附VS插件)

更多请点击: https://intelliparadigm.com 第一章:低代码≠低质量:编译期校验的范式革命 传统低代码平台常被诟病为“拖拽即交付、运行才报错”,其核心缺陷在于将大量语义校验推迟至运行时——而真正的工程化演进正始于将校验前移…...

PPTAgent:让AI帮你制作专业演示文稿的智能框架

PPTAgent:让AI帮你制作专业演示文稿的智能框架 【免费下载链接】PPTAgent An Agentic Framework for Reflective PowerPoint Generation 项目地址: https://gitcode.com/gh_mirrors/pp/PPTAgent PPTAgent是一个创新的AI演示文稿生成框架,采用基于…...

AI_概率统计-2.常见分布

以下涵盖均匀分布、正态分布(高斯分布)、伯努利分布、二项分布、多项分布,以及 Softmax 背后的分布思想。 2. 常见分布 核心目标:掌握 AI 中高频使用的6种分布(均匀、正态、伯努利、二项、多项、softmax对应分布&#…...

散点云处理笔记(一):基于主成份分析算法(PCA)的平面拟合

前面我们对 Kafka 的整体架构和一些关键的概念有了一个基本的认知,本文主要介绍 Kafka 的一些配置参数。掌握这些参数的作用对我们的运维和调优工作还是非常有帮助的。 写在前面 Kafka 作为一个成熟的事件流平台,有非常多的配置参数。详细的参数列表可以…...

长芯微LD4449完全P2P替代ADS4449, 是一款高线性、四通道、14 位、250MSPS 模数转换器 ADC

描述长芯微LD4449 是一款高线性、四通道、14 位、250MSPS 模数转换器 (ADC)。此器件针对低功耗和高无杂散动 态范围 (SFDR) 而设计,具有低噪声性能以及在宽输入 频率范围内出色的 SFDR特性• 四通道 • 14 位分辨率 • 最大采样数据速率:250MSPS • 功率…...

HNU计算机系统期中题库分类(300个)

自用CS期中题库题目分类(按ID大类小类) 一、计算机组成原理(CPU、指令系统、存储器、运算基础) 1. CPU结构与功能 ID:9504、ID:9429、ID:9430、ID:9431、ID:9475、ID:9655、ID:9660、ID:9695、ID:9696、ID:9697、ID:9584、ID:9549…...

LFM2-2.6B-GGUF实操手册:日志实时查看+err.log错误定位技巧

LFM2-2.6B-GGUF实操手册:日志实时查看err.log错误定位技巧 1. 项目概述 LFM2-2.6B-GGUF是由Liquid AI公司开发的轻量级大语言模型,采用GGUF量化格式,特别适合资源有限的本地部署场景。这个2.6B参数的模型经过量化后体积大幅缩小&#xff0c…...

保姆级教程:图形验证码后端核验全流程(多语言实现)

摘要 图形验证码作为互联网应用的第一道安全屏障,其后端核验机制的设计直接决定了验证码系统的安全性和用户体验。本文深入剖析图形验证码的核心核验流程,详细讲解基于Token的后端验证机制,并通过Java、Python、Go三种主流语言提供完整的代码…...

Zotero浏览器扩展跨平台架构深度解析:如何实现学术文献一键保存的终极解决方案

Zotero浏览器扩展跨平台架构深度解析:如何实现学术文献一键保存的终极解决方案 【免费下载链接】zotero-connectors Chrome, Firefox, Edge, and Safari extensions for Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-connectors Zotero Conne…...

内网穿透方案:Fish-Speech 1.5在企业防火墙后的部署

内网穿透方案:Fish-Speech 1.5在企业防火墙后的部署 1. 引言 在企业内部部署AI服务时,经常会遇到一个实际问题:Fish-Speech 1.5 TTS服务部署在内网服务器上,但外部用户或分支机构需要访问。由于企业防火墙的安全策略&#xff0c…...

手机端千问 文心 元宝 Kimi怎么发图片

移动端 AI 对话导出:从“碎片化截屏”到“结构化知识”的技术进阶 在 2026 年的生产力变革中,移动端大模型(LLM)已成为职场人的“外脑”。然而,根据《2025-2026年中国生成式AI用户行为洞察报告》显示,超过 …...

Pixel 2刷入FART12脱壳系统全流程:从驱动安装到Dex提取的保姆级避坑指南

Pixel 2刷入FART12脱壳系统实战手册:从零开始打造专业逆向分析设备 在移动安全研究和逆向工程领域,拥有一台专用的脱壳设备能极大提升工作效率。Google Pixel 2凭借其出色的硬件兼容性和开发者友好特性,成为搭建脱壳分析平台的理想选择。本文…...

Xdotool深度解析:Linux桌面自动化技术指南

Xdotool深度解析:Linux桌面自动化技术指南 【免费下载链接】xdotool fake keyboard/mouse input, window management, and more 项目地址: https://gitcode.com/gh_mirrors/xd/xdotool xdotool是一个基于X11系统的命令行自动化工具,通过XTEST扩展…...

生物多样性监测相机:揭秘野生动物世界的科技之眼

生物多样性监测相机(也叫狩猎相机),是一种专门用于自动捕捉野生动物影像的设备。它能够拍摄照片和视频,为人们揭开野生动物世界的神秘面纱。这种相机通常被安装在野外,凭借其特殊的功能,默默记录着野生动物…...

FIDO2跨设备认证:基于QES的虚拟认证器架构解析

1. 项目概述在当今数字身份认证领域,FIDO2与WebAuthn标准已经成为抵抗钓鱼攻击的黄金方案。作为一名长期从事身份安全研究的从业者,我见证了这项技术从诞生到普及的全过程。然而,传统FIDO2实现存在一个根本性矛盾:设备绑定的安全特…...

Spring Boot 开发中批量消息处理的部分失败补偿问题详解

文章目录Spring Boot 开发中批量消息处理的部分失败补偿问题详解引言1. 问题表现:批量处理部分失败的典型症状2. 原因分析:批量处理部分失败的根源2.1 消息中间件的批量确认机制2.2 事务与批量的冲突2.3 补偿机制的缺失2.4 幂等性设计不足3. 解决方案&am…...

调查记者深度采访 实用的律师证人访谈实操技巧

"今天把我跟着资深调查记者打磨的、律师圈常用的2026最新访谈实操技巧整理出来,不管你是做论文调研访谈,还是准备校招面试,都是直接能用的落地方法,解决你记录乱、挖不到料、赶ddl熬大夜的痛点。我踩过这些坑,也见…...

【译】在 Visual Studio 中完全掌控您的悬浮窗口

如果您和我一样使用多显示器办公,那您大概率会渐渐爱上 Visual Studio 中的悬浮工具窗口与文档。将解决方案资源管理器、调试器或是代码文件拖拽到第二块(甚至第三块)屏幕上,能够大幅提升工作效率。但这些悬浮窗口的运行表现&…...

终极指南:3步解决PS手柄PC兼容问题,解锁完美游戏体验

终极指南:3步解决PS手柄PC兼容问题,解锁完美游戏体验 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 你是否曾经兴奋地连接PlayStation手柄到PC,准备在…...

三步解决网易云音乐NCM格式限制:ncmdump完全解密攻略

三步解决网易云音乐NCM格式限制:ncmdump完全解密攻略 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾经从网易云音乐下载了心爱的歌曲,却发现只能在官方客户端播放?当你试图在车载音响、手…...

Python 算法快速复习手册(长期没用、有基础、极速捡回、纯刷题向) | 一、Python 算法面试万能模板【直接背诵、白板默写】 |

一、必写开头 & 基础规则1. 无需头文件Python 不用 include,直接写代码。2. 缩进是语法(最容易忘)不用大括号 {}if / for / while / 函数 后面加冒号 :下方代码缩进 4 个空格python运行if a > 0:print("正数") # 缩进必须对…...

强化学习/对齐(个人理解)

Bradley-Terry 奖励模型含义:给定选中和拒绝响应的隐藏状态,将其投影为标量奖励并计算偏好损失。def reward_model_loss(chosen_hidden, rejected_hidden, reward_head):r_chosen (chosen_hidden reward_head).squeeze(-1) # (B,)r_rejected (rej…...

Windows下用清华源5分钟搞定ONNX全家桶(含CUDA版本匹配避坑指南)

Windows下5分钟极速部署ONNX全家桶:清华源加速与CUDA版本精准匹配实战 刚接手一个新项目需要部署YOLOv5模型时,我遇到了典型的ONNX环境配置噩梦:ImportError: Could not load library cudnn_ops_infer64_8.dll。这个报错背后是无数开发者共同…...

Win11Debloat:3分钟快速清理Windows系统垃圾的终极免费工具

Win11Debloat:3分钟快速清理Windows系统垃圾的终极免费工具 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter a…...