STM32 定时器有时一开启就进中断的话题 在用到STM32定时器的更新中断时,发现有些情形下只要开启定时器就立即进入一次中断。准确说,只要使能更新中断允许位就立即响应一次更新中断【当然前提是相关NVIC也已经配置好】。换言之,只要使能了相关定时器更新中断,不管你定时间隔多长甚至不在乎你是否启动了相关定时器,它都会立即进入一次定时器更新中断服务程序。
以STM32F051芯片为例,做了几种不同顺序的组合测试。根据测试发现,的确有些情况下一运行TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE); 【即使能更新中断】就立即进入更新中断服务程序。当然后面的中断都是正常的。
老实说,这个问题比较容易忽视,有些情况下也无关紧要,但有些情况可能会给应用带来困扰。从STMCU相关技术手册似乎并不能明显地找到关于这个问题的很合适或者逻辑性很强的前因后果。
经过验证测试,如果注意一下相关指令代码顺序是可以回避这个问题的。
先做更新中断标志的清除操作,即清除TIMx->SR寄存器里的UIF标志,然后做定时器更新中断的使能操作。至于开启相关定时器的指令摆放位置并不严格。下面是相关动作的操作顺序及结果,可以参考、验证之。这里共罗列了6种写法,其中有3种情形是会立即进入中断的,另外3种不会。 - IM_ClearITPendingBit(TIM1, TIM_IT_Update); //清除更新中断请求位
- TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE); //使能定时器1更新中断
- TIM_Cmd(TIM1, ENABLE); //启动定时器
复制代码
(1)不会立即进入更新中断程序。 - TIM_ClearITPendingBit(TIM1, TIM_IT_Update);//清除更新中断请求位
- TIM_Cmd(TIM1, ENABLE);
- TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);//使能定时器1更新中断
复制代码
(2)不会立即进入更新中断程序。 - TIM_Cmd(TIM1, ENABLE);
- TIM_ClearITPendingBit(TIM1, TIM_IT_Update);//清除更新中断请求位
- TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);//使能定时器1更新中断
复制代码
(3)不会立即进入更新中断程序。 - TIM_Cmd(TIM1, ENABLE);
- TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);//使能定时器1更新中断
- TIM_ClearITPendingBit(TIM1, TIM_IT_Update);//清除更新中断请求位
复制代码
(4)立即进入更新中断程序。 - TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);//使能定时器1更新中断
- TIM_ClearITPendingBit(TIM1, TIM_IT_Update);//清除更新中断请求位
- TIM_Cmd(TIM1, ENABLE);
复制代码
(5)立即进入更新中断程序。 - TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);//使能定时器1更新中断
- TIM_Cmd(TIM1, ENABLE);
- TIM_ClearITPendingBit(TIM1, TIM_IT_Update);//清除更新中断请求位
复制代码
(6)立即进入更新中断程序。 顺便提下关于定时器里UG位和URS位的使用,分别在TIMx->EGR和TIMx->CR1寄存器里。对UG位置1可以产生更新事件并对相关计数器和寄存器重新初始化,如果URS位为0的话,同时会产生更新中断。如果不希望对UG位置1的同时产生更新中断,得置URS位为1,否则会立即进入更新中断。 文章出处: 茶话MCU
|
大神您好,我遇到您说的问题,两天没解决。
上面这个库函数的操作结果是把定时器1的SR寄存器的第0位清0对吗?
。。。。。
TIM1_SR1=0x00; //清除状态寄存器;
TIM1_CR1=0x01; //使能计数器
TIM1_IER=0x01; //更新中断使能
前面是设置计时初值,按这个操作仍然是直接进中断而不经定时的。相当于你的操作组合的第一种。
如果您看到回复,麻烦指点下在下,感激不尽