STM32学习笔记---TIM_GetFlagStatus和TIM_GetITStatus两个固件库函数的区别

本文详细分析了STM32中TIM_GetFlagStatus和TIM_GetITStatus两个函数的区别。TIM_GetFlagStatus主要用于检查中断标志状态,而TIM_GetITStatus不仅检查中断标志,还会检查中断使能状态。在实际应用中,如触摸按键实验中,两者的使用会导致不同的中断处理行为。正确理解和使用这两个函数对于STM32的中断处理至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TIM_GetFlagStatus和TIM_GetITStatus两个函数的区别


最近结合正点原子基于STM32F103ZET6芯片开发板的触摸按键实验,在对TIM5_CH2捕获状态进行判断时发现利TIM_GetFlagStatus和TIM_GetITStatus两个函数会有不同效果。因此,重新检查了两个函数的定义区别,分享如下(如有理解不对的地方,望指正!!!)

首先是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中断请求
#define TIM_FLAG_CC2 ((uint16_t)0x0004)
在这里插入图片描述
而对于函数 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位的状态相与的结果;所以,大家在使用这两个函数时一定注意区分!!!!

<think>好的,我需要解释TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET这个函数的意义。首先,用户可能对STM32的定时器中断不太熟悉,所以要从基础开始讲。 先确定TIM_GetITStatus的作用。这个函数是用来检查特定定时器的某个中断标志是否被置位。参数TIM3表示定时器3,TIM_IT_Update指的是更新中断。当定时器溢出或计数器重新加载时,会触发这个中断。 接下来,比较结果是否不等于RESET。在STM32的标准库中,RESET通常定义为0,而SET为非0。所以,如果函数返回SET,说明中断标志被触发,需要处理。 然后,要说明这个表达式常见的应用场景,比如在中断服务函数中检查中断来源,处理更新事件,比如更新计数器、执行任务等。处理完后,必须清除中断标志,否则会不断进入中断。 需要注意可能的误区,比如中断标志可能在多个地方被触发,或者在处理前需要确认是否是预期的中断源。另外,不同系列的STM32库可能有细微差别,但整体逻辑一致。 最后,总结这个表达式的作用:检查TIM3的更新中断是否发生,是中断处理中的关键步骤。确保用户理解整个流程注意事项。</think>好的,我来逐步解释这个函数的含义作用: $$ \text{TIM\_GetITStatus(TIM3, TIM\_IT\_Update) != RESET} $$ 1. **基本组成解析** - **TIM3**:STM32微控制器的定时器3外设 - **TIM_IT_Update**:定时器更新中断类型 - **TIM_GetITStatus()**:STM32标准库中检查中断标志位的函数 2. **函数功能** - 这是STM32标准外设库中用于检查定时器中断状态的典型写法 - 具体作用:**检查TIM3定时器的"更新事件"中断是否被触发** - 当定时器计数器溢出(例如从ARR值归零时),会触发更新事件 3. **返回值逻辑** - 当`TIM_GetITStatus()`返回**SET**(非0)时,表示中断标志位置1 - `!= RESET`的判断相当于`== SET` - 整个表达式为真时,说明定时器更新中断已发生 4. **典型应用场景** ```c // 在TIM3的中断服务函数中 if(TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) { // 处理定时器溢出事件(例如:更新PWM参数、计时计数等) TIM_ClearITPendingBit(TIM3, TIM_IT_Update); // 必须清除中断标志 } ``` 5. **重要注意事项** - 中断标志检查必须**先于清除操作** - 更新事件可能由以下情况触发: - 计数器上溢/下溢 - 软件强制更新(TIM_GenerateEvent()) - 计数器被重新初始化 - 在高级定时器(TIM1/TIM8)中,更新事件的行为可能更复杂 6. **底层寄存器对应** 该函数实际检查的是TIMx->SR寄存器的第0位(UIF位): $$ \text{UIF} = \begin{cases} 1 & \text{更新事件发生} \\ 0 & \text{未发生更新事件} \end{cases} $$ 建议在使用时配合官方库文件`stm32fxxx_tim.h`中的定义理解,不同STM32系列(F1/F4/H7等)实现原理一致,但寄存器地址可能不同。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值