专注电子技术学习与研究
当前位置:单片机教程网 >> MCU设计实例 >> 浏览文章

MSP430F5299时钟设置(24M)和计数器A使用

作者:未知   来源:不详   点击数:  更新时间:2014年08月31日   【字体:

///////////////24MHZ时钟设置//////////////////////////////////////////////////////////////
  UCSCTL3 |=SELREF__REFOCLK;
   __bis_SR_register(SCG0);     //disable the FLL control loop
   UCSCTL0=0X0000;//            //Set lowest possible DCOx,MODxSCG0
   UCSCTL1=DCORSEL_7;           //Select DCO range 24MHz opreation
                               //DCORSEL_x,其中x可选3、4、5、6、7
   UCSCTL3=FLLD_0+731;          //Set DCO Multiplier for 24MHz
                                //(N+1)*FLLRef=Fdco
                                //(731+1)*32768=24MHz
                               //Set FLL DIV =fDCOCLK/2
   /*__bis_SR_register(SCG0);                 //Enable the FLL control loopSCG0
   UCSCTL4 |=SELA__DCOCLK+SELS__XT1CLK+SELM__DCOCLK;//MCLK Source select
   UCSCTL5 |=DIVPA_2;                       //ACLK output divide
   UCSCTL6 |=XT1DRIVE_3+XCAP_0;             //XT1 cap */

//////////////////////////////////////////////////////////////////////////////////////////////////

#include "msp430F5529.h"
int tt=0,temp,kk;
void delay(int ns)
{
  while(ns--);
}
void adc1()
{
 P1SEL |=BIT6;
 ADC12CTL0 =ADC12ON  + ADC12SHT0_8 + ADC12MSC;
 ADC12CTL1 =ADC12SHP + ADC12CONSEQ_2;
 ADC12MCTL0=ADC12SREF_0+ADC12INCH_6;
 ADC12CTL0 |=ADC12ENC;
}
void MclkFre(void)
{
   UCSCTL3 |=SELREF__REFOCLK;
  __bis_SR_register(SCG0);     //disable the FLL control loop
   UCSCTL0=0X0000;//            //Set lowest possible DCOx,MODxSCG0
   UCSCTL1=DCORSEL_7;           //Select DCO range 24MHz opreation
                               //DCORSEL_x,其中x可选3、4、5、6、7
   UCSCTL3=FLLD_0+731;          //Set DCO Multiplier for 24MHz
                                //(N+1)*FLLRef=Fdco
                                //(731+1)*32768=24MHz
                               //Set FLL DIV =fDCOCLK/2
   /*__bis_SR_register(SCG0);                 //Enable the FLL control loopSCG0
   UCSCTL4 |=SELA__DCOCLK+SELS__XT1CLK+SELM__DCOCLK;//MCLK Source select
   UCSCTL5 |=DIVPA_2;                       //ACLK output divide
   UCSCTL6 |=XT1DRIVE_3+XCAP_0;             //XT1 cap */
}
void TimerA(void)
{
   P1DIR |= 0x01;                            // P1.0 output
   TA1CCTL0 = CCIE;                          // CCR0 interrupt enabled
   TA1CCR0 = 100;                            //计数最大值设置
   TA1CTL = TASSEL_2 + MC_2 + TACLR;         // SMCLK, contmode, clear TAR

}
int main(void)
 {
   WDTCTL = WDTPW + WDTHOLD;   // Stop WDT
   MclkFre();
   TimerA();  
   __bis_SR_register(LPM0_bits + GIE);       // Enter LPM0, enable interrupts
   __no_operation();                         // For debugger
 }
 // Timer1 interrupt service routine
 #pragma vector=TIMER1_A0_VECTOR
 __interrupt void TIMER1_A0_ISR(void)
 {
 
   if(kk==50)
   {
     kk=0;
   P1OUT ^= 0x01;// Toggle P1.0
   }
    else kk++;
                           
    TA1CCR0 += 10000;                         // 重装
 }
#pragma vector=ADC12_VECTOR
__interrupt void ADC12ISR(void)
{
    tt=ADC12MEM0; //转换数据存在12位ADC12MEM0寄存器中
}

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
对于定时器Timer,与以往430系列的TimerA模块基本没什么差别,需要注意的是
         TACCR0是一个独立的中断源,对于的中断服务函数是TIMERA0_VECTOR
          TACCR1\TACCR2\TA是共用一个中断源,对于的中断标志在TAIV寄存器中,对于的中断服务函数是TIMERA1_VECTOR,需要在中断服务函数里判断是哪个触发源。具体方式如下:
#pragma vector = TIMERA1_VECTOR
 __interrupt void T IMERA1_ISR(void)
 {
 switch(__even_in_range(TAIV,10))
 {
 case  2 :      // TACCR1 CCIFG
 P1OUT ^= 0x04 ;break;
 case  4 :      // TACCR2 CCIFG
 P1OUT ^= 0x02 ;break;
 case 10 :      // TAIFG
 P1OUT ^= 0x01 ;break;
 }
 }
在5529中,A计数是在TA0R而不是TACCR0中,TACCR0在整个计数过程中是不变的,定时器A有一个比较模式,就是把变化的TA0R不断的与TACCR0进行比较,相等就产生中断。
关闭窗口