
P1SEL
|=
BIT2
//设置P1.2端口为功能模块使用
TACTL
|=TACLR
TACTL
=
TASSEL_2+TAIE+MC1
//定时器A时钟信号选择SMCLK
8M,清计数寄存器,使能中断,同时设置定时器A计数模式为连续增计模式
CCTL1
=CM0+SCS+CAP+CCIE
//输入上升沿捕获,同步,capture模式
CCI0A为捕获信号源,中断使能
//TACCTL1
&=~CCIFG
//清CCR2
的标志位
//中断允许
_EINT()
LPM0
}
#pragma
vector=TIMERA1_VECTOR
//定时器A中断处理
__interrupt
void
timer_a(void)
{
switch(TAIV)
//向量查询
{
case
2:
//捕获中断
if(CCTL1&CM0)
//上升沿
{
CCTL1=(CCTL1&(~CM0))|CM1
//更变设置为下降沿触发
start=TACCR1
//记录初始时间
overflow=0
//溢出计数变量复位
}
else
if(CCTL1&CM1)
//下降沿
{
CCTL1=(CCTL1&(~CM1))|CM0
//更变设置为上升沿触发
end=TACCR1
//用start,end,overflow计算脉冲宽度
TACTL
&=~TAIE
//不使能中断
CCTL1
&=~CCIE
P1SEL
&=~BIT2
_DINT()
LPM0_EXIT
}
break
case
10:
//定时器溢出中断
overflow++
break
//溢出计数加1
default:break
}
}
然后再对得到的start,end,overflow处理计算即可。。。
看你这程序是Timer_A控制的Uart程序,我没弄过,没有发言权。不过下面是我编的一个串口中断的接收发送程序(不是用定时器模拟的),你可以看一下。
/******************************************************
程序功能:接收PC机十六进制数据后回传至PC机
数据格式:十六进制
帧头:FD
帧尾: FE
*******************************************************/
#include <msp430x14x.h>
unsigned char RecBuf[255]//接收数据缓存
unsigned char *SDat//指向要发送的数据
unsigned char Rindex //接收数据计数
unsigned char Tindex //发送数据计数
unsigned char SendLen//发送数据长度
/*************************************************
函数名称:ConfigUart0
功能:配置UART0,使用SMCLK,N.8.1, 9600
无校验,8个数据位,1个停止位,波特率9600
参数:无
返回值 :无
**************************************************/
void ConfigUart0()
{
P3SEL |= 0x30 // 选择P3.4和P3.5做UART通信端口
ME1 |= UTXE0 + URXE0// 使能USART0的发送和接受
UCTL0 |= CHAR // 选择8位字符
UTCTL0 |= SSEL1 // UCLK = SMCLK
UBR00 = 0xD0// 波特率9600
UBR10 = 0x00//
UMCTL0 = 0x40 // Modulation
UCTL0 &= ~SWRST // 初始化UART状态机
IE1 |= URXIE0 + UTXIE0 // 使能USART0的收发中断
}
/********************主函数********************/
void main(void)
{
unsigned int i
WDTCTL = WDTPW + WDTHOLD// 关闭看门狗
BCSCTL1 &= ~XT2OFF //使TX2有效,TX2上电默认是关闭的
do
{
IFG1 &= ~OFIFG//清除振荡器失效标志
for(i=0xffi>0i--) //延时,待稳定
}
while((IFG1 &OFIFG)!=0)//若振荡器失效标志有效
BCSCTL2 |= SELM1//使MCLK=XT2
BCSCTL2 |= SELS+DIVS1 //SMCLK=XT2,4分频,即2MHZ
BoardConfig(0xb8) // 关闭数码管、流水灯和电平转换
ConfigUart0() //配置UART0
_EINT() //打开全局中断
while(1)
{
LPM1
}
}
/*******************************************
函数名称:UART0_RXISR
功能:UART0的接收中断服务函数,在这里唤醒
CPU,使它退出低功耗模式
参数:无
返回值 :无
********************************************/
#pragma vector = UART0RX_VECTOR
__interrupt void UART0_RXISR(void)
{
RecBuf[Rindex++] = RXBUF0
if(RecBuf[Rindex-1]==0xfe) //接收完毕
{
if(RecBuf[0]==0xfd) //帧头正确
{
LPM1_EXIT
SDat = RecBuf
IFG1 |= UTXIFG0// 设置中断标志,进入发送中断程序
SendLen = Rindex
Rindex=0
}
}
}
/*******************************************
函数名称:UART0_TXISR
功能:UART0的发送中断服务函数
参数:无
返回值 :无
********************************************/
#pragma vector = UART0TX_VECTOR
__interrupt void UART0_TXISR(void)
{
if(Tindex <SendLen)
{
TXBUF0 = *(SDat+Tindex)
Tindex++
}
else
{
Tindex=0
//LPM1
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)