㈠ 跪求msp430的串口发送程序啊!
首先写发送程序,必须要使发送接收模块被允许,所以必须ME1 |= UTXE0 + URXE0该语句必须要写。其次发送接收都是高频的,故要将晶振设为高频,然后再对各个寄存器最一下必要的设置。
USART控制寄存器的组成部分:PENA,PEV,SP,CHAR,Listen,SYNC,MM,SWRST
各位都有其操作功能,我列举几个我觉得比较重要的
首先看SYNC:
串口发送主要可分为异步的UART模式,和同步的SPI模式,即由SYNC来控制,
SYNC:“0”UART模式
“1”SPI模式
CHAR:“0”选择字符以7位发送,不用接收缓存寄存器URXBUF或发送缓存寄器UTXBUF的最高位
“1”选择字符以8位发送
SWRST: 置位时,USART的各中断允许初始化,直至复位时USART才被允许。
发送控制寄存器UTCTL亦类似,对各个位做必要的设置就可以得到你想要的结果。UTCTL8位由高到低分别为:未用,CKPL,SSEL1,SSEL0,URXSE,TXWake,未用,TXEPT。还有接收控制寄存器URCTL0和URCTL1详情可以参照书本。
另有一个比较重要的就是波特率计算,用到UBR0及UBR1波特率寄存器以及调整控制寄存器UMCTL.具体计算为:UBR,UBR1和UBR0的16位数据
Mx ,调整器的各位数据
波特率=时钟周期/(UBR+(M7+M6+…+M0)/8)
贴上一个简单的程序:
#include <msp430x14x.h>
void main(void)
{
volatile unsigned int i;
WDTCTL = WDTPW + WDTHOLD; // 关闭开门狗
P3SEL |= 0x30; // P3.4,5 = USART0 TXD/RXD
BCSCTL1 |= XTS; // ACLK= LFXT1,LFXT1高频工作
do
{
IFG1 &= ~OFIFG; // Clear OSCFault flag
for (i = 0xFF; i > 0; i--); // Time for flag to set
}
while ((IFG1 & OFIFG)); // OSCFault flag still set?
BCSCTL2 |= SELM_3; // MCLK = LFXT1 (safe)
ME1 |= UTXE0 + URXE0; // Enable USART0 TXD/RXD
UCTL0 |= CHAR; // 8-bit character
UTCTL0 |= SSEL0; // UCLK= ACLK
UBR00 = 0x45; //
UBR10 = 0x00; //
UMCTL0 = 0x00; // 波特率计算
UCTL0 &= ~SWRST; //初始USART
IE1 |= URXIE0; // Enable USART0 RX interrupt
_BIS_SR(LPM0_bits + GIE); // Enter LPM0 w/ interrupt
}
#pragma vector=UART0RX_VECTOR
__interrupt void usart0_rx (void)
{
while (!(IFG1 & UTXIFG0)); // USART0 TX buffer ready?
TXBUF0 = RXBUF0; // RXBUF0 to TXBUF0
}
亦可参考汇编的:
#include "msp430x12x.h"
ORG 01100h ; Progam Start /* 程序开始 */
;------------------------------------------------------------------------------
RESET mov.w #0A00h,SP //将立即数#0A00h赋给寄存器SP
call #Init_Sys
Mainloop bis.b #CPUOFF,SR ; Enter LPM0 //CPU关闭进入低功耗模式0
nop
Init_Sys; Initalize MSP430 system
;------------------------------------------------------------------------------
StopWDT mov.w #WDTPW+WDTHOLD,&WDTCTL ; //关闭看门狗,高8位5A是写入,低8位80为时钟输入禁止,计数停止
SetupBC bis.b #XTS,&BCSCTL1 ; LFXT1 = HF XTAL //选择晶振频率为高频,BCSCTL1寄存器的D6位为1,表示选择高频
SetupOsc bic.b #OFIFG,&IFG1 ; Clear OSC fault flag //清中断标志1
mov.w #0FFh,R15 ; R15 = Delay //通用寄存器R15数据初始化
SetupOsc1 dec.w R15 ; Additional delay to ensure start //减一
jnz SetupOsc1 ; //不等于0时程序跳转
bit.b #OFIFG,&IFG1 ; OSC fault flag set? //状态位C置位
jnz SetupOsc ; OSC Fault, clear flag again //重新清中断标志1
bis.b #SELM1+SELM0,&BCSCTL2 ; MCLK = LFXT1 //选择LFXT1CLK为MCLK的时钟源
SetupUART0 mov.b #CHAR,&UCTL0 ; 8-bit characters //8位数据位
mov.b #SSEL0,&UTCTL0 ; UCLK = ACLK //选择辅助时钟ACLK
mov.b #045h,&UBR00 ; 8MHz 115200
mov.b #000h,&UBR10 ; 8MHz 115200 //计算波特率
mov.b #000h,&UMCTL0 ; 8MHz no molation 115200//未分频
bis.b #UTXE0+URXE0,&ME1 ; Enable USART0 TXD/RXD //串口发送接收允许
bis.b #URXIE0,&IE1 ; Enable USART0 RX interrupt//串口接收中断允许
SetupP3 bis.b #030h,&P3SEL ; P3.4,5 = USART0 TXD/RXD //选择P3.4,5口,030h=001(p5)1(p4)0000,P3SEL的地址01bh的数值应该为0
bis.b #010h,&P3DIR ; P3.4 = output direction //010h=0001(p4)0000,p4口为输出,
eint ; General enable interrupts //
ret ; Return from subroutine
;
;------------------------------------------------------------------------------
USART0RX_ISR; Confirm TX buffer is ready, then Echo back RXed character
;------------------------------------------------------------------------------
TX1 bit.b #UTXIFG0,&IFG1 ; USART0 TX buffer ready? //发送中断标志
jz TX1 ; Jump is TX buffer not ready //没在等待发送,则再去判断等待发送的标志
mov.b &RXBUF0,&TXBUF0 ; TX -> RXed character //共用一块缓冲
reti ;
;
;------------------------------------------------------------------------------
; Interrupt Vectors Used MSP430x13x/14x
;------------------------------------------------------------------------------
ORG 0FFFEh ; //复位中断
DW RESET ; POR, ext. Reset, Watchdog //中断入口
ORG 0FFF2h ; //等待串口接收数据中断
DW USART0RX_ISR ; USART0 receive //串口接收
END
㈡ MSP430程序解释
看你这程序是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; // Molation
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=0xff;i>0;i--); //延时,待稳定
}
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;
}
}
㈢ MSP430涓插彛閫氫俊鏃舵帴鍙椼佸彂閫佷腑鏂鏄鎬庝箞浜х敓鐨勶紵
鎬庝箞浜х敓鐨勶紵濡傛灉灏卞瓧闈㈡剰鎬濇潵璇寸殑璇潂灏辨槸鐢辫姱鐗囧唴鐨勪腑鏂閫昏緫浜х敓鐨剘涓插彛妯″潡鍙戦佸瘎瀛樺櫒涓虹┖鎴栨帴鍙楀瘎瀛樺櫒涓烘弧鏃讹紝浼氬悜430涓鏂鎺у埗鍣ㄥ彂淇″彿~
杩欐槸TI鐨勫畼鏂逛唬鐮佹牱渚
//******************************************************************************
//MSP-FET430x140Demo-USART0,Ultra-LowPwrUART9600String,32kHzACLK
//
//Description:Thisprogramdemonstratesafull-plex9600-baudUARTusing
//USART0anda32kHzcrystal.TheprogramwillwaitinLPM3,andwill
//respondtoareceived'u'characterusing8N1protocol.Theresponsewill
//bethestring'HelloWorld.
//ACLK=LFXT1=UCLK0,MCLK=SMCLK=defaultDCO~800KHz
//@9600=32768Hz/9600=3.41(000Dh4Ah)
////**//
//
//MSP430F149
//-----------------
///||XIN|-
//|||32kHz
//--|RSTXOUT|-
//||
//|P3.4|----------->
//||9600-8N1
//|P3.5|<-----------
//
//M.Buccini
//TexasInstrumentsInc.
//Feb2005
//BuiltwithCCEVersion:3.2.:3.21A
//******************************************************************************
#include<msp430x14x.h>
staticcharstring1[]={"HelloWorld "};
chari;
voidmain(void)
{
WDTCTL=WDTPW+WDTHOLD;//Stopwatchdog
P3SEL=0x30;//P3.3,4=USART0TXD/RXD
ME1|=UTXE0+URXE0;//EnabledUSART0TXD/RXD
UCTL0|=CHAR;//8-bitcharacter,SWRST=1
UTCTL0|=SSEL0;//UCLK=ACLK
UBR00=0x03;//9600from1Mhz
UBR10=0x00;//
UMCTL0=0x4A;//Molation
UCTL0&=~SWRST;//InitializeUSARTstatemachine
IE1|=URXIE0+UTXIE0;//EnableUSART0RX/TXinterrupt
IFG1&=~UTXIFG0;//ClearinitalflagonPOR
_BIS_SR(LPM3_bits+GIE);//EnterLPM3w/interrupt
}
//UART0TXISR
#pragmavector=USART0TX_VECTOR
__interruptvoisart0_tx(void)
{
if(i<sizeofstring1-1)
TXBUF0=string1[i++];
}
//UART0RXISR
#pragmavector=USART0RX_VECTOR
__interruptvoisart0_rx(void)
{
if(RXBUF0=='u')//'u'received?
{
i=0;
TXBUF0=string1[i++];
}
}