stm32F1 SCB->VTOR开机默认是0,如何理解?

STM32F1在SystemInit函数中默认SCB->VTOR为0,这是因为Cortex-M3内核在复位后从0x00000000启动,而STM32通过BOOT管脚状态进行地址映射。在Flash启动模式下,0x08000000被映射到0x00000000,使得两者等价。因此,即使SCB->VTOR设置为0,程序仍能正常运行。在IAP设计中,可能需要在app程序中设置SCB->VTOR,以确保正确切换到新的应用程序地址。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.使用stm32cubemx生成新的f1工程,SystemInit函数中默认没有设置SCB->VTOR,则SCB->VTOR默认为0,程序正常运行。
2.在设计IAP的时候,为社么在app程序中需要设置SCB->VTOR,而bootloader中不需要?
3.程序的SCB->VTOR = 0x0800 0000 | offset;
4.那么对于bootloader来说,只是offset = 0而已,为什么连0x0800 0000都可以不设了呢?
5.想请教各位大佬,这个应该怎么理解?


答:

ARM Cortex-M3内核永远从0x00000000启动,STM32在这里取了个巧,它在0x00000000开始的一段地址空间是虚拟的,可以通过设置BOOT[1:0]管脚状态,在启动时动态将另外一段地址空间映射到这部分上面去。
当arm复位之后,读到的0x00000000内容已经是被STM32重映射之后的了,所以它可以system boot模式启动、还是Flash启动、还是内存启动。
如果是正常的Flash启动,则会将0x08000000映射到0x00000000,因此arm以为自己还在操作0x00000000,其实是在操作0x08000000,已经被STM32偷梁换柱了,当然,此时直接操作0x08000000也是可以的,二者完全等价。

因此,SCB->VTOR保持为0x00000000完全没有任何问题。

原文:http://www.openedv.com/forum.php?mod=viewthread&tid=320947&extra=page%3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值