標(biāo)題: MSP430單片機(jī)定時(shí)器TA中斷 程序 [打印本頁]

作者: 51hei單片    時(shí)間: 2016-3-14 19:00
標(biāo)題: MSP430單片機(jī)定時(shí)器TA中斷 程序
本程序是《MSP430系列單片機(jī)系統(tǒng)工程設(shè)計(jì)與實(shí)踐》書里面的源碼,(包含工程文件 (例2.8.20)))完整例程下載:http://www.torrancerestoration.com/bbs/dpj-46245-1.html

關(guān)于本程序的詳細(xì)解說大家可以下載電子書點(diǎn)擊上圖即可
原書一共有4個(gè)程序
程序1

  1. #include  <msp430x41x.h>
  2. void main(void)
  3. {
  4.   WDTCTL = WDTPW + WDTHOLD;                       // 停止看門狗
  5.   FLL_CTL0 |= XCAP18PF;                         // 配置晶振負(fù)載電容
  6.   P1DIR |= BIT3;                                  // 設(shè)置P1.3為輸出腳
  7.   TACCTL0 |= CCIE;                                // 允許比較/捕獲模塊0的中斷
  8.   TACCR0 = 3277-1;                                //100ms約3277個(gè)ACLK周期
  9.   TACTL = TASSEL_1 + MC_1;                      //TA設(shè)為增計(jì)數(shù)模式,時(shí)鐘=ACLK
  10.   _EINT();
  11.   LPM3;
  12. }

  13. #pragma vector=TIMERA0_VECTOR
  14. __interrupt void TACCR0_ISR (void)              // 計(jì)至TACCR0中斷
  15. {
  16.     P1OUT ^= BIT3;                              // P1.3取反
  17. }
復(fù)制代碼

程序2
  1. #include  <msp430x41x.h>
  2. void main(void)
  3. {
  4.   WDTCTL = WDTPW + WDTHOLD;                    // 停止看門狗
  5.   FLL_CTL0 |= XCAP18PF;                 // 配置晶振負(fù)載電容
  6.   P1DIR |= BIT3+BIT1+BIT4;              // 設(shè)置P1.3、P1.1、P1.4為輸出腳

  7.   TACCR0 = 32768-1;                        // 1秒=32768個(gè)ACLK周期
  8.   TACCR1 = 6554-1;                        // 0.2秒=6554個(gè)ACLK周期
  9.   TACCR2 = 29938-1;                        // 0.7秒=29938個(gè)ACLK周期  
  10.   TACTL = TASSEL_1 + MC_1;              // TA設(shè)為增計(jì)數(shù)模式,時(shí)鐘=ACLK
  11.   TACTL |= TAIE;                        // 允許TA溢出中斷
  12.   TACCTL1 |= CCIE;                      // 允許比較/捕獲模塊1的中斷
  13.   TACCTL2 |= CCIE;                      // 允許比較/捕獲模塊2的中斷   
  14.   _EINT();
  15.   while(1)
  16.   {
  17.      //                                 CPU可以執(zhí)行其他任務(wù)
  18.   }
  19. }

  20. #pragma vector=TIMERA1_VECTOR
  21. __interrupt void TA_ISR(void)
  22. {
  23.   switch( TAIV )
  24.   {
  25.     case  2:    P1OUT &=~( BIT3+BIT1+BIT4);           
  26.                 P1OUT |= BIT1;           //TACCR1~TACCR2階段只亮綠燈
  27.                 break;
  28.     case  4:    P1OUT &=~( BIT3+BIT1+BIT4);           
  29.                 P1OUT |= BIT4;           //TACCR2~0階段只亮藍(lán)燈
  30.                 break;                          
  31.     case 10:    P1OUT &=~( BIT3+BIT1+BIT4);           
  32.                 P1OUT |= BIT3;           //0~TACCR1階段只亮紅燈
  33.                 break;
  34.   }
  35. }
復(fù)制代碼

程序3
  1. #include  <msp430x41x.h>
  2. void main(void)
  3. {
  4.   WDTCTL = WDTPW + WDTHOLD;                    // 停止看門狗
  5.   FLL_CTL0 |= XCAP18PF;                 // 配置晶振負(fù)載電容
  6.   P1DIR |= BIT3 + BIT4;                      // 設(shè)置P1.3、P1.4為輸出腳
  7.   TACTL |= MC_1 + TASSEL_1 + ID_0; //定時(shí)器TA設(shè)為增量計(jì)數(shù)模式,ACLK
  8.   TACCR0=328-1;               //PWM總周期 =328個(gè)ACLK周期約等于100Hz
  9.   TACCR1=246;                //TA1占空比 = 246/328= 75%
  10.   TACCR2=164;                //TA2占空比 = 164/328= 50%
  11.   TACTL |= TAIE;                                // 允許TA溢出中斷
  12.   TACCTL1 |= CCIE;                              // 允許比較/捕獲模塊1的中斷
  13.   TACCTL2 |= CCIE;                              // 允許比較/捕獲模塊2的中斷   
  14.   _EINT();
  15.   while(1)
  16.   {
  17.      //... ...                                         // CPU可以執(zhí)行其他任務(wù)
  18.   }
  19. }
  20. #pragma vector=TIMERA1_VECTOR
  21. __interrupt void TA_ISR(void)
  22. {
  23.   switch( TAIV )
  24.   {
  25.     case  2:    P1OUT &=~ BIT3;                   //計(jì)至TACCR1,P1.3置低
  26.                 break;
  27.     case  4:    P1OUT &=~ BIT4;                   //計(jì)至TACCR2,P1.4置低
  28.                 break;                          
  29.     case 10:    P1OUT |=( BIT3 + BIT4);        //計(jì)至TACCR0,置高
  30.                 break;
  31.   }
  32. }
