
本帖最后由 james-351009 于 2014-12-13 16:33 编辑 最近在使用STM32F407的定时器,遇到一个诡异的问题。 我用TIM2做PWM波形输出,用了一个OC脚。中断的配置是只有更新事件产生中断。 在每个更新事件产生时,UIF位由硬件置位,系统进入中断例程。那么问题来了,在UIF没有置位的时候 也能进中断例程吗?这个现象是偶尔产生,而且这个中断是紧跟在正常更新中断例程之后产生的! 在中断使能寄存器里,我只使能了UIE位!而这个莫名其秒的中断,是怎么回事呢?! 下面是在进入那个中断时的寄存器截图: ![]() 只使能了 UIE ![]() ![]() ![]() 这是我加的监测程序,在中断例程的最前面,也没有检测UIF置位! 上面是中断时的寄存器截图 请各位大神以及STM32官方能给个说法!谢谢了! |
请教为什么中断回调函数中不能使用接收中断开启函数
bootloader占用的flash起始地址一般在哪,从0x08000000地址开始的flash能够被用户使用吗
如何使用window程序对控制参数进行调整。
PWM+DMA求助
STM32中比较适合做FOC控制的芯片
当有一外部信号(上升和下降沿触发),用timer计测脉冲间隔的问题,要给采用那种触发:ITRx、Gate、还是其它那种方式最好,响应最快,谢谢
ST的IMU和地磁计用motionfx库融合后航向角异常的问题
请问一下,F4硬件开发手册有最新版本吗?
stm32f407VGT6用freertos库一直进hardfault循环
stm32cubeide 中文乱码能解决吗
previously set by software. However trigger mode can set the CEN bit automatically by
hardware.
SMS:External Clock Mode 1 - Rising edges of the selected trigger (TRGI) clock the counter.
注意SMS设置为External Clock Mode 1以后,在开始的时候会产生一个触发事件,就是TRGI。
在注意TIF产生的来源:This flag is set by hardware on trigger event (active edge detected on TRGI input when the slave mode controller is enabled in all modes but gated mode. It is set when the counter starts or stops when gated mode is selected. It is cleared by software.
你把SMS的值修改以后,这个中断应该就不会产生了。楼主可以考虑修改为000,然后测试一下。
感谢大神显身。
TIM2中断例程相当于一个计数功能,在使用前配置好,开启中断,再使能TIM2。在计数没有达到预期之前,是不会使能和关闭中断的。上述现象是发生在这个过程中的,并未操作任何TIM2的寄存器。不知道我说明白没有
希望有更多大神关注啊!能提供线索者有奖
补充一下,这个中断的优先级是最高的,另外我也使用TIM3,TIM4无此现象,而TIM2唯一特殊的是32BIT的.
没有设置GATED模式。相同配置下TIM3,TIM4没有此问题出现。
上图中的TIF是触发了,但我没有使能相应的中断位,DIER中可以看到。
谢谢你的回复 ,配置在上面的图中都能看到的,你所关心的SMCR的值也有。
回头试试,但可能性不大,谢谢你的回复