历史上的今天
今天是:2024年09月08日(星期日)
2020年09月08日 | stm32 boot0 boot1的启动方式
2020-09-08 来源:eefocus
STM32 三种启动模式对应的存储介质君是芯片内置的,它们是:
1.用户闪存 =芯片内置的Flash
2.SRAM=芯片内置的RAM区,就是内存了。
3.系统存储器=芯片内部一块特定的区域,芯片出厂时在这个区域预置了一段bootloader,就是同事的ISP升级程序,这个区域的内容在芯片出现后没偶人能够修改或拆除,即它是一个ROM;
在每个STM32 的芯片上都有两个管脚BOOT0和BOOT1,这两个管脚在芯片复位时电平状态决定了芯片复位后从哪个区域开始执行程序,BOOT1=X BOOT0=0 从用户闪存(flash)启动,这时正常模式 较多情况下使用这种模式BOOT1=1 BOOT0=1 从内置SRAM(内存)启动,这种模式可以用于调试BOOT1=0 BOOT0=1 从系统存储器启动, 这种可以用于调试
STM32引脚状态决定了用哪种方式启动,
Main Flash memory (flash启动) 是STM32内置的flash,一般我们使用JTAG或者SWD模式下载时,就是下载到这里面,启动后也直接从这启动程序。
System memory 从系统存储启动,这种模式启动的程序功能是有厂家设,一般很少使用,一般来说STM32在出厂是内置了一段bootloader,也就是我们常说的ISP程序,这是一块ROM,出厂后我发修改, 这种启动模式,是为了从串口下载程序,因为厂家提供BootLoader中,可以通过bootloader将程序下载到系统Flash中,Embedded Memory 内置SRAM,既然是SRAM,自然就没有程序存储的能力,这个模式一般用于程序调试 例如我们修改了代码一个小小地方,然后需要拆除整个flash,比较费时可以考虑这种启动方式
综合所述,我们将BOOT0和BOOT1通过一个100k的下拉电阻,直接接地。
STM32 启动过程:
STM32的内部闪存(flash)地址起始于0x08000000,一般情况下,程序文件就从地址开始写入,此外STM32是基于Cortex-M3内核的微控制器,其内部通过一张中断向量表来响应,此外,STM32是基于Cortex-M3内核的位控制器,其内部通过一张“中断向量表”来响应中断,程序启动后,首先从"中断向量表"取出复位中断向量执行复位中断程序完成启动,而这张"中断向量表"的起始地址是0x8000004,当中断来临,STM32的内部硬件机制会自动将PC指针定位到中断向量表处,并根据中断源取出对应的中断向量执行中断服务程序。
在图53.1.1,STM32 在复位后,先从0x08000004地址取出复位中断向量的地址,并跳转到复位中断服务程序,如题彪了(1)所示,在复位中断执行完后,会跳转到我们的
Main函数,如图(2)所示,而我们的main一般都是一个死循环,在main函数执行过程中,如果收到中断请求,此时STM32强制将PC指针指回中断向量表处,如图3所示,
然后,根据中断源进入相应的中断服务程序,如图标号4所示,在执行完中断服务以后,程序再次返回main函数执行,如图标号5所示

史海拾趣
|
现在是编码IC(TX)已经发射管编码输出,,并且接收管可以收到编码信号,,可是解码IC(RX)并未解码.,,如果发射和接收IC 的频率已经吻合,,可是仍然无法解码??请问怎么解决呢?… 查看全部问答> |
|
我现在做的串口通信,是发送数据到硬件,硬件响应,然后再返回响应的信息数据,但发回的数据有的时候是一行,有的时候是两或者三行,想问问各位高手,我怎么才能显示所有三行的数据,现在可以接收显示一行。谢谢!!… 查看全部问答> |
|
stm32的gpio的od模式上拉不到5V,只到2V左右,也没有高低电平的变化。上拉电阻1K,那个管脚是兼容5V的。谁用过stm32的od模式,解释一下。谢谢… 查看全部问答> |
|
1.怎样实现相位可调?是用硬件还是软件实现?如果是用软件的话是通过设计寄存器来实现吗,如果是用硬件的话应该用什么电路或者器件呢? 2.ad9850产生的信号的电流是多少?在网上没有查到,看ad9850的中文资料也没有说,题目要求是在1k欧姆的负载条 ...… 查看全部问答> |
|
本帖最后由 dontium 于 2015-1-23 11:36 编辑 在EEWORLD组织的“我爱模拟之——TI模拟博文深度阅读季”看到一篇关于去耦电容的文章《去耦电容器......是否真的有必要?》网址是deyisupport./blog/b/signalchain/archive/2013/09/17/51504.aspx 然 ...… 查看全部问答> |




