OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4107|回复: 1

有关STM32F427定时器的问题

[复制链接]

3

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
96
金钱
96
注册时间
2016-10-17
在线时间
26 小时
发表于 2017-8-17 11:49:14 | 显示全部楼层 |阅读模式
1金钱
在配置STM32F4定时器4的是的时候我打开了溢出中断,关闭了捕获中断,如下图:
)NLMK$HAAB8J2_QZGNGY.png
       打开硬件仿真后,查看TIM4->DIER寄存器,显示是0X00000001,也就是说只使能了定时器4溢出中断。当定时器4计数溢出后,定时器4的状态寄存器SR寄存器最低位置1,然后进入定时器4中断。
       但是硬件仿真发现SR寄存器一直都是0X001F,真个真的很奇怪。
41Y`QE_XUH[4K2O2~J2SWR0.png
       当我进入中断读取SR寄存器后发现不止有溢出中断进入了定时器4中断,还有其他的中断被触发了。
CU9HJD0EUUC`)QV6@UL6D0M.png
       于是我在定时器4中断里加了如下代码,在定时器4中断里读取SR寄存器的值,然后用printf函数把Counter值发回到串口助手。
       当我注释下面那句Counter2 = TIM4->SR;,如上图所示。串口助手显示Counter2值为0X0030,二进制也就是0001 1110.
       当我注释上面那句Counter2 = TIM4->SR;,                 串口助手显示Counter2值为0X0031,二进制也就是0001 1111.

       这个问题让我百思不得其解,按道理说不应该只有溢出中断会进入定时器中断吗?为什么SR寄存器的四个捕获中断位一直是1呢,求解。



正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
96
金钱
96
注册时间
2016-10-17
在线时间
26 小时
 楼主| 发表于 2017-8-17 21:13:09 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-19 01:10

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表