定时器A捕获功能测脉冲宽度的问题

2019-07-14 14:07发布

MSP430F149 定时器A捕获功能测脉冲宽度 各位大神帮忙看看哪出了问题?

/****测脉冲宽度并用1602显示出来****/

#include <msp430x14x.h>
#include "cry1602.c"

#define  uint     unsigned int
#define  uchar    unsigned char

uint pwm_star,pwm_end;

uint width;

uint i=0;

uchar *s="The width is :";

uchar b[]={'0','1','2','3','4','5','6','7','8','9'};

uint m,n,p,q;

void main(void)

{
    WDTCTL=WDTPW+WDTHOLD;
   
    P6DIR |= BIT2;P6OUT |= BIT2;        //关闭电平转换
   
    P6DIR |= BIT3;P6OUT |= BIT3;        
   
    BCSCTL1 &= ~XT2OFF;                 //打开XT2高频晶体振荡器
    do
    {
        IFG1 &= ~OFIFG;                 //清除晶振失败标志
        for (i = 0xFF; i > 0; i--);     //等待8MHz晶体起振
    }
    while ((IFG1 & OFIFG));             //晶振失效标志仍然存在?
    BCSCTL2 |= SELM_2 + SELS;           //MCLK和SMCLK选择高频晶振
   
    P1DIR|=BIT2;
    P1SEL|=BIT2;   //捕获源为P1.2
   
    TACTL=TACLR;   //定时器清零
    TACTL |= TASSEL_2 + ID_3; //计数时钟选择SMLK=8MHz,1/8分频后为1MHz
   
    TACCTL1 =CM_3+SCS+CAP+CCIS_0+CCIE; //上升沿下降沿都同步捕获
      
    TACTL = MC_2; //定时器计数开始 连续计数模式
   
    _EINT();
   
    LcdReset();
   
    DispStr(0,0,s);     
     
   while(1)
    {           
   
     m=width/1000;
     n=(width/100)%10;
     p=(width/10)%10;
     q=width%10;
   
     Disp1Char(4,1,b[m]);
     Disp1Char(5,1,b[n]);
     Disp1Char(6,1,b[p]);
     Disp1Char(7,1,b[q]);
     
    }
}
   
/******定时器TA的CCR1的中断 用于检测脉冲上升沿和下降沿******/

#pragma vector=TIMERA1_VECTOR
__interrupt void Timer_A1(void)
{
  switch(TAIV)
  { case 0x02:
            if(CCI==1)
            {
              pwm_star = TACCR1;
              break;
            }
            else
            {
              pwm_end = TACCR1;
              break;
            }
         
         default:
            break;
  }
  
  width = pwm_end-pwm_star;
   
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
9条回答
lefeng
1楼-- · 2019-07-15 14:13
参考一下
#pragma vector = TIMER0_A1_VECTOR
__interrupt void TIMER0_A1_ISR (void)
{
  switch(__even_in_range(TA0IV,0x0A))
  {
      case  TA0IV_NONE: break;              // Vector  0:  No interrupt
      case  TA0IV_TACCR1:                   // Vector  2:  TACCR1 CCIFG
        if (TA0CCTL1 & CCI)                 // Capture Input Pin Status
        {
            // Rising Edge was captured
            if (!Count)
            {
                REdge1 = TA0CCR1;
                Count++;
            }
            else
            {
                REdge2 = TA0CCR1;
                Count=0x0;
                __bic_SR_register_on_exit(LPM0_bits + GIE);  // Exit LPM0 on return to main
            }

            if (First_Time)
                First_Time = 0x0;
        }
        else
        {
            // Falling Edge was captured
            if(!First_Time)
            {
                FEdge = TA0CCR1;
            }
        }
        break;
      case TA0IV_TACCR2: break;             // Vector  4:  TACCR2 CCIFG
      case TA0IV_6: break;                  // Vector  6:  Reserved CCIFG
      case TA0IV_8: break;                  // Vector  8:  Reserved CCIFG
      case TA0IV_TAIFG: break;              // Vector 10:  TAIFG
      default:         break;
  }
}
CaLipton
2楼-- · 2019-07-15 19:32
 精彩回答 2  元偷偷看……
Rospiers
3楼-- · 2019-07-15 19:58
我觉得楼主这段程序好像并没有计脉冲数啊~最近也在用1602显示频率数

一周热门 更多>