STM32的三种Boot模式及验证

一、三种BOOT模式介绍

  STM32的启动方式一般以存储器的类型来区分,如内部 FLASH 启动方式、内部SRAM 启动方式以及系统存储器启动方式。

1、用户闪存存储器(Main Flash memory)

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

  当芯片上电后采样到 BOOT0 引脚为低电平时, 0x00000000 和 0x00000004 地址被映射到内部 FLASH 的首地址 0x08000000 和 0x08000004。因此,内核离开复位状态后,读取内部 FLASH 的 0x08000000 地址空间存储的内容,赋值给栈指针 MSP,作为栈顶地址,再读取内部 FLASH 的 0x08000004 地址空间存储的内容,赋值给程序指PC,作为将要执行的第一条指令所在的地址。具备这两个条件后,内核就可以开始从 PC指向的地址中读取指令执行了。

2、SRAM存储器(Embedded Memory)

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

  当芯片上电后采样到 BOOT0 和 BOOT1 引脚均为高电平时,0x00000000和 0x00000004 地址被映射到内部 SRAM 的首地址 0x20000000 和 0x20000004,内核从SRAM 空间获取内容进行自举。

  在实际应用中,由启动文件 starttup_stm32f10x.s 决定了 0x00000000 和 0x00000004地址存储什么内容,链接时,由分散加载文件(sct)决定这些内容的绝对地址,即分配到内部 FLASH 还是内部 SRAM。

3、系统存储器(System memory)

  从系统存储器启动,这种模式启动的程序功能是由厂家设置的。一般来说,这种启动方式用的比较少。系统存储器是芯片内部一块特定的区域,STM32在出厂时,由ST在这个区域内部预置了一段BootLoader, 也就是我们常说的ISP程序, 这是一块ROM,出厂后无法修改。一般来说,我们选用这种启动模式时,是为了从串口下载程序,因为在厂家提供的BootLoader中,提供了串口下载程序的固件,可以通过这个BootLoader将程序下载到系统的Flash中。但是这个下载方式需要以下步骤:

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

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

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

二、实例验证

(一)用 DAP 仿真器下载程序

1、使用DAP仿真器与指南者开发板连接好接入电脑

2、打开博客:C/C++程序内存的各种变量存储区域及验证.使用的工程文件(USART1接发)
在这里插入图片描述
3、编译无误后进行配置,打开魔术棒
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
4、配置好后,烧录程序
在这里插入图片描述
烧录完成
在这里插入图片描述
5、查看程序运行结果
在这里插入图片描述

(二)用串口下载程序

1、安装 USB 转串口驱动
1)打开指南者资料找到USB转串口驱动CH340,点击安装
在这里插入图片描述
2)检查是否安装成功
在这里插入图片描述
2、用USB 线连接电脑和开发板的 USB 转串口接口,给开发板上电。(不用连接DAP)
3、开发板的BOOT0和BOOT1接地,RXD和TXD分别接PA9和PA10,如下图
在这里插入图片描述
4、开始下载
1)打开 mcuisp 软件,配置如下:
①搜索串口,设置波特率 115200(尽量不要设置的太高)
②选择要下载的 HEX 文件(就是刚刚的工程文件生成的HEX文件)
③校验、编程后执行
④DTR 低电平复位,RTS 高电平进入 bootloader
⑤开始编程。如果出现一直连接的情况,按一下开发板的复位键即可。
在这里插入图片描述
在这里插入图片描述
5、下载成功
在这里插入图片描述
6、查看结果
在这里插入图片描述

(三)总结

  用 DAP 仿真器下载程序采用了内部 FLASH 启动方式,打开串口之后,开发板和上位机直接就可以直接进行通信。
  用串口下载程序是采用了系统存储器启动方式,打开串口后,需要按一下复位键,才能够通信。

总结

以上就是STM32的三种BOOT模式介绍和其中内部 FLASH 启动方式(用户闪存存储器)、系统存储器启动方式的实例演示验证。

参考:

1、《零死角玩转STM32——F103指南者》
2、STM32三种BOOT模式介绍.

STM32WB55 Boot(启动过程)是一个关键的概念,涉及到如何从系统上电到运行应用程序之间的时间段内的操作系统初始化、内存映射等步骤。STM32WB55系列是微控制器(MCU),它是基于Arm Cortex-M4 和 Cortex-M0+内核,并集成了蓝牙低功耗和双模式Wi-Fi功能。 ### STM32WB55 Boot流程概述: 1. **复位操作**:当STM32WB55微控制器接通电源时,会触发硬件复位信号。这通常导致微控制器进入一个默认状态,所有寄存器都恢复到初始值。 2. **复位响应**:微处理器识别到复位请求并做出响应。此时,可能会发生一些内部配置操作,如设置CPU频率、时钟源等。 3. **加载Bootloader**:如果存在,则Bootloader会被加载到RAM中。Bootloader的主要任务是从非易失性存储(例如Flash ROM)读取程序,将程序加载到内存空间中,并准备执行它。STM32WB55支持多种Bootloader类型,包括标准的ARM CMSIS-DAP bootloader以及更复杂的应用程序特定的自定义Bootloader。 4. **验证程序完整性**:Bootloader通常会对固件镜像进行校验,检查其完整性是否满足预期的安全性和可靠性需求。这个过程可能涉及CRC计算、SHA哈希验证等技术。 5. **内存映射与初始化**:Bootloader会分配必要的内存区域,比如堆栈区、全局数据区、函数调用区等。同时,还会配置中断向量表,这是在中断处理期间用于跳转到适当中断服务程序的关键部分。 6. **程序加载与执行**:一旦内存布局和初始化完成,Bootloader就会将应用程序的二进制文件从Flash ROM加载到RAM中。接着,程序从预设的地址开始执行,通常是主函数的入口点。 7. **进入应用层**:一旦应用程序启动并运行,控制权就完全交给了应用代码。Bootloader的任务至此结束,微控制器将专注于执行用户的应用逻辑。 ### 相关问题 - 1. **STM32WB55 Bootloader的选择与配置**:如何选择合适的Bootloader版本,并对其进行正确的配置以适应特定的应用场景? 2. **优化STM32WB55 Boot过程**:有哪些策略可以提高Bootloader加载应用程序的速度? 3. **STM32WB55 Boot过程中的安全考虑**:在Boot过程中应采取哪些措施来保护系统的安全性,防止未经授权的访问或恶意软件的植入?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值