0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

STM32F4的复位序列对比STM32F7的复位序列

MCU开发加油站 来源:STM32单片机 作者:STM32单片机 2021-01-18 16:44 次阅读

前言

初次接触到STM32F7,可能会有个疑惑,为什么0地址变成了ITCM RAM的起始地址。系统复位还是从地址0处开始执行吗?如果是,那这似乎看起来是冲突的。实际上,STM32F7是基于Cortex-M7内核,而Cortex-M7和Cortex-M3/M4的复位序列有些不一样。本文中,将针对这个问题做详细讲解。

STM32F4的复位序列

STM32F4基于Cortex-M4。对于基于Cortex-M3/M4的芯片,复位后总是从0x00000000地址处,取主堆栈指针(MSP)的值,从0x00000004处,取出PC的初始值(这个值是复位向量),然后从这个值对应的地址处取指。

63291ee8-445e-11eb-8b86-12bb97331649.png

这两个值,就是中断向量表里的第一个和第二个表项的值。

6356b042-445e-11eb-8b86-12bb97331649.jpg

在Cortex-M3/M4里,复位后默认中断向量表在0地址开始的位置。之后,可以通过修改VTOR寄存器的值,重定位中断向量表。在IAP的应用中,我们会遇到这种情况,如下图:

6397fe76-445e-11eb-8b86-12bb97331649.jpg

上电复位,先执行IAP程序。此时用到的是位于0地址处的IAP程序的向量表(虽然图中说此时VTOR的值等于0x08000000,实际上,因为ST提供了存储器地址重映射的功能,通过boot引脚的配置,已经将0x08000000处的存储空间重映射到了地址0处,所以0x08000000和地址0x00000000处开始的存储空间是同一块物理空间,其内容当然也是一样的。所以不用修改VTOR的值,VTOR=0也是一样的)。言归正传,上电后,先从IAP复位中断程序开始执行IAP程序,执行完IAP程序后,需要跳转到用户程序,这时就需要将向量表重定位到用户程序的向量表位置(修改VTOR寄存器的值到用户向量表的起始地址)。

这是M3/M4的情况,STM32F7之前的所有芯片都是一样的。

STM32F7的复位序列 前面讲的那些情况,在STM32F7中就有些不一样了。在ARM Cortex-M7的Generic User Guide中,有一段如下描述: “On system reset, thevector table is at the address configured at implementation, typically0x00000000. ” 从这段话,我们可以看出,在M7中,复位后向量表的位置不是固定在0地址处,而是可以由各个芯片厂商自己定义。 对于STM32F7来说,它是由BOOT_ADD0[15:0]和BOOT_ADD1[15:0]这两个optionbytes决定的。

63c6e2d6-445e-11eb-8b86-12bb97331649.png

Boot 脚= 0时,由BOOT_ADD0 [15:0] 的值决定,ST默认值为0x0020 0000。这是ITCM-FLASH的起始地址(通过ART加速器,访问FLASH); Boot 脚= 1时,由BOOT_ADD1 [15:0] 的值决定,ST默认值为0x0010 0000。这是system Bootloader的起始地址。 * 如果对BOOT_ADDx写入的地址值超出了存储器映射的范围或者到了保留地址空间,系统将自动转为下面的值: BOOT_ADD0 = 0x0020 0000; BOOT_ADD1 = 0x0000 0000(和出厂时ST默认的值0x0010 0000不一样) 也就是说,只要你配置好了boot address, stm32F7芯片的硬件会自动修改向量表的偏移地址寄存器VTOR,使之与boot address相匹配。不需要再通过软件修改VTOR寄存器。

回到本文开始的那个问题。对于STM32F7来说,默认状态下,复位后它并不是从0地址开始执行,而是从0x0020 0000 或者0x0010 0000开始执行,所以与ITCM-RAM从0地址处开始并不冲突。如果你非要将向量表放在0地址开始的位置(修改VTOR寄存器),也不是不可以。只是这时,如果你还要在ITCM-RAM里面跑别的程序的话,就要注意向量表不要与其他程序的地址重叠了。

责任编辑:lq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 复位
    +关注

    关注

    0

    文章

    171

    浏览量

    24211
  • STM32F4
    +关注

    关注

    3

    文章

    194

    浏览量

    28046
  • STM32F7
    +关注

    关注

    1

    文章

    48

    浏览量

    8967

原文标题:STM32F7与STM32F4之复位序列比较

