云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 基于MCS51的两片单片机之间的串行通信接口设计

基于MCS51的两片单片机之间的串行通信接口设计

  • 62 次阅读
  • 3 次下载
  • 2025/12/3 7:00:25

基于MCS51的两片单片机之间的串行通信接口设计

while(1) //开启死循环 { if(K1==0) { ES=0; delay1(5000); if(K1==0) {

SBUF=5;

while(!TI); // 等待发送完 TI=0; while(!K1); } ES=1;

}

else if(AA==100) { AA=0; P1=Table[i]; i++;

if(i>9) { i=0; }

delay1(5000); } else { ES=0; TI=0;

31

基于MCS51的两片单片机之间的串行通信接口设计

SBUF=4;

while(!TI); //等待发送完 TI=0; ES=1;

DS18B20_dis(); }

delay1(5000); } }

void UART_init(void) //初始化异步传输时隙 {

SCON=0X50;//串口工作方式1,

TMOD=0X22;//定时器1工作方式2,8位自动重装 TH1=0XF3; //设置T1初始值

TL1=0XF3;//波特率为2400(12MHZ)(11.0592MHZ填充值为0xf4) TR1=1; //启动T1定时器 EA=1;//开总中断 ES=1;//guan串口中断 }

void delay1(unsigned int delay_time) //时隙延迟 {

while(delay_time); }

void DS18B20_dis() {

write_command(0x80);//输入命令 delay1(500);

write_data(0x30+temp10/10); write_data(0x30+temp10); write_data (0xdf);

32

基于MCS51的两片单片机之间的串行通信接口设计

write_data ('C'); }

void ser() interrupt 4 //空闲时隙中断 { RI=0; AA=SBUF; if(AA<100) {

temp1=AA; } else ; }

B机程序: #include #include \

sbit LED1=P2^6; //定义一个可寻址变量 sbit LED2=P2^7; sbit KB=P1^7; unsigned char aa;

void UART_init(void);//设置初始值为空 unsigned int temp1 = 0; void main() {

UART_init(); init_ds18b20(); delay(50000);//延迟 LED1=1; LED2=1;

while(1)

33

基于MCS51的两片单片机之间的串行通信接口设计

{

if(aa==5) { LED2=LED2; LED1=LED1;

delay(50000);//延迟 delay(50000); }

else if(KB==0) { ES=0;

delay(5000);//延迟 if(KB==0) {

SBUF=100;

while(!TI);//等待发送完

TI=0; //发送标志位置零等待下次发送 while(!KB); } ES=1;

} else { ES=0; LED1=1; LED2=1;

temp1= rd_temperature();//选择温度 SBUF=temp1;

while(!TI);//等待接受完成

TI=0; //发送标志位置,等待下次发送

34

基于MCS51的两片单片机之间的串行通信接口设计

ES=1; }

delay(50000); //延迟 } }

void UART_init(void) //同步中断 {

SCON=0X50;//串口工作方式1,

TMOD=0X22;//定时器1工作方式2,8位自动重装 TH1=0XF3;

TL1=0XF3;//波特率为2400(12MHZ)(11.0592MHZ填充值为0xf4) TR1=1;

EA=1;//开总中断 ES=1;//开串口中断 }

void ser() interrupt 4 //中断 {

RI=0;//关闭接受使能位,等待下次接送 aa=SBUF; }

35

  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

基于MCS51的两片单片机之间的串行通信接口设计 while(1) //开启死循环 { if(K1==0) { ES=0; delay1(5000); if(K1==0) { SBUF=5; while(!TI); // 等待发送完 TI=0; while(!K1); } ES=1; } else if(AA==100) { AA=0; P1=Table[i]; i++; if(i>9) { i=0; } delay1(5000); } else { ES=0; TI=0; 31

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com