在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)中找到以下说明:
可以通过以下方法来实现中断向量表重定义。
基本思想:
1、将中断向量表放入到RAM的起始地址(只需要在应用程序中保留RAM起始地址的0x100大小不使用即可)。
2、在Bootloader中将应用程序的中断向量表从Flash中拷贝到RAM中。
3、设置STM32F0xx中断向量表位于RAM中,主要用到的寄存器如下:
具体实现代码如下:
/* * Function: void JumpToApp(void) * Parameter: none * Return: none */ static void JumpToApp(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 */ int main(void) { memcpy((void*)0x20000000, (void*)APP_FLASHADDR, 0x100); SYSCFG->CFGR1 |= 0x03; JumpToApp(); while (1); }
微信公众号:嵌入式大玩家
更多精彩文章我将第一时间在微信公众号里面分享,如果不想错过,可以关注我的微信公众号。
本着免费分享的原则,方便大家手机学习知识,定期在微信平台分享技术知识。如果觉得文章的内容对你有用,又想了解更多相关的文章,请用微信搜索“嵌入式大玩家” 或者扫描下面二维码、关注,将有更多精彩内容等着你。