430捕获模式求助

2019-03-24 14:32发布

#pragma vector=TIMERB0_VECTOR        
__interrupt void TimerB0(void)
{
    if(TBCCTL0&CM1)                        //捕获到下降沿
    {
        TBCTL|=TBCLR;
        TBCCTL0=(TBCCTL0&(~CM1))|CM0;    //改为上升沿捕获:CM1置零,CM0置一
    }
    else if(TBCCTL0&CM0)                    //捕获到上升沿
    {
        width[i++]=TBCCR0;                  //记录下结束时间
        TBCCTL0=(TBCCTL0&(~CM0))|CM1;   //改为下降沿捕获:CM0置零,CM1置一
        if(i==32)
        {
            AverageTB0 = 0;
            for(i = 0; i < 32; i++)
            AverageTB0 += width;
            AverageTB0 >>= 5;     //除以32求平均值,以免数据不停跳变
            i=0;
        }
    }
   
}
在改变上升沿捕获还是下降沿捕获的时候,为什么是设置CM1和CM0,而不是CM1和CM2呢 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
wstt
2019-03-25 10:09
原帖由 浅影月居 于 2012-4-23 20:32 发表 如果是这样的话,CM0和CM1不就是指停止捕获和上升沿捕获了么?那怎么改变成下降沿捕获?
对不起,是我没有领会到你的意思。#define CM_0                (0*0x4000u) /* Capture mode: 0 - disabled */#define CM_1                (1*0x4000u) /* Capture mode: 1 - pos. edge */#define CM_2                (2*0x4000u) /* Capture mode: 1 - neg. edge */#define CM_3                (3*0x4000u) /* Capture mode: 1 - both edges */这是IAR的一段定义,对CM0和CM1寄存器的赋值有四个,如上所示对应下面四种状态CMx Bit15-14Capture mode00 No capture01 Capture on rising edge10 Capture on falling edge11 Capture on both rising and falling edges这样解释你看能理解

一周热门 更多>

相关问题

    相关文章