首先是TIM_GetFlagStatus()
FlagStatus TIM_GetFlagStatus(TIM_TypeDef* TIMx, uint16_t TIM_FLAG)
{
ITStatus bitstatus = RESET;
/* Check the parameters */
assert_param(IS_TIM_ALL_PERIPH(TIMx));//参量定时器TIMx
assert_param(IS_TIM_GET_FLAG(TIM_FLAG));//参量中断类型
if ((TIMx->SR & TIM_FLAG) != (uint16_t)RESET)
{
bitstatus = SET;
}
else
{
bitstatus = RESET;
}
return bitstatus;
}
根据上面定义,该函数输入变量分别为定时器TIMx(x=1-17)和中断类型TIM_FLAG(其实际上是一个16进制的数),该函数是对SR寄存器进行操作,并返回 bitstatus 的值
比如TIM_GetFlagStatus(TIM5,TIM_FLAG_CC2),实际上是读取的SR寄存器的第2位的状态,即判断是否发生了TIM_FLAG_CC2中断请求
而对于函数 TIM_GetITStatus()
ITStatus TIM_GetITStatus(TIM_TypeDef* TIMx, uint16_t TIM_IT)
{
ITStatus bitstatus = RESET;
uint16_t itstatus = 0x0, itenable = 0x0;
/* Check the parameters */
assert_param(IS_TIM_ALL_PERIPH(TIMx));
assert_param(IS_TIM_GET_IT(TIM_IT));
itstatus = TIMx->SR & TIM_IT;
itenable = TIMx->DIER & TIM_IT;
if ((itstatus != (uint16_t)RESET) && (itenable != (uint16_t)RESET))
{
bitstatus = SET;
}
else
{
bitstatus = RESET;
}
return bitstatus;
}
根据上面定义,该函数输入变量分别为定时器TIMx(x=1-17)和中断类型TIM_IT(其实际上是一个16进制的数),该函数是同时对SR寄存器和DIER寄存器进行操作,并返回 bitstatus 的值
比如TIM_GetFlagStatus(TIM5,TIM_IT_CC2),实际上是读取的SR寄存器的第2位的状态和DIER寄存器第2位的状态,即判断是否发生了TIM_IT_CC2中断请求,并且是否响应(使能)了该中断请求
以我在触摸按键实验中的例子来说:
u16 GetState_Value()
{
Tpad_Init();
TIM5_CH2_Cap_Init(5,0xffff);
while(TIM_GetFlagStatus(TIM5,TIM_FLAG_CC2)==RESET)//语句1
//while(TIM_GetITStatus(TIM5,TIM_IT_CC2)==RESET)//语句2
{
if(TIM_GetCounter(TIM5)>0xffff-500)
return TIM_GetCounter(TIM5); };
return TIM_GetCapture2(TIM5);
}
采用语句1判断时:当定时器5发生捕获中断时,就返回捕获比较值;否则一直等待捕获,直到计数值>0xffff-500,发生了溢出,返回此时的计数值;而采用语句2判断时:当定时器5发生捕获中断并响应中断,就返回捕获比较值;否则一直计数,直到计数值>0xffff-500,发生了溢出,返回此时的计数值,由于响应中断必然之前已经出现了中断标志位置1,所以while(TIM_GetITStatus(TIM5,TIM_IT_CC2)==RESET)这句相当于读取的SR寄存器的第2位的状态和DIER寄存器第2位的状态相与的结果;所以,大家在使用这两个函数时一定注意区分!!!!
版权声明:本文为CSDN博主「小重拌豆腐」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_41535111/article/details/118187546
暂无评论