51单片机串口通讯编程

51单片机串口通讯编程,第1张

首先你的波特率是4800,要一致才可以,如果波特率一样,那么程序修改如下:

#include<reg52h>

void main(viod)

{

SCON=0x50;

TMOD=0x20;

TH1=0xfa;

TL1=0xfa;

TR1=1;

EA=1;

ES=1;

while(1);

}

void uart(void) interrupt 4

{

ES=0;

if(RI)

{

    if(SBUF=='H')

    {

        SBUF='O';

        while(TI==0);

        TI=0;

        SBUF='K';

        while(TI==0);

        TI=0;

    }

ES=1;

TI=0;

}

我用的新唐芯片,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;

}

}

}

接收

以下是我刚改的程序编译成功了

请参考

#include"reg51h"

//定义全局变量

unsigned char data_10[10]={0,0,0,0,0,0,0,0,0,0};

unsigned char Time_50ms,count;

bit flag=0;

bit data_flag=0;

/

函数名:UART串口初始化函数

调 用:UART_init();

参 数:无

返回值:无

结 果:启动UART串口接收中断,允许串口接收,启动T/C1产生波特率(占用)

备 注:振荡晶体为12MHz,PC串口端设置 [ 4800,8,无,1,无 ]

//

void UART_init (void){

EA = 1; //允许总中断(如不使用中断,可用//屏蔽)

ES = 1; //允许UART串口的中断

TMOD |= 0x20;//定时器T/C1工作方式2

SCON = 0x50;//串口工作方式1,允许串口接收(SCON = 0x40 时禁止串口接收)

TH1 = 0xF3;//定时器初值高8位设置

TL1 = 0xF3;//定时器初值低8位设置

PCON = 0x80;//波特率倍频(屏蔽本句波特率为2400)

TR1 = 1;//定时器启动

}

//

/

函数名:UART串口接收中断处理函数

调 用:[SBUF收到数据后中断处理]

参 数:无

返回值:无

结 果:UART串口接收到数据时产生中断,用户对数据进行处理(并发送回去)

备 注:过长的处理程序会影响后面数据的接收

//

void UART_R (void) interrupt 4 using 1{ //切换寄存器组到1

TR0=1; //打开定时器开始计时

RI = 0;//令接收中断标志位为0(软件清零)

data_10[count] = SBUF;//将接收到的数据送入变量 UART_data

count++;//接收到一个字节数据计数+1

if(count>=10) //如果接收到10个数据

{

TR0=0; //停止定时器

TH0 = 0x3C; //给定时器赋初值

TL0 = 0xB0; //给定时器赋初值

count=0;//清零数据计数

//data_flag=1; //数据有效标志位

SBUF = 0x55;//返回数据 55H

while(TI == 0);//检查发送中断标志位

TI = 0;//令发送中断标志位为0(软件清零)

}

if(flag)

{

TR0=0; //停止定时器

TH0 = 0x3C; //给定时器赋初值

TL0 = 0xB0; //给定时器赋初值

count=0;//清零数据计数

SBUF = 0xff;//返回数据 ffH

while(TI == 0);//检查发送中断标志位

TI = 0;//令发送中断标志位为0(软件清零)

}

}

//

/

函数名:定时/计数器初始化函数

调 用:T_C_init();

参 数:无

返回值:无

结 果:设置SFR中T/C1和(或)T/C0相关参数

备 注:本函数控制T/C1和T/C0,不需要使用的部分可用//屏蔽

//

void T_C_init (void){

TMOD |= 0x01; //高4位控制T/C1 [ GATE,C/T,M1,M0,GATE,C/T,M1,M0 ]

EA = 1;//中断总开关

TH0 = 0x3C; //16位计数寄存器T0高8位

TL0 = 0xB0; //16位计数寄存器T0低8位(0x3CB0 = 50mS延时)

ET0 = 1; //T/C0中断开关

TR0 = 0; //T/C0开关

}

//

/

函数名:定时/计数器0中断处理函数

调 用:[T/C0溢出后中断处理]

参 数:无

返回值:无

结 果:重新写入16位计数寄存器初始值,处理用户程序

备 注:必须允许中断并启动T/C本函数方可有效,重新写入初值需和T_C_init函数一致

//

void T_C0 (void) interrupt 1 using 1{ //切换寄存器组到1

TH0 = 0x3C; //16位计数寄存器T0高8位(重新写入初值)

TL0 = 0xB0; //16位计数寄存器T0低8位(0x3CB0 = 50mS延时)

Time_50ms++; //50ms到 计数+1

if(Time_50ms>=100)

{

Time_50ms=0;// 清零50ms计数

flag=1; //5s时间 标志置位

TR0=0;//关闭计时器

}

}

//

main()

{

IP = 0x10; //中断优先级设置(串口中断最高优先级)

UART_init();//初始化串口

T_C_init(); // 初始化计数器

while(1);// 空循环

}

串行发送程序 Txasm :

PCON, #00H ;; 波特率不倍增

SETB TR1 ;; 启动定时器T1

MOV IE, #0 ;; 禁止任何中断

CALL DLY125 ;; 延时125ms

;;--------------------------------------------

T_X: ;; 透传发送字串

ACALL DSPLED ;; P20控制LED闪亮

MOV R3, #4 ;; 待发送字符个数

MOV DPTR, #TAB_TX ;; 数据表首址

TX_LP1: CLR A

MOVC A, @A+DPTR ;; A←数据表的1个字符

CLR TI ;; TI清零,允许发送

MOV SBUF,A ;; 发送1个字符

JNB TI, $ ;; 等待1个字符帧发送结束

DJNZ R3, TX_next

CALL DLY500 ;; 延时500ms

SJMP T_X ;; 重复发送

TX_next: ;; 发送另一字符

INC DPTR ;; 数据表指针移动

SJMP TX_LP1

;;--------------------------------------------

DSPLED: ;;开机或复位,P20控制LED闪亮6遍

MOV R2, #6 ;; 循环次数

LEDLP1: CLR P20 ;; LED亮

CALL DLY125 ;; 延时125ms

SETB P20 ;; LED灭

CALL DLY125

DJNZ R2,LEDLP1 ;; 循环

RET

;;----------------------------------------------

DLY125: ;; 延时125ms

DLY125A: MOV R5,#250

DLY125B: MOV R6,#250

DJNZ R6,$

DJNZ R5,DLY125B

RET

;; 2502502μs=125 000μs =125ms

;;----------------------------------------------

DLY500: ;; 延时500ms

MOV R7,#4

DLY500A: MOV R6,#250

DLY500B: MOV R5,#250

DJNZ R5,$

DJNZ R6,DLY500B

DJNZ R7,DLY500A

RET

;; 42502502μs=500 000μs =500ms

;;-------------------------------------------------

TAB_TX: DB 38H,30H,35H,31H,

;; 8 0 5 1

;;----------------------------------------------

END

以上就是关于51单片机串口通讯编程全部的内容,包括:51单片机串口通讯编程、编写单片机串口收发数据的完整程序(C语言编写)、急!!!单片机C语言实现串口通信编程等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/zz/9501647.html

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

发表评论

登录后才能评论

评论列表(0条)

保存