在STM32F103等Cortex-m3/m4内核的单片机上可以通过设置SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET;该寄存器的值来实现中断向量表的重定义。
关于Cortex M3/M4中断向量表重映射问题会单独一篇文章详细介绍,此篇主要讲解关于M0的,要问为什么要做中断向量表重映射也会单独一篇文章详细介绍。
与M3/M4不同的是在STM32F0xx系列以Cortex-m0为内核的单片机中却怎么也找不到这个设置中断向量表的寄存器,可是在ST提供的固件库里,我却没有发现类似于stm32f10x固件库中的
voidNVIC_SetVectorTable(uint32_t NVIC_VectTab, uint32_t Offset)
接口,浏览了一下Cortex-M0的Programmingmanual,原来M0并没有SCB->VTOR这个寄存器,难怪ST的库里没有提供NVIC_SetVectorTable这个接口。
通过查阅 Reference manual文档(RM0360)中找到以下说明:
image可以通过以下方法来实现中断向量表重定义。
基本思想:
1、将中断向量表放入到RAM的起始地址(只需要在应用程序中保留RAM起始地址的0x100大小不使用即可)。
2、在Bootloader中将应用程序的中断向量表从Flash中拷贝到RAM中。
3、设置STM32F0xx中断向量表位于RAM中,主要用到的寄存器如下:
具体实现代码如下:
/** Function: void JumpToApp(void)
* Parameter: none
* Return: none*/staticvoidJumpToApp(void)
{
ApplicationAddress=APP_FLASHADDR;
if(((*(uint32_t*)ApplicationAddress) &0x2FFE0000) ==0x20000000)
{
/*Jump to user application*/
m_JumpAddress= *(uint32_t*) (ApplicationAddress +4);
/*最开头4个字节存放MSP的初始值,从这之后的4个字节存放ResetHandler中断向量*/
JumpToApplication=(FunVoidType) m_JumpAddress;
/*Initialize user application's Stack Pointer*/
__set_MSP(*(uint32_t*) ApplicationAddress);
JumpToApplication();
}
}
/** Function: void clock_init(void)
* Parameter: none
* Return: none*/
intmain(void)
{
memcpy((void*)0x20000000, (void*)APP_FLASHADDR,0x100);
SYSCFG->CFGR1 |=0x03;
JumpToApp();while(1);
}
微信公众号:嵌入式大玩家
更多精彩文章我将第一时间在微信公众号里面分享,如果不想错过,可以关注我的微信公众号。
本着免费分享的原则,方便大家手机学习知识,定期在微信平台分享技术知识。如果觉得文章的内容对你有用,又想了解更多相关的文章,请用微信搜索“嵌入式大玩家” 或者扫描下面二维码、关注,将有更多精彩内容等着你。
image
网友评论