復(fù)制代碼

程序4
  1. #include  <msp430x41x.h>
  2. int Result;
  3. int TA_OverflowCnt;                        //TA溢出次數(shù)存放變量
  4. unsigned long int ExeTime;                //執(zhí)行時(shí)間存放變量
  5. /****************************************************************
  6. 運(yùn)行時(shí)間待測(cè)函數(shù)1:求兩個(gè)浮點(diǎn)數(shù)之和
  7. ****************************************************************/
  8. float FloatSum(float x ,float y)  /*226個(gè)指令周期*/
  9. {
  10.   return(x+y);
  11. }
  12. /****************************************************************
  13.                      運(yùn)行時(shí)間待測(cè)函數(shù)2:求兩個(gè)定點(diǎn)數(shù)之和
  14. ****************************************************************/
  15. int IntSum(int x ,int y)          /*17個(gè)指令周期*/
  16. {
  17.   return(x+y);
  18. }
  19. /****************************************************************
  20.                      運(yùn)行時(shí)間待測(cè)函數(shù)3: 軟件延時(shí)
  21. ****************************************************************/
  22. void Delay()                          /*774030個(gè)指令周期*/
  23. {  int i,j;
  24.    for(i=0;i<1234;i++)
  25.    {
  26.      for(j=0;j<123;j++);
  27.    }
  28. }

  29. void main(void)
  30. {

  31.   WDTCTL = WDTPW + WDTHOLD;                            // 停止看門狗
  32.   FLL_CTL0 |= XCAP18PF;                         // 配置晶振負(fù)載電容
  33.   _EINT();                                              // 總中斷允許
  34.   while(1)
  35.   {
  36. //-------------------------測(cè)量定時(shí)器的固有延遲-------------------------
  37.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計(jì)時(shí)   
  38.     TACTL = TASSEL_2 + MC_0;            // TA停止計(jì)時(shí)
  39.     ExeTime=TAR;                        // 讀取TA計(jì)數(shù)值,就是固有延遲時(shí)間
  40.     _NOP();                                // 在這一行設(shè)斷點(diǎn)觀察
  41. //-----------------------測(cè)量浮點(diǎn)求和函數(shù)的執(zhí)行時(shí)間----------------------
  42.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計(jì)時(shí)   
  43.     Result=FloatSum(12345 ,12456);                // 執(zhí)行待測(cè)函數(shù)1
  44.     TACTL = TASSEL_2 + MC_0;                           // TA停止計(jì)時(shí)
  45.     ExeTime=TAR;                                // 讀取TA計(jì)數(shù)值,就是執(zhí)行時(shí)間
  46.     _NOP();                                        // 在這一行設(shè)斷點(diǎn)觀察
  47. //-----------------------測(cè)量定點(diǎn)求和函數(shù)的執(zhí)行時(shí)間-------------------
  48.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計(jì)時(shí)
  49.     Result= IntSum(12345 ,12456);        // 執(zhí)行待測(cè)函數(shù)2
  50.     TACTL = TASSEL_2 + MC_0;            // TA停止計(jì)時(shí)   
  51.     ExeTime=TAR;                        // 讀取TA計(jì)數(shù)值,就是執(zhí)行時(shí)間
  52.     _NOP();                                // 在這一行設(shè)斷點(diǎn)觀察
  53. //----------------------測(cè)量延遲和函數(shù)的執(zhí)行時(shí)間--------------------
  54.     TA_OverflowCnt=0;        // 長執(zhí)行時(shí)間函數(shù)TA會(huì)溢出,用一變量計(jì)數(shù)溢出次數(shù)
  55.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR;     // TA清零并開始計(jì)時(shí)
  56.     Delay();                                        // 執(zhí)行待測(cè)函數(shù)3
  57.     TACTL = TASSEL_2 + MC_0;                    // TA停止計(jì)時(shí)   
  58.     ExeTime=TA_OverflowCnt*65536+TAR; // 讀取TA計(jì)數(shù)值及溢出次數(shù),計(jì)算執(zhí)行時(shí)間
  59.     _NOP();                                  // 在這一行設(shè)斷點(diǎn)觀察
  60.   }
  61. }
  62. #pragma vector=TIMERA1_VECTOR
  63. __interrupt void TA_ISR(void)
  64. {
  65.   switch( TAIV )
  66.   {
  67.     case  2:   break;
  68.     case  4:   break;                          
  69.     case 10:  TA_OverflowCnt++;                //TA每次溢出,溢出次數(shù)變量+1
  70.                 break;
  71.   }
  72. }  
復(fù)制代碼




作者: 瀟湘夜雨001    時(shí)間: 2019-8-14 21:09
你好,問下430定時(shí)器中斷到底該用CCIE還是TAIE,我試過,好像只有CCIE能進(jìn)中斷?




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1