STM32 芯片启动过程分析求证

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了STM32 芯片启动过程分析求证相关的知识,希望对你有一定的参考价值。

STM32 的开发之前做过一些,但对头文件的理解以及存储器的映射理解不是很深,现在准备开始研究ARM的时候,发现启动引导问题暴露出来了,现在我把我对STM32 启动过程描述一下,请高手指正:
STM32 有三种启动模式,根据上电后两个BOOT脚的电平可以确定是哪种启动:
1,User flash memory 2,system memory 3, embedded SRAM.
现假设User flash 的起始地址是0x08000000
system memory address 是0x1FFFF000
embedded SRAM address 是0x20000000
1。现在假设User flash 里已经烧写有应用程序,并且我选择user flash memory启动模式,则上电后PC指针从绝对物理地址0x00000000启动,然后经跟着就是执行厂家固化的boot程序(即:检测boot引脚的高低电平,根据检测结果实现指针跳转)。由于我之前假设是User flash模式,所以PC指针会跳转到0x0800000处,然后紧跟着就是堆栈设置,中断向量入口设置,最后执行main函数。
2。如果是system flash模式,则上电检测后会跳转到0x1FFFF000,在这个模式里厂家还固化了一些函数来实现IAP(初始化串口,还有一些串口协议等等)。估计在这个模式下,中断是不好使的。这一点求证??
3。如果是sram模式估计过程跟模式1的过程相似。

所以在STM32 运行中,不会出现象ARM的那种情况,即需要引导将FLASH中程序copy到SRAM中执行的这个过程。这一点结论,我心里没有底

参考技术A

看这段,用户手册第二章一目了然。

参考技术B 需要帮你做设计吗追问

我只是对这部分比较感兴趣,工作上我不需要搞软件,我纯属个人兴趣。

追答

好的

浅谈STM32的启动过程

分享这篇文章,谈一下STM32启动流程。如果读者朋友已经有过汇编相关基础,能够够好理解本文内容。汇编语言是比C语言更接近机器底层的编程语言,能让我们更好的理解和操纵硬件底层。

STM32三种启动模式

下好程序后,重启芯片时,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存,这就是所谓的启动过程。

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

从主闪存存储器启动,将主Flash地址0x08000000映射到0x00000000,这样代码启动之后就相当于从0x08000000开始。主闪存存储器是STM32内置的Flash,作为芯片内置的Flash,是正常的工作模式。一般我们使用JTAG或者SWD模式下载程序时,就是下载到这个里面,重启后也直接从这启动程序。

从系统存储器启动。首先控制BOOT0、BOOT1管脚,复位后,STM32与上述两种方式类似,从系统存储器地址0x1FFF F000开始执行代码。系统存储器是芯片内部一块特定的区域,芯片出厂时在这个区域预置了一段Bootloader,就是通常说的ISP程序。这个区域的内容在芯片出厂后没有人能够修改或擦除,即它是一个ROM区。启动的程序功能由厂家设置。系统存储器存储的其实就是STM32自带的bootloader代码。

从内置SRAM启动,将SRAM地址0x20000000映射到0x00000000,这样代码启动之后就相当于从0x20000000开始。内置SRAM,也就是STM32的内存,既然是SRAM,自然也就没有程序存储的能力了,这个模式一般用于程序调试。假如我只修改了代码中一个小小的地方,然后就需要重新擦除整个Flash,比较的费时,可以考虑从这个模式启动代码,用于快速的程序调试,等程序调试完成后,在将程序下载到SRAM中。

用户可以通过设置BOOT1和BOOT0引脚的状态,来选择在复位后的启动模式。STM32三种启动模式对应的存储介质均是芯片内置的,如下图:

在这里插入图片描述
串口下载程序原理

从系统存储器启动,这种模式启动的程序功能是由厂家设置的。一般来说,这种启动方式用的比较少。系统存储器是芯片内部一块特定的区域,STM32在出厂时,由ST在这个区域内部预置了一段BootLoader,也就是我们常说的ISP程序,这是一块ROM,出厂后无法修改。

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

这个下载方式需要以下步骤:

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

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

程序下载完成后,又有需要将BOOT0设置为GND,手动复位,这样,STM32才可以从Flash中启动。

从汇编代码分析STM32启动过程

STM32的启动文件与编译器有关,不同编译器,它的启动文件不同。虽然启动文件(汇编)代码各有不同,但它们原理类似,都属于汇编程序。拿基于MDK-ARM的启动文件来举例,说一下要点内容。在基于MDK的启动文件开始,有一段汇编代码是分配堆栈大小的。

在这里插入图片描述
这里重点知道堆栈数值大小就行。还有一段AREA(区域),表示分配一段堆栈数据段。可以使用STM32CubeMX对上面的数值大小进行配置:
在这里插入图片描述
在IAR中,是通过工程配置堆栈大小:
在这里插入图片描述
看下面的汇编代码,程序上电之后,是跳到Reset_Handler这个位置。在这里插入图片描述
知道代码是从Reset_Handler开始执行,再来看如下Reset_Handler汇编代码。在启动的时候,执行了SystemInit这个函数。在这里插入图片描述
执行完SystemInit函数,初始化了系统时钟,之后跳转到main函数执行。
优质学习资料(免费):
STM32 几个G的资料分享 里面包含各种嵌入式,物联网,单片机的资料详解,项目实战,优秀竞赛作品等,点击即可免费领取http://makerschool.mikecrm.com/HmynTNs
在这里插入图片描述
学习交流群:881895560

以上是关于STM32 芯片启动过程分析求证的主要内容,如果未能解决你的问题,请参考以下文章

STM32代码的启动过程

stm32启动地址

stm32启动过程cortex-m3架构堆栈代码位置编译汇编链接分析

STM32F407 读保护,写保护,解锁过程芯片已设置读保护,无法读取更多信息

BSP视频教程STM32H7视频教程第4期:从启动到运行过程全解析,电源域,复位,时钟,软硬件启动流程到堆栈,map和htm文件分析(2022-01-26)

PCB---STM32最小系统制作过程