51单片机通过串口实现数据的发送与接收程序

51单片机通过串口实现数据的发送与接收程序,第1张

串口收发,要有通信协议。也就是什么时候开始接收,接收到指令后,转发什么数据。这个要知道,才可以写。而且使用不同的51单片机,其内部寄存器配置是不同的。

一般来说,过程如下:

1,配置串口参数、波特率等,开启串口中断;

void Init_UART()

{

}

2,中断函数里写中断响应函数,根据接收的指令或者数据,执行相应的动作;

程序一般为:

void UART_ISR() interrupt x using y

{

串口中断处理函数

}

x - 单片机的C51中断号

y - 指定使用的当前工作寄存器组号(0-3 PSW中的RS0,RS1组合)

3,主程序

int main(void)

{

Init_UART()

while(1)

{

//数据发送函数

}

}

4-ADC12应有例程

//******************************************************************************

//MSP430F149 ADC12模块+串行通讯的实验程序

//使用ADC12采集实验,将采集到数据送向PC.(单路单次采集)

//P3.4为发送,P3.5为接收 晶体使32768HZ/8MHZ. 串行波特率B/S

//使用SMCLK作为波特率发器时,不能使用LPM2,LPM3!

//以下程序已验证通过,初学者可直接使用.由时间仓促和水平有限,请读者批评指正.

//编写:www.Microcontrol.cn/DC

//******************************************************************************

#include <msp430x14x.h>

//********************************************

//表区

unsigned char number_table[]={'0','1','2','3','4','5','6','7','8','9'}

unsigned char display_buffer[]={0x00,0x00,0x00,0x00,0xff}

//*******************波特率***********300 600 1200 2400 4800 9600 19200 38400 76800 115200const

//************************************[0]**[1]**[2]*[3]**[4]**[5]***[6]***[7]****[8]***[9]*

unsigned char BaudrateUBR0[] ={0x6D,0x36,0x1B,0x0D,0x06,0x03, 0xA0, 0xD0, 0x68, 0x45}

unsigned const char BaudrateUBR1[] ={0x00,0x00,0x00,0x00,0x00,0x00, 0x01, 0x00, 0x00, 0x00}

unsigned const char BaudrateUMCTL[]={0x22,0xD5,0x03,0x6B,0x6F,0x4A, 0xC0, 0x40, 0x40, 0x4A}

unsigned char timp

//变量区

unsigned int ADC0

//子程序声明

void init (void)//初始化

void ADC12setup(void) //ADC12初始化

void BaudrateSetup(unsigned char U0)//UART0初始化

void data_converter(unsigned char *p,unsigned int vaule)//数据变换

void send_data(unsigned char *p)//串行口发送数组

//********************************************

void main(void)

{

init()

//主循环

for ()

{

LPM0

ADC12CTL0 |= ADC12SC//sampling open,AD转换完成后(ADC12BUSY=0),ADC12SC自动复位

while((ADC12IFG &BIT0) == 0) //等转换结束

ADC0 = ADC12MEM0//读转换数据值,同时清ADC12IFG0标志

data_converter(display_buffer,ADC0) //数据变换

send_data(display_buffer) //发送数据

}

}

//********************************************************************************

void init(void)

{

WDTCTL = WDTPW + WDTHOLD// 停止WDT

P1DIR=0x01P1OUT=0x0f //LED设置

BaudrateSetup(6)

ADC12setup()

_EINT() // 全局中断使能

}

//**********************************************************************************

//串口接收中断,退出LPM0模式.

#pragma vector=USART0RX_VECTOR

__interrupt void usart0_rx (void)

{

LPM0_EXIT

}

//**********************************************************************************

//ADC12初始化

void ADC12setup(void)

{

//ADC12设置**************************

P6SEL |= 0x01 //使用A/D通道 A0

ADC12CTL0 = ADC12ON //开ADC12内核,设SHT0=2 (N=4)

ADC12CTL1 = SHP //SAMPCON信号选为采样定时器输出

//ADC12内部参考电压设置

ADC12CTL0 |= REF2_5V//选用内部参考电压为2.5V

ADC12CTL0 |= REFON //内部参考电压打开

ADC12MCTL0 |= SREF_1//R+=2.5V R-=VSS

//转换允许

ADC12CTL0 |= ENC//转换允许(上升沿)

ADC0=0x00

}

