完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
[color=#333333 !important]STM32F4基于Cortex-M4。对于基于Cortex-M3/M4的芯片,复位后总是从0x00000000地址处,取主堆栈指针(MSP)的值,从0x00000004处,取出PC的初始值(这个值是复位向量),然后从这个值对应的地址处取指。
[color=#333333 !important] [color=#333333 !important]这两个值,就是中断向量表里的第一个和第二个表项的值。 [color=#333333 !important] [color=#333333 !important]在Cortex-M3/M4里,复位后默认中断向量表在0地址开始的位置。之后,可以通过修改VTOR寄存器的值,重定位中断向量表。在IAP的应用中,我们会遇到这种情况,如下图: [color=#333333 !important] [color=#333333 !important]上电复位,先执行IAP程序。此时用到的是位于0地址处的IAP程序的向量表(虽然图中说此时VTOR的值等于0x08000000,实际上,因为ST提供了存储器地址重映射的功能,通过boot引脚的配置,已经将0x08000000处的存储空间重映射到了地址0处,所以0x08000000和地址0x00000000处开始的存储空间是同一块物理空间,其内容当然也是一样的。所以不用修改VTOR的值,VTOR=0也是一样的)。言归正传,上电后,先从IAP复位中断程序开始执行IAP程序,执行完IAP程序后,需要跳转到用户程序,这时就需要将向量表重定位到用户程序的向量表位置(修改VTOR寄存器的值到用户向量表的起始地址)。 [color=#333333 !important]这是M3/M4的情况,STM32F7之前的所有芯片都是一样的。 [color=#333333 !important]STM32F7的复位序列 [color=#333333 !important]前面讲的那些情况,在STM32F7中就有些不一样了。在ARMCortex-M7的GenericUserGuide中,有一段如下描述:“Onsystemreset,thevectortableisattheaddressconfiguredatimplementation,typically0x00000000.”从这段话,我们可以看出,在M7中,复位后向量表的位置不是固定在0地址处,而是可以由各个芯片厂商自己定义。 [color=#333333 !important]对于STM32F7来说,它是由BOOT_ADD0[15:0]和BOOT_ADD1[15:0]这两个optionbytes决定的。 [color=#333333 !important] [color=#333333 !important]Boot脚=0时,由BOOT_ADD0[15:0]的值决定,ST默认值为0x00200000。这是ITCM-FLASH的起始地址(通过ART加速器,访问FLASH); [color=#333333 !important]Boot脚=1时,由BOOT_ADD1[15:0]的值决定,ST默认值为0x00100000。这是systemBootloader的起始地址。 [color=#333333 !important]*如果对BOOT_ADDx写入的地址值超出了存储器映射的范围或者到了保留地址空间,系统将自动转为下面的值: [color=#333333 !important]BOOT_ADD0=0x00200000; [color=#333333 !important]BOOT_ADD1=0x00000000(和出厂时ST默认的值0x00100000不一样) [color=#333333 !important]也就是说,只要你配置好了bootaddress,stm32F7芯片的硬件会自动修改向量表的偏移地址寄存器VTOR,使之与bootaddress相匹配。不需要再通过软件修改VTOR寄存器。 [color=#333333 !important]回到本文开始的那个问题。对于STM32F7来说,默认状态下,复位后它并不是从0地址开始执行,而是从0x00200000或者0x00100000开始执行,所以与ITCM-RAM从0地址处开始并不冲突。如果你非要将向量表放在0地址开始的位置(修改VTOR寄存器),也不是不可以。只是这是,如果你还要在ITCM-RAM里面跑别的程序的话,就要注意向量表不要与其他程序的地址重叠了。 |
|
|
|
只有小组成员才能发言,加入小组>>
692 浏览 0 评论
1106 浏览 1 评论
2473 浏览 5 评论
2808 浏览 9 评论
移植了freeRTOS到STMf103之后显示没有定义的原因?
2646 浏览 6 评论
使用eim外接fpga可是端口一点反应都没有有没有大哥指点一下啊
653浏览 9评论
649浏览 7评论
请教大神怎样去解决iMX6Q在linux3.0.35内核上做AP失败的问题呢
781浏览 6评论
628浏览 5评论
668浏览 5评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 00:55 , Processed in 1.084477 second(s), Total 77, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号