news 2026/6/16 6:11:45

STM32F103基于CAN协议的bootload程序源码,成功量产应用于实际项目

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
STM32F103基于CAN协议的bootload程序源码,成功量产应用于实际项目

基于STM32F103的CAN bootload程序源码,包含boot和app两个工程,已应用到实际项目并量产

最近在量产一款工业控制器时遇到了头疼的问题——产品装到现场后发现程序有bug咋升级?总不能每次都拆下来用ST-Link烧录吧?这时候CAN总线Bootloader就成了救命稻草。今天就跟大伙儿聊聊我们项目中实际使用的STM32F103双工程方案,源码在文末自取。

先上硬菜,boot工程的核心跳转逻辑:

//boot_main.c关键片段 if(Check_JumpToApp() == VALID_APP_FLAG) { __disable_irq(); __set_MSP(*(__IO uint32_t*)APP_ADDRESS); /* 重设中断向量表 */ SCB->VTOR = APP_ADDRESS & 0x1FFFFF80; /* 函数指针跳转 */ uint32_t app_reset = *(__IO uint32_t*)(APP_ADDRESS + 4); ((void (*)(void))app_reset)(); }

这段代码里有个骚操作——SCB->VTOR寄存器设置。很多兄弟的Bootloader跑着跑着进APP就死机,八成是忘了这茬。STM32的中断向量表默认在0x08000000,APP工程必须修改自己的中断偏移量:

//APP工程的system_stm32f1xx.c中 #define VECT_TAB_OFFSET 0x8000 //假设bootloader占32KB

硬件抽象层才是魔鬼细节。我们的CAN配置里藏了个超时机制,防止升级过程卡死:

//CAN初始化片段 hcan.Instance->MCR |= CAN_MCR_INRQ; while(!(hcan.Instance->MSR & CAN_MSR_INAK)) { if((HAL_GetTick() - startTick) > 100) { //超时自重启 NVIC_SystemReset(); } }

实测发现,某些国产CAN芯片初始化时会卡INRQ标志,这个超时重启能让设备在异常时自动恢复,避免变砖。后来产线反馈升级成功率从87%直接飙到99.8%,这行代码值回票价。

量产时还踩过一个大坑:APP工程的bin文件必须带CRC校验。我们的方案是在生成hex后自动添加校验尾:

arm-none-eabi-objcopy -O binary app.ax7 app.bin crc32 app.bin >> app.bin

Bootloader端验证时这么玩:

uint32_t fileCRC = *(__IO uint32_t*)(flashAddr + fileSize - 4); if(HAL_CRC_Calculate(&hcrc, flashAddr, fileSize-4) != fileCRC) { //校验失败,重传 Send_Nak(CAN_ERR_CRC); }

有次产线工人误用了旧版本bin文件,结果设备自动识别校验失败,避免了整批返工。厂长听说后给项目组加了个鸡腿,这波不亏。

代码仓库里还有个骚操作——boot和app共用同一套硬件驱动。通过条件编译实现资源复用:

//hal_can.h #ifdef BOOTLOADER #define CAN_TX_MSG_ID 0x321 #else #define CAN_TX_MSG_ID 0x322 #endif

最后给个忠告:量产项目千万别用库函数擦写Flash!我们最早版本用HALFLASHProgram写死的升级包,结果有次断电导致设备变砖。后来切到底层寄存器操作才稳如老狗:

//Flash写入关键操作 FLASH->CR |= FLASH_CR_PG; *(__IO uint16_t*)address = data; while(!(FLASH->SR & FLASH_SR_EOP)); FLASH->SR = FLASH_SR_EOP;

源码已脱敏上传GitHub,搜索"Stm32f103-can-bootloader"就能找到。下期打算聊聊如何在Bootloader里集成AES128加密,防止现场被逆向——有次竞品公司买我们的设备直接dump固件,把老子吓出一身冷汗...(此处应有后怕表情)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/11 15:17:17

冶金轧钢车间远距离通讯解决方案:DP转光纤实现设备稳定互联

某冶金厂专注于高强度结构钢、特种合金钢板的研发与生产,核心轧钢车间承担着企业80%的钢材轧制任务。该车间采用“中控室西门子S7-400PLC8台四辊可逆轧机6台红外温度传感器”的控制架构,其中PLC作为控制核心,需实时接收每台轧机张力控制器反馈…

作者头像 李华
网站建设 2026/6/15 23:43:02

安全运维工程师和传统运维工程师在工作内容上有什么主要区别?

安全运维工程师和传统运维工程师虽然都带着“运维”二字,工作环境也常有交集,但他们的核心目标、日常工作重心和所需的技能图谱有着本质的区别。为了让你能快速把握全局,下表清晰地展示了它们在四个核心维度上的不同。对比维度传统运维工程师…

作者头像 李华
网站建设 2026/6/13 23:08:45

sync.Pool 真不是“对象池”:Go GC 性能优化的隐藏王牌

sync.Pool 深度解析本期分享 sync.Pool:短生命周期对象的复用技巧,以及它在 Go Runtime 与 GC 背后发生的那些事。一、为什么需要 sync.Pool 要理解 为什么会有 sync.Pool,我们需要先理解 Heap Allocation(堆分配)。 1…

作者头像 李华
网站建设 2026/6/15 11:03:01

实时对抗类游戏AI难训练?破解高动态环境下的3大技术瓶颈

第一章:实时对抗类游戏AI训练的挑战与机遇实时对抗类游戏为人工智能提供了极具挑战性的测试平台。这类环境不仅要求AI具备快速决策能力,还需在信息不完全、对手策略动态变化的情况下持续适应。由于每局对战的时间步长极短,且动作空间庞大&…

作者头像 李华
网站建设 2026/6/15 2:23:06

CDMA在移动通信系统中的应用研究与仿真

一、CDMA技术原理及在移动通信中的核心优势 CDMA(码分多址)是基于扩频通信技术的多址接入方式,其核心原理是通过不同的伪随机码(PN码)区分用户信号,实现多用户在同一频率和时间资源上的并行通信。在发送端&…

作者头像 李华