文章出处:【微信号:mcugeek,微信公众号:MCU开发加油站】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32F103×8/STM32F103×B MCU手册

    需要确定系统时钟源,如使用HSE或HSI,然后配置PLL倍增因子以获得所需的系统时钟频率。这通常通过修改RCC(复位与时钟控制)寄存器来完成,并可以在STM32CubeMX或标准外设库/HAL库中轻松设置。2. Q: 为什么STM32F
    发表于 11-18 15:14 0次下载

    STM32项目实战:基于STM32F4的智能灯光控制系统(LVGL),附项目教程/源码

    《智能灯光控制系统_STM32F4》项目完整文档、项目源码,私信小雯老师免费领取。STM32项目实战之“智能灯光控制系统”(基于STM32F4)今天小编来分享一个《智能灯光控制系统》的项目案例,硬件
    的头像 发表于 10-17 16:16 756次阅读
    <b class='flag-5'>STM32</b>项目实战:基于<b class='flag-5'>STM32F4</b>的智能灯光控制系统(LVGL),附项目教程/源码

    【GD32 MCU 移植教程】8、从 STM32F4xx 系列移植到 GD32F4xx 系

    GD32F4xx 系列 MCU 是基于 Arm® Cortex®-M4 处理器的 32 位通用微控制器,与 STM32F4xx系列 MCU 保持高度兼容。本文主要从以下三个方面进行介绍:硬件资源
    的头像 发表于 09-06 09:40 1243次阅读
    【GD32 MCU 移植教程】8、从 <b class='flag-5'>STM32F4</b>xx 系列移植到 GD32<b class='flag-5'>F4</b>xx 系

    STM32F40xxx、STM32F41xxx、STM32F42xxx、STM32F43xxx中文手册

    STM32F4系列单片机中文手册
    发表于 08-08 14:32 2次下载

    STM32复位电路用复位芯片和阻容复位电路区别

    STM32是一款广泛使用的微控制器,其复位电路设计对于系统的稳定性和可靠性至关重要。本文将详细介绍STM32复位电路中使用复位芯片和阻容
    的头像 发表于 08-06 10:26 1406次阅读

    请问stm32f 103复位复位时间可以设置多长?

    stm32f103复位复位时间可以设置多长??可以直接在复位脚直接加一个电容吗?
    发表于 07-04 08:27

    STM32F103xC,STM32F103xD,STM32F103xE中文资料

    电子发烧友网站提供《STM32F103xC,STM32F103xD,STM32F103xE中文资料.pdf》资料免费下载
    发表于 06-17 14:12 3次下载

    PDR_ON复位和NRST引脚复位,对STM32F407IG的影响有什么区别呢?

    新手请问大家在实际做工程的时候,有没有用PDR_ON引脚做芯片复位呢? PDR_ON复位和 NRST引脚复位,对芯片的影响有什么区别呢? 谢谢大家。 PS:我用的是STM32F407I
    发表于 05-16 07:21

    请问STM32F7 DISCOVERY是几层板?

    STM32F7 DISCOVERY 是几层板? 感觉硬件还是很稳定的。想自己做块F7的板子,双面板,能不能做到这种稳定程度呢?网上看到不少人自己画 板遇到SDRAM数据不稳定的
    发表于 05-09 07:40

    请问STM32F7系列可以录制视频吗?分辨率多少的?

    网上几乎没人用STM32的芯片来做录制视频的,请教一下各位高手STM32F7系列可以用做录制视频吗?
    发表于 05-09 06:06

    STM32F4STM32F7复位序列介绍

    内核,而Cortex-M7和Cortex-M3/M4复位序列有些不一样。本文中,将针对这个问题做详细讲解。 STM32F4
    发表于 04-08 07:05

    STM32F7开启读保护Level2后,还能擦除重新烧录程序吗?

    STM32F7开启读保护Level2之后,还能擦除重新烧录程序吗?
    发表于 04-01 07:38

    STM32F103RET6外部复位引脚,无法复位是什么情况?

    STM32F103RET6 外部复位引脚,无法复位,是什么情况? P.S.复位电路没有问题,可正常输出复位信号
    发表于 03-28 09:13

    有一个STM32F7的程序,如何实现到H7的移植?

    有一个STM32F7的程序,如何实现到H7的移植,平台式STM32CubeIDE
    发表于 03-22 07:09

    stm32复位电容容值

    STM32是意法半导体(STMicroelectronics)推出的一系列32位微控制器,具有低功耗、高性能和丰富的外设功能。在STM32微控制器中,复位电容是电路中的一个重要组成部分,用于保持系
    的头像 发表于 01-05 17:39 1751次阅读