你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32三种启动模式

[复制链接]
STMCU-管管 发布时间:2020-9-2 16:14

所谓启动,一般来说就是指我们下好程序后,重启芯片时,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。用户可以通过设置BOOT1和BOOT0引脚的状态,来选择在复位后的启动模式

8 M/ p6 R! {5 `

STM32上电或者复位后,代码区始终从0x00000000开始,三种启动模式其实就是将各自存储空间的地址映射到0x00000000中。


7 ]! t6 b3 P" a  i( p* z4 w' l

(1)从Flash启动,将主Flash地址0x08000000映射到0x00000000,这样代码启动之后就相当于从0x08000000开始。

" _9 c+ K& o8 C* o% ~/ ~

(2)从RAM启动,将RAM地址0x20000000映射到0x00000000,这样代码启动之后就相当于从0x20000000开始。


' B4 f3 C0 J4 ~5 @1 h

(3)从系统存储器启动。首先控制BOOT0 BOOT1管脚,复位后,STM32与上述两种方式类似,从系统存储器地址0x1FFF F000开始执行代码。系统存储器存储的其实就是STM32自带的bootloader代码,在bootloader中提供了UART1的接口,通过此接口可以将用户所需的程序代码下载到主Flash中,下载完毕后,此时程序代码已经存储在主Flash当中,这时切换启动模式(从主Flash启动),复位后所执行的就是刚刚下载到Flash中的代码了。


7 R5 Q7 b' _+ d  l7 k: g9 F9 M/ ^

* K2 f; w" I  H  L; U' D1 f

STM32三种启动模式对应的存储介质均是芯片内置的,如下图:

aHR0cDovL2ltZy5ibG9nLmNzZG4ubmV0LzIwMTcxMTMwMTY0ODAzMjEy.png

(1)用户闪存 : 芯片内置的Flash。正常的工作模式。

! G3 i4 J* \& t3 h  u* n; `
(2)SRAM: 芯片内置的RAM区,就是内存。可以用于调试。


- H& \5 u1 x: t% n/ L8 G- y3 c9 f& \3 H(3)系统存储器: 芯片内部一块特定的区域,芯片出厂时在这个区域预置了一段Bootloader,就是通常说的ISP程序。这个区域的内容在芯片出厂后没有人能够修改或擦除,即它是一个ROM区。启动的程序功能由厂家设置。


1 @1 k$ N* C5 E/ v; L



* ~! C6 W5 K" k$ y

Main Flash memory:

是STM32内置的Flash,一般我们使用JTAG或者SWD模式下载程序时,就是下载到这个里面,重启后也直接从这启动程序。


: L$ S( e& N! m( ]

System memory:

从系统存储器启动,这种模式启动的程序功能是由厂家设置的。一般来说,这种启动方式用的比较少。


2 y! ~& W- A% C4 Y' r- l0 L+ r系统存储器是芯片内部一块特定的区域,STM32在出厂时,由ST在这个区域内部预置了一段BootLoader,也就是我们常说的ISP程序,这是一块ROM,出厂后无法修改。


- N$ F+ [* x* i6 i' g

一般来说,我们选用这种启动模式时,是为了从串口下载程序,因为在厂家提供的BootLoader中,提供了串口下载程序的固件,可以通过这个BootLoader将程序下载到系统的Flash中。但是这个下载方式需要以下步骤:

# P7 i8 |' q! A- ?! G4 X: {3 R  K

Step1: 将BOOT0设置为1,BOOT1设置为0,然后按下复位键,这样才能从系统存储器启动BootLoader;

Step2: 最后在BootLoader的帮助下,通过串口下载程序到Flash中;

Step3: 程序下载完成后,又有需要将BOOT0设置为GND,手动复位,这样,STM32才可以从Flash中启动,可以看到,利用串口下载程序还是比较的麻烦,需要跳帽跳来跳去的,非常的不注重用户体验。

* K% v& n" f$ J, O

Embedded Memory:

内置SRAM,既然是SRAM,自然也就没有程序存储的能力了,这个模式一般用于程序调试。

+ q. U% C7 |4 u# ], T

假如我只修改了代码中一个小小的地方,然后就需要重新擦除整个Flash,比较的费时,可以考虑从这个模式启动代码(也就是STM32的内存中),用于快速的程序调试,等程序调试完成后,在将程序下载到SRAM中。

( V' ?& |4 }8 `/ N4 X1 ~8 z9 S



& X: }8 O( C# e! a4 E7 {  H

发BOOT模式选择。

1、通常使用程序代码存储在主闪存存储器,配置方式:BOOT0=0,BOOT1=X;两个启动引脚通过10K电阻接地。

2、Flash锁死解决办法:


4 D$ U; X3 U1 H6 m) I

开发调试过程中,由于某种原因导致内部Flash锁死,无法连接SWD以及Jtag调试,无法读到设备,可以通过修改BOOT模式重新刷写代码。

+ ?9 M* N8 z! n) t" v

修改为BOOT0=1,BOOT1=0即可从系统存储器启动,ST出厂时自带Bootloader程序,SWD以及JTAG调试接口都是专用的。重新烧写程序后,可将BOOT模式重新更换到BOOT0=0,BOOT1=X即可正常使用。

0 E, e$ B) P3 N. m- N4 h6 q


( f+ ?5 R1 \! f  X/ d% A- p

嵌入式系统的启动还需要一段启动代码(bootloader),类似于启动PC时的BIOS,一般用于完成微控制器的初始化工作和自检。


. F; R) T6 J) Y5 `1 `+ U( H$ E

STM32的启动代码在startup_stm32f10x_xx.s(xx根据微控制器所带的大、中、小容量存储器分别为hd、md、ld)中,其中的程序功能主要包括初始化堆栈、定义程序启动地址、中断向量表和中断服务程序入口地址,以及系统复位启动时,从启动代码跳转到用户main函数的入口地址。


& n8 ~2 @0 G3 |* x
收藏 评论0 发布时间:2020-9-2 16:14

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版