附整个工程。
原理,做高频信号测量。ACLK=32768HZ,MCLK=SMCLK=4MHZ
首先利用TB0产生一个1S闸门,闸门关闭的时候OneSecondFlag置位。
TA0的时钟为TA0CLK(即待测信号),10分频,增计数模式,TA0CCR0=100;在闸门期间,TA0第一次中断的时候,打开TA2标准计数,并把TA0CCR0=10000。闸门关闭后,TA0在紧接着的一次中断中关闭自己。并将HighFrequenceWaitFlag清零。
实际发现,好像TA0没有按照计划在应有的时刻关掉。
还有,请教TI在多中断中怎样处理来防止中断竞争之类的事情发生。有没有相关的例程
主要程序部分如下:
void TAInit1() //高频预测量定时器设置
{
/*TB0设定1S间隔*/
TB0CTL|=MC_0; //关闭定时器
TB0CTL|=TBCLR; //计数器TA2清零
TB0CCR0=32767; //比较模式对比数值
TB0CCTL0|=CCIE; //CCRO比较中断使能
TB0CTL|=TBSSEL_1+ID_0;//选择ACLK时钟32.768KHZ,初级1分频,关闭TA2IFG中断
TB0EX0=TBIDEX_0;//二级1分频
/*TA0设定待测信号计数*/
TA0CTL|=MC_0; //关闭定时器
TA0CTL|=TACLR; //计数器TA0清零
TA0CCR0=100; //比较模式对比数值
TA0CCTL0|=CCIE; //CCRO比较中断使能
TA0CTL|=TASSEL_0+ID_1;//选择TA0CLK,即待测信号,初级2分频,关闭TA0IFG中断
TA0EX0=TAIDEX_4;//二级5分频,总共为10分频
/*TA1标准信号计数*/
TA1CTL|=MC_0; //关闭定时器
TA1CTL|=TACLR; //计数器TA1清零
TA1CTL|=TASSEL_2+ID_0+TAIE;//选择SMCLK4MHZ,初级1分频,开启TA1IFG中断
TA1EX0=TAIDEX_0;//二级1分频
}
/*TA2-CCR0中断服务函数*/
#pragma vector=TIMER0_B0_VECTOR //CCR0中断标志
__interrupt void TA2Interrupt0()
{
OneSecondFlag=1; //1S标志位置位
TB0CTL=MC_0; //关闭定时器2
TB0CTL&=~TBIE;
/*测试用*/
P1OUT^=BIT2;
if(HInputOverflowTime==0)//溢出次数为0,表示实际信号为低频
{
TA0CTL|=MC_0; //TA0直接关闭
TA0CTL&=~TAIE;
IsHighFrequenceFlag=0;//判断为低频
HighFrequenceWaitFlag=0;//高频测量等待结束
/*测试用*/
P1OUT^=BIT3;
}
}
/*TA0-CCR0中断服务函数*/
#pragma vector=TIMER0_A0_VECTOR //CCR0中断标志
__interrupt void TA0Interrupt0()
{
//__enable_interrupt();
if(OneSecondFlag==0) //表示还在1S的大闸门内
{
if(HInputWorkFlag==0) //待测信号第一个闸门沿到来
{
TA0CCR0=10000; //比较模式对比数值
TA1CTL|=MC_2; //标准信号开始同时进入连续技计数模式
HInputWorkFlag=1; //进入闸门内
}
else //处于待测信号闸门内
{
HInputOverflowTime++;
P1OUT^=BIT4;
}
}
/*就是这里好像不能按照设想关掉相应的定时器,实际好像会一直进入中断,或者好一点的话也会比预计多中断几次*/
if(OneSecondFlag==1) //表示1S的大闸门已经关闭
{
TA0CTL|=MC_0; //关闭待测信号计数
TA0CTL&=~TAIE;
HInputOverflowTime++;
TA1CTL&=~TAIE;
TA1CTL|=MC_0; //关闭标准信号计数
HReferenceNum=TA1R;//暂时记录标准信号计数终值
HighFrequenceWaitFlag=0;//高频测量等待结束
P1OUT^=BIT5;
}
}
/*TA1IFG中断服务函数*/
#pragma vector=TIMER1_A1_VECTOR
__interrupt void TA1Interrupt1()
{
switch(__even_in_range(TA0IV,14))
{
case 14:HROverflowTime++;break;
default:break;
}
}
/*高频测量主函数*/
void HFMeasure()
{
OneSecondFlag=0; //定时1S标志
TB0CTL|=MC_1;//定时器2增模式
TA0CTL|=MC_1;//定时器0增模式
DelayMs(1500);
//while(HighFrequenceWaitFlag);//高频测量等待
//P1DIR|=BIT3;
//P1OUT|=BIT3;
TB0CTL|=MC_0; //关闭定时器TB
TA0CTL|=MC_0; //关闭定时器
TA1CTL|=MC_0; //关闭定时器
HInputNum=100*HInputOverflowTime;
DelayMs(1);
//HReferenceNum++;
HReferenceNum+=HROverflowTime*65537;
DelayMs(2);
}