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

2019-03-24 08:24发布

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

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

  4. #define  uint     unsigned int
  5. #define  uchar    unsigned char

  6. uint pwm_star,pwm_end;

  7. uint width;

  8. uint i=0;

  9. uchar *s="The width is :";

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

  11. uint m,n,p,q;

  12. void main(void)

  13. {
  14.     WDTCTL=WDTPW+WDTHOLD;
  15.    
  16.     P6DIR |= BIT2;P6OUT |= BIT2;        //关闭电平转换
  17.    
  18.     P6DIR |= BIT3;P6OUT |= BIT3;        
  19.    
  20.     BCSCTL1 &= ~XT2OFF;                 //打开XT2高频晶体振荡器
  21.     do
  22.     {
  23.         IFG1 &= ~OFIFG;                 //清除晶振失败标志
  24.         for (i = 0xFF; i > 0; i--);     //等待8MHz晶体起振
  25.     }
  26.     while ((IFG1 & OFIFG));             //晶振失效标志仍然存在?
  27.     BCSCTL2 |= SELM_2 + SELS;           //MCLK和SMCLK选择高频晶振
  28.    
  29.     P1DIR|=BIT2;
  30.     P1SEL|=BIT2;   //捕获源为P1.2
  31.    
  32.     TACTL=TACLR;   //定时器清零
  33.     TACTL |= TASSEL_2 + ID_3; //计数时钟选择SMLK=8MHz,1/8分频后为1MHz
  34.    
  35.     TACCTL1 =CM_3+SCS+CAP+CCIS_0+CCIE; //上升沿下降沿都同步捕获
  36.       
  37.     TACTL = MC_2; //定时器计数开始 连续计数模式
  38.    
  39.     _EINT();
  40.    
  41.     LcdReset();
  42.    
  43.     DispStr(0,0,s);     
  44.      
  45.    while(1)
  46.     {           
  47.    
  48.      m=width/1000;
  49.      n=(width/100)%10;
  50.      p=(width/10)%10;
  51.      q=width%10;
  52.    
  53.      Disp1Char(4,1,b[m]);
  54.      Disp1Char(5,1,b[n]);
  55.      Disp1Char(6,1,b[p]);
  56.      Disp1Char(7,1,b[q]);
  57.      
  58.     }
  59. }
  60.    
  61. /******定时器TA的CCR1的中断 用于检测脉冲上升沿和下降沿******/

  62. #pragma vector=TIMERA1_VECTOR
  63. __interrupt void Timer_A1(void)
  64. {
  65.   switch(TAIV)
  66.   { case 0x02:
  67.             if(CCI==1)
  68.             {
  69.               pwm_star = TACCR1;
  70.               break;
  71.             }
  72.             else
  73.             {
  74.               pwm_end = TACCR1;
  75.               break;
  76.             }
  77.          
  78.          default:
  79.             break;
  80.   }
  81.   
  82.   width = pwm_end-pwm_star;
  83.    
  84. }
复制代码 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
11条回答
ywlzh
2019-03-25 07:44
qignsi2015 发表于 2015-8-6 15:37
好吧,谢谢 我试试

我刚才看了下,你编程现在没有个好的习惯,一个好的编程习惯可以省去很多麻烦,我给你找了个例程:
#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;
  }
}

你看看是不是一看就很清晰,哪个向量,到底是哪个引起的中断,一看就知道,调试就很方便

一周热门 更多>

相关问题

    相关文章