找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 9632|回復: 1
打印 上一主題 下一主題
收起左側(cè)

MSP430單片機定時器TA中斷 程序

[復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:108615 發(fā)表于 2016-3-14 19:00 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
本程序是《MSP430系列單片機系統(tǒng)工程設(shè)計與實踐》書里面的源碼,(包含工程文件 (例2.8.20)))完整例程下載:http://www.torrancerestoration.com/bbs/dpj-46245-1.html

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

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

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

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

  7.   TACCR0 = 32768-1;                        // 1秒=32768個ACLK周期
  8.   TACCR1 = 6554-1;                        // 0.2秒=6554個ACLK周期
  9.   TACCR2 = 29938-1;                        // 0.7秒=29938個ACLK周期  
  10.   TACTL = TASSEL_1 + MC_1;              // TA設(shè)為增計數(shù)模式,時鐘=ACLK
  11.   TACTL |= TAIE;                        // 允許TA溢出中斷
  12.   TACCTL1 |= CCIE;                      // 允許比較/捕獲模塊1的中斷
  13.   TACCTL2 |= CCIE;                      // 允許比較/捕獲模塊2的中斷   
  14.   _EINT();
  15.   while(1)
  16.   {
  17.      //                                 CPU可以執(zhí)行其他任務
  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階段只亮藍燈
  30.                 break;                          
  31.     case 10:    P1OUT &=~( BIT3+BIT1+BIT4);           
  32.                 P1OUT |= BIT3;           //0~TACCR1階段只亮紅燈
  33.                 break;
  34.   }
  35. }
復制代碼

程序3
  1. #include  <msp430x41x.h>
  2. void main(void)
  3. {
  4.   WDTCTL = WDTPW + WDTHOLD;                    // 停止看門狗
  5.   FLL_CTL0 |= XCAP18PF;                 // 配置晶振負載電容
  6.   P1DIR |= BIT3 + BIT4;                      // 設(shè)置P1.3、P1.4為輸出腳
  7.   TACTL |= MC_1 + TASSEL_1 + ID_0; //定時器TA設(shè)為增量計數(shù)模式,ACLK
  8.   TACCR0=328-1;               //PWM總周期 =328個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í)行其他任務
  18.   }
  19. }
  20. #pragma vector=TIMERA1_VECTOR
  21. __interrupt void TA_ISR(void)
  22. {
  23.   switch( TAIV )
  24.   {
  25.     case  2:    P1OUT &=~ BIT3;                   //計至TACCR1,P1.3置低
  26.                 break;
  27.     case  4:    P1OUT &=~ BIT4;                   //計至TACCR2,P1.4置低
  28.                 break;                          
  29.     case 10:    P1OUT |=( BIT3 + BIT4);        //計至TACCR0,置高
  30.                 break;
  31.   }
  32. }
復制代碼

程序4
  1. #include  <msp430x41x.h>
  2. int Result;
  3. int TA_OverflowCnt;                        //TA溢出次數(shù)存放變量
  4. unsigned long int ExeTime;                //執(zhí)行時間存放變量
  5. /****************************************************************
  6. 運行時間待測函數(shù)1:求兩個浮點數(shù)之和
  7. ****************************************************************/
  8. float FloatSum(float x ,float y)  /*226個指令周期*/
  9. {
  10.   return(x+y);
  11. }
  12. /****************************************************************
  13.                      運行時間待測函數(shù)2:求兩個定點數(shù)之和
  14. ****************************************************************/
  15. int IntSum(int x ,int y)          /*17個指令周期*/
  16. {
  17.   return(x+y);
  18. }
  19. /****************************************************************
  20.                      運行時間待測函數(shù)3: 軟件延時
  21. ****************************************************************/
  22. void Delay()                          /*774030個指令周期*/
  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;                         // 配置晶振負載電容
  33.   _EINT();                                              // 總中斷允許
  34.   while(1)
  35.   {
  36. //-------------------------測量定時器的固有延遲-------------------------
  37.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計時   
  38.     TACTL = TASSEL_2 + MC_0;            // TA停止計時
  39.     ExeTime=TAR;                        // 讀取TA計數(shù)值,就是固有延遲時間
  40.     _NOP();                                // 在這一行設(shè)斷點觀察
  41. //-----------------------測量浮點求和函數(shù)的執(zhí)行時間----------------------
  42.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計時   
  43.     Result=FloatSum(12345 ,12456);                // 執(zhí)行待測函數(shù)1
  44.     TACTL = TASSEL_2 + MC_0;                           // TA停止計時
  45.     ExeTime=TAR;                                // 讀取TA計數(shù)值,就是執(zhí)行時間
  46.     _NOP();                                        // 在這一行設(shè)斷點觀察
  47. //-----------------------測量定點求和函數(shù)的執(zhí)行時間-------------------
  48.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR; // TA清零并開始計時
  49.     Result= IntSum(12345 ,12456);        // 執(zhí)行待測函數(shù)2
  50.     TACTL = TASSEL_2 + MC_0;            // TA停止計時   
  51.     ExeTime=TAR;                        // 讀取TA計數(shù)值,就是執(zhí)行時間
  52.     _NOP();                                // 在這一行設(shè)斷點觀察
  53. //----------------------測量延遲和函數(shù)的執(zhí)行時間--------------------
  54.     TA_OverflowCnt=0;        // 長執(zhí)行時間函數(shù)TA會溢出,用一變量計數(shù)溢出次數(shù)
  55.     TACTL = TASSEL_2 + MC_2 + TAIE + TACLR;     // TA清零并開始計時
  56.     Delay();                                        // 執(zhí)行待測函數(shù)3
  57.     TACTL = TASSEL_2 + MC_0;                    // TA停止計時   
  58.     ExeTime=TA_OverflowCnt*65536+TAR; // 讀取TA計數(shù)值及溢出次數(shù),計算執(zhí)行時間
  59.     _NOP();                                  // 在這一行設(shè)斷點觀察
  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. }  
復制代碼



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩

相關(guān)帖子

回復

使用道具 舉報

沙發(fā)
ID:155399 發(fā)表于 2019-8-14 21:09 | 只看該作者
你好,問下430定時器中斷到底該用CCIE還是TAIE,我試過,好像只有CCIE能進中斷?
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表