STM32中的BOOT0和BOOT1

2022-05-11 08:02:12 浏览数 (1)

STM32中的BOOT0和BOOT1是用来设置启动方式的。

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

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

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

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

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

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

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

当BOOT0和BOOT1均设置为逻辑1时,系统将从内置SRAM中启动。然后,我们需要在代码中设置正确的中断向量表位置。中断向量表通常被放置在用户程序的开始,所以flash中运行时,向量表位于 0x08000000处,而当代码被放置在SRAM中运行时,他的位置就成了0x20000000。在初始化NVIC时,我们可以放置如下代码,定义向量 表的位置

NVIC_SetVectorTable(0x20000000 , 0x0); 或 NVIC_SetVectorTable(0x80000000 , 0x0);(其中的地址需要看具体芯片,这是举一个例子)

STM32的FLASH分为主存储块和信息块。主存储块用于保存具体的程序代码和用户数据;信息块用于负责由STM32出厂时放置2KB的启动程序(Bootloader)和 512B的用户配置信息区。

0 人点赞