TIM2CH1_CAPTURE_STA的通俗理解,分享下我的理解

2019-07-20 22:43发布

以下是输入捕获实验的理解


//定时器5中断服务程序  
void TIM2_IRQHandler(void)

/*第一个if很关键,最后看第三步:   
 捕获完成后 请问TIM2CH1_CAPTURE_STA第七位状态几何?我们的目的是什么?
 获取高电平时间后是不是要显示,显示后还需不需要再次捕获呢?
 捕获后 TIM2CH1_CAPTURE_STA为1,无法进行下列if判断,无法进入中断判断,
 故TIM2CH1_CAPTURE_STA=0需要清零,main函数有所体现。

 会有人问 if((TIM2CH1_CAPTURE_STA&0X80)==0)可不可以不要,我认为可以。
 原因每次捕获都是从上升沿开始再捕获下降沿,可以下降沿读取捕获值
 主函数中if(TIM2CH1_CAPTURE_STA&0X80)改为TIM2CH1_CAPTURE_STA&0x40即可
*/
  if((TIM2CH1_CAPTURE_STA&0X80)==0) //还未成功捕获
{  
/* 再看 第二步

从下面看:读取溢出标号,在捕获上升沿后,没来得及捕获下降沿时发生溢出。说明什么?
溢出必发生在高电平 IM2CH1_CAPTURE_STA&0X40表示已经捕获到高电平(上升沿阶段)。
来一次溢出,则(TIM2CH1_CAPTURE_STA&0X3F)++,表示溢出次数。
溢出超出了,怎么办?
TIM_APR 16位预装载值,即CNT>65536-1时溢出。 
0X3F个65536共4128768单位,约4128768/72=58ms 即最大值。 程序是不是就完了了?

没有,若超过最大值,不作处理则形成bug 。
(TIM2CH1_CAPTURE_STA&0X3F)++等于0x40 ,溢出数等于清0,结果有出现没发生溢出情况下的脉宽值TIM2CH1_CAPTURE_VAL
 所以必须做处理,可以做强制结束该次捕获,设为测量范围的最大值,超过就不准了,一杆秤最大只能称多重的一样,超过范围则无法使用。
 TIM2CH1_CAPTURE_VAL=0XFFFF;


*/

if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)
 
{    
if(TIM2CH1_CAPTURE_STA&0X40)//已经捕获到高电平了
{
if((TIM2CH1_CAPTURE_STA&0X3F)==0X3F)//高电平太长了
{
TIM2CH1_CAPTURE_STA|=0X80;//标记成功捕获了一次
TIM2CH1_CAPTURE_VAL=0XFFFF;
}else TIM2CH1_CAPTURE_STA++;
}  
}

/* 先看 第一步

从下面看:TIM2CH1_CAPTURE_STA=0 默认为0,TIM2_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; 
发生第一次捕获肯定是上升沿无疑,
进入中断程序 判断if(TIM2CH1_CAPTURE_STA&0X40) 第6位必为0,
也就是说第6位为0表示捕获上升沿,为了方便计数高电平,由高电平开始计数,即清零工作。
为了下次进中断程序 TIM2CH1_CAPTURE_STA第6位还为0,难道还捕获上升沿吗?
故TIM2CH1_CAPTURE_STA|=0X40,也就是说第6位为1表示准备捕获下升沿,标号没有
实际作用,接着用TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Falling)来体现第6位表示实际作用功能(0:上。1:下)。
至此,一次高电平完成,TIM2CH1_CAPTURE_STA|=0X80用第7位表示,完成的作用意义就是读取捕获值(高电平) 存放TIM2CH1_CAPTURE_VAL。
也就是说第7位的作用是读捕获值(0:不读。1:读)。
最后用TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Rising)来进入第2或第3等多次捕获跳转。

注意:这里用到了TIM2CH1_CAPTURE_STA第7位表示,读取捕获值 存放TIM2CH1_CAPTURE_VAL。这里的捕获没考虑溢出的情况
*/
if (TIM_GetITStatus(TIM2, TIM_IT_CC1) != RESET)//捕获1发生捕获事件
{
if(TIM2CH1_CAPTURE_STA&0X40) //捕获到一个下降沿
{  
TIM2CH1_CAPTURE_STA|=0X80; //标记成功捕获到一次上升沿
TIM2CH1_CAPTURE_VAL=TIM_GetCapture1(TIM2);
  TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Rising); //CC1P=0 设置为上升沿捕获
}else   //还未开始,第一次捕获上升沿
{
TIM2CH1_CAPTURE_STA=0; //清空
TIM2CH1_CAPTURE_VAL=0;
TIM_SetCounter(TIM2,0);
TIM2CH1_CAPTURE_STA|=0X40; //标记捕获到了上升沿
  TIM_OC1PolarityConfig(TIM2,TIM_ICPolarity_Falling); //CC1P=1 设置为下降沿捕获
}    
}           
  }
 
    TIM_ClearITPendingBit(TIM2, TIM_IT_CC1|TIM_IT_Update); //清除中断标志位
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
18条回答
chenshoubao
1楼-- · 2019-07-21 17:59
回复【3楼】正点原子:
---------------------------------
我有个不理解的地方,定义的TIM2CH1_CAPTURE_STA这个变量是如何作为寄存器使用的,如果有单片机里有一个固定的寄存器,捕捉到了自动置1,这样能理解。TIM2CH1_CAPTURE_STA直接与0x80来判断到底有没有捕捉。实在不能理解,能否指点下
chenshoubao
2楼-- · 2019-07-21 19:49
回复【5楼】正点原子:
---------------------------------
这个变量虽然被定义成了 一个寄存器。。但是我在中文参考手册里也找了,没有这个寄存器啊
正点原子
3楼-- · 2019-07-22 00:24
回复【9楼】chenshoubao:
---------------------------------
这就是个变量。。。。
Ldd69stm32
4楼-- · 2019-07-22 02:44
 精彩回答 2  元偷偷看……
Ldd69stm32
5楼-- · 2019-07-22 06:58
 精彩回答 2  元偷偷看……
OKQQ
6楼-- · 2019-07-22 12:16
其实为什么要除以72.。。

一周热门 更多>