msp430单片机用定时器A测量方波相位差的程序如何编写?真的很急!拜托了!

msp430单片机用定时器A测量方波相位差的程序如何编写?真的很急!拜托了!,第1张

这个简单,把两个方波进行异或,用430单片机的定时器A测量异或后的方波的脉冲宽度,在对测量数据进行简单的计算就可得到相位差。。。具体程序如下:

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

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/8052733.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-13
下一篇2023-04-13

发表评论

登录后才能评论

评论列表(0条)

    保存