完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本帖最后由 lee_st 于 2016-7-27 11:06 编辑
前言 大家都知道,任何STM32 都包含有一块系统存储器(System Memory),里边存储着内部的启动代码Bootloader。不同的 STM32 型号所支持的用于升级代码的通讯口不尽相同,需要参考应用笔记AN2606。但是,有一个问题避免不了,那就是如 何进入System Memory 去执行Bootloader?通常的办法都是将BOOT1 和BOOT0 进行配置:BOOT0 拉高,BOOT1 拉低 (有些型号的BOOT1 由选项字节nBOOT1 进行控制)。可是在一些产品中,由于外观的要求,往往不方便在外边开口去放 置按键或跳线来改变BOOT 脚的电平。而且,用户并不想自己写IAP 代码,觉得麻烦。特别是一些产品,需要使用USB DFU 来进行代码升级的,而在产品功能中USB 又没用到,用户就会觉得自己为了一个通过USB 进行代码升级的功能,去写 IAP 的话,需要去熟悉USB 的代码,觉得麻烦,而且这些USB 的代码还占用了用户的程序空间。对于这些用户来讲,他们很 希望能在不管BOOT 脚的情况下能够去调用STM32 中System Memory 的Bootloader,完成代码升级功能。 问题 某客户在其产品的设计中,使用了STM32F411。由于产品外观的要求,无法在外部对BOOT 脚进行控制,而且外观上只有 USB 接口是留在外边的,需要使用USB DFU 进行升级。而且USB 接口只用于代码升级,没有其他功能,所以客户不想去碰 USB 代码,希望能够直接使用System Memory 中的Bootloader 进行代码升级。 调研 1.判断其可行性 首先,打开应用笔记AN2606《STM32 microcontroller system memory boot mode》,翻到3.1 Bootloader activation 一节的 最后,可以看到如下信息: 这里的意思就是说,用户可以通过从用户代码跳转到系统存储器去执行Bootloader。但是,在跳转到Bootloader 之前,有几 个事情必须要做好: 1) 关闭所有外设的时钟 2) 关闭使用的PLL 3) 禁用所有中断 4) 清除所有挂起的中断标志位 最后,可以通过离开Bootloader 激活条件且产生一个硬件复位或者直接使用Go 命令去执行用户代码。 |
|
相关推荐
|
|
那么,如何从用户代码跳转到 System Memory 中去呢?这个其实并不难,如果写过 IAP,或者看过关于 IAP 的应用笔记中的
参考代码的话,比如应用笔记 AN3965“ STM32F40x/STM32F41x in-application programming using the USART”及其参考 代码 STSW-STM32067,都应该知道, IAP 的启动代码通过重新设置主堆栈指针并跳转到用户代码来执行用户代码的。同样 的道理,只要知道 System Memory 的地址,一样可以从用户代码通过重新设置主堆栈指针并跳转到 System Memory 来执行 Bootloader。而 System Memory 地址可以从参考手册来获得。比如,查看 STM32F411 的参考手册 RM0383, |
|
|
|
|
|
《DNESP32S3使用指南-IDF版_V1.6》第三十五章 摄像头实验
542 浏览 0 评论
《DNESP32S3使用指南-IDF版_V1.6》第三十章 DHT11数字温湿度传感器
648 浏览 0 评论
751 浏览 0 评论
【敏矽微ME32G070开发板免费体验】之原厂2812测试例程解析
1295 浏览 0 评论
1143 浏览 2 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12056 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-28 14:44 , Processed in 0.628317 second(s), Total 63, Slave 46 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号