//**********************************************************************************

//UART0初始化

void BaudrateSetup(unsigned char U0)

{

unsigned int i

if(U0>5) //当U0>5时,启用XT2

{

BCSCTL1 &= ~XT2OFF //启动XT2,

do

{ IFG1 &= ~OFIFG //清OSCFault标志

for(i=0xFFi>0i--)//延时等待

}

while((IFG1 &OFIFG) != 0)//查OSCFault,为0时转换完成

BCSCTL2 |= SELS //SMCLK为XT2

}

//UART0

P1OUT=0x00

if(U0>5){UTCTL0=SSEL1} // 时钟源:SMCLK

else{UTCTL0=SSEL0} // 时钟源:ACLK

UCTL0 &= ~SWRST// SWRST复位, USART允许

UCTL0=CHAR // 8bit

ME1|=UTXE0 + URXE0 // Enable Tx0,Rx0

IE1|=URXIE0// RX使能

UBR00=BaudrateUBR0[U0] // 低位分频器因子

UBR10=BaudrateUBR1[U0] // 高位分频器因子

UMCTL0=BaudrateUMCTL[U0] // 波特率调整因子

P3SEL |= 0x30 // 将P3.4,5使用外围模块 = USART0 TXD/RXD

P3DIR |= 0x10 // 将P3.4设为输出(发),P3.5默认为输入(收)

}

//**********************************************************************************

//数据变换

void data_converter(unsigned char *p,unsigned int value)

{

unsigned int m,n,j=0

p[0]=number_table[value/1000]

m=value%1000

p[1]=number_table[m/100]

n=m%100

p[2]=number_table[n/10]

j=n%10

p[3]=number_table[j/1]

}

//**********************************************************************************

//串行口发送数组

void send_data(unsigned char *p)

{unsigned int n

timp=RXBUF0

for(n=0p[n]!=0xffn++)

{

while ((IFG1 &UTXIFG0) == 0)// USART0发送UTXIFG0=1,表示UTXBUF准备好发送一下字符

TXBUF0 = p[n]

}

}

//**********************************************************************************

//ADC12模块例程(1)结速

我用的新唐芯片,8051内核,跟51差不多,望采纳

void UART_Initial (void)

{

P02_Quasi_Mode //Setting UART pin as Quasi mode for transmit

P16_Quasi_Mode //Setting UART pin as Quasi mode for transmit

SCON_1 = 0x50 //UART1 Mode1,REN_1=1,TI_1=1

T3CON = 0x08 //T3PS2=0,T3PS1=0,T3PS0=0(Prescale=1), UART1 in MODE 1

clr_BRCK

RH3= HIBYTE(65536 - (1000000/u32Baudrate)-1) /*16 MHz */

RL3= LOBYTE(65536 - (1000000/u32Baudrate)-1) /*16 MHz */

set_TR3//Trigger Timer3

}

以上是初始化的

void Send_Data_To_UART1(UINT8 c)

{

TI_1 = 0

SBUF_1 = c

while(TI_1==0)

}

这个是发送

void UART_isr (void) interrupt 4 //串行中断服务程序

{

if (RI_1==1)

{ /* if reception occur */

clr_RI_1/* clear reception flag for next reception */

Receive_Date[c] = SBUF_1

if (Receive_Date[0] == First_Date)

{

c++

}

else if(Receive_Date_Size >0 &&Receive_Date_Size <4)

{

c++

}

else if(Receive_Date[c] == Last_Date &&Receive_Date_Size ==4)

{

c = 0

Flag_Receive_One = 1

}

else

{

c = 0

}

}

}

接收


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

原文地址: http://outofmemory.cn/yw/11982318.html

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

发表评论

登录后才能评论

评论列表(0条)

保存