
systick中断逻辑包括void SysTick_Handler(void)。
SysTick是arm处理器中一个24位的系统计时器,向下递减,主要用于系统节拍数的计算,stm32使用的也是arm的处理器,它的中断函数叫void SysTick_Handler(void)。
SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);//SysTick时钟源为AHB时钟除以8。
SysTick_SetReload(9000);//SysTick重装载值为9000。
SysTick_ITConfig(ENABLE);//使能SysTick中断。
NVIC_SystemHandlerPriorityConfig(SystemHandler_SysTick。
中断源识别
当系统中有多个中断源时,一旦有中断请求,CPU必须确定是哪一个中断源提出的中断请求,并由中断控制器给出中断服务子程序的入口地址,装入CS与IP/EIP两个寄存器。CPU转入相应的中断服务子程序开始执行。
主程序和中断服务子程序都要使用CPU内部寄存器等资源,为使中断处理程序不破坏主程序中寄存器的内容,应先将断点处各寄存器的内容压入堆栈保护起来,再进入的中断处理。现场保护是由用户使用PUSH指令来实现的。
中断服务函数和中断向量表对应起来了么,stm32的设计是tim1的不同中断单独不同的中断源,一定要看清楚了。同时自己编写的中断服务函数一定要和启动文件中定义的中断向量表对应起来。两者不一致则程序就会执行汇编文件中定义的默认服务函数,一个无限循环。做到这两点程序至少不会跑飞了。剩下的事情需要注意的是在中断服务函数中清楚中断源。欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)