STM32 BOOT 启动配置 ISP升级 介绍

启动配置

在STM32F10xxx里,可以通过BOOT[1:0]引脚选择三种不同启动模式。

|----------|-------|--------|---------------|
| 启动模式选择引脚 | 启动模式 | 说明 |
| BOOT1 | BOOT0 |
| X | 0 | 主闪存存储器 | 主闪存存储器被选为启动区域 |
| 0 | 1 | 系统存储器 | 系统存储器被选为启动区域 |
| 1 | 1 | 内置SRAM | 内置SRAM被选为启动区域 |

在系统复位后, SYSCLK的第4个上升沿, BOOT引脚的值将被锁存。用户可以通过设置BOOT1

和BOOT0引脚的状态,来选择在复位后的启动模式

在从待机模式退出时, BOOT引脚的值将被被重新锁存;因此,在待机模式下BOOT引脚应保持

为需要的启动配置。在启动延迟之后, CPU从地址0x0000 0000获取堆栈顶的地址,并从启动

存储器的0x0000 0004指示的地址开始执行代码。

因为固定的存储器映像,代码区始终从地址0x0000 0000开始(通过ICode和DCode总线访问),

而数据区(SRAM)始终从地址0x2000 0000开始(通过系统总线访问)。 Cortex-M3的CPU始终从

ICode总线获取复位向量,即启动仅适合于从代码区开始(典型地从Flash启动)。 STM32F10xxx

微控制器实现了一个特殊的机制,系统可以不仅仅从Flash存储器或系统存储器启动,还可以从

内置SRAM启动。

根据选定的启动模式,主闪存存储器、系统存储器或SRAM可以按照以下方式访问:

● 从主闪存存储器启动:主闪存存储器被映射到启动空间(0x0000 0000),但仍然能够在它原

有的地址(0x0800 0000)访问它,即闪存存储器的内容可以在两个地址区域访问, 0x0000

0000或0x0800 0000。

● 从系统存储器启动:系统存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的

地址(互联型产品原有地址为0x1FFF B000,其它产品原有地址为0x1FFF F000)访问它。

● 从内置SRAM启动:只能在0x2000 0000开始的地址区访问SRAM。

注意: 当从内置SRAM启动,在应用程序的初始化代码中,必须使用NVIC的异常表和偏移寄存器,从

新映射向量表之SRAM中。

内嵌的自举程序

内嵌的自举程序存放在系统存储区,由ST在生产线上写入,用于通过可用的串行接口对闪存存

储器进行重新编程:

● 对于小容量、中容量和大容量的产品而言,可以通过USART1接口启用自举程序。进一步的

细节请查询AN2606。

● 对于互联型产品而言,可以通过以下某个接口启用自举程序: USART1、 USART2(重映像

的)、 CAN2(重映像的)或USB OTG全速接口的设备模式(通过设备固件更新DFU协议)。

USART接口依靠内部8MHz振荡器(HSI)运行。 CAN和USB OTG接口只能当外部有一个

8MHz、 14.7456MHz或25MHz时钟(HSE)时运行。进一步的细节请查询AN2606。

ISP升级

由上可知:只需要将STM32F10xxx的BOOT0拉高,BOOT1拉低。就可以进入ISP升级。如下图所示。

使用 FlyMcu STM32程序下载软件与STM32 USART1连接

ISP工具:下载链接

相关推荐
竹照煜_ysn1 小时前
蓝桥杯51单片机设计
单片机·嵌入式硬件·51单片机
Electron-er2 小时前
汽车LIN总线通讯:从物理层到协议栈的深度解析
单片机·汽车电子·lin总线·lin总线通讯
Do vis8242 小时前
STM32第十六天蓝牙模块
stm32·单片机·嵌入式硬件
学不动CV了2 小时前
ARM单片机启动流程(二)(详细解析)
c语言·arm开发·stm32·单片机·51单片机
猫猫的小茶馆4 小时前
【STM32】通用定时器基本原理
c语言·stm32·单片机·嵌入式硬件·mcu·51单片机
jingshaoqi_ccc5 小时前
stm32的USART使用DMA配置成循环模式时发送和接收有着本质区别
stm32·单片机·嵌入式硬件
MingYue_SSS8 小时前
开关电源抄板学习
经验分享·笔记·嵌入式硬件·学习
玉树临风江流儿8 小时前
炸鸡派-定时器基础例程
单片机·嵌入式硬件
小宋同学在不断学习9 小时前
stm32-掌握SPI原理(一)
stm32·单片机·spi
is08159 小时前
STM32的 syscalls.c 和 sysmem.c
c语言·stm32·嵌入式硬件