#include <reg51.h>
#include <absacc.h>
#define TR 1
#define uchar unsigned char
#define uint unsigned int
uchar idata buf[10]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09}; //从机1发送的数据
uchar idata buf1[10]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x08,0x09}; //从机2发送的数据
uchar idata buf2[3]; //接受从机的数据
uchar data1,data2,data3;
uchar pf,addr,TRR,count,count1;
uchar flag,flag1,flag2=3;
uchar i;
sbit key1=P2^0;
/************延时程序************/
void delay(uchar k)
{
uchar j;
while((k--)!=0)
{
for(j=0;j<125;j++)
{;}
}
}
void init(void)
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
PCON=0x00;
TR1=1;
SCON=0xd0;
}
void send(uchar addr,uchar TRR)
{
TB8=1;
key1=1; //TB8置1
SBUF=addr; //发送从机的地址
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0)
{
;
}
data1=SBUF; //接受从机地址并检验
RI=0;
if(data1!=addr) //从机地址有错误
{
flag2=0;
}
else{ //从机地址正确--------是发送数据标志0X01
if(TRR==0x01)
{
TB8=0; //TB8置0
key1=1;
SBUF=TRR;
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //接受从机状态
{
;
}
data3=SBUF;
RI=0;
if(data3!=TRR) //从机没有就绪
{
flag2=0;
}
else{ //从机就绪
pf=0; //清效验位
key1=1;
for(i=0;i<=9;i++) //发送数据
{
TB8=0;
SBUF=buf[i];
pf+=buf[i];
while(TI==0)
{
;
}
TI=0;
}
TB8=0;
SBUF=pf; //发送效验和
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //主机接受从机是否正确接受数据
{
;
}
data2=SBUF;
RI=0;
if(data2==0xcc) //如果正确结束数据通信
{
flag2=3; //通信结束标志
}
else{
flag2=0; //如果不正确重新通信------即重新通信标志
}
}
}
if(TRR==0x02)
{ //是接受从机数据标志------即TRR=0X0
TB8=0;
key1=1;
SBUF=TRR; //发送接受标志0X02
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //接受从机的状态
{
;
}
data3=SBUF;
RI=0;
if(data3!=TRR) //从机没有就绪
{
flag2=0;
}
else{ key1=0; //从机就绪---主机接受数据
pf=0;
for(i=0;i<=2;i++)
{
while(RI==0)
{
;
}
buf2[i]=SBUF; //接受从机发送的数据
pf+=buf2[i];
RI=0;
}
key1=0;
while(RI==0) //接受从机的效验和
{
;
}
data2=SBUF;
RI=0;
if(pf==data2) //比较效验和
{
flag2=3; //效验和正确标志
}
else{
flag2=0; //效验和错误标志
}
}
}
}
}
void display(void)
{
if(flag2==3) //如果接受正确开始显示
{
for(i=0;i<=2;i++)
{
P0=buf2[i];
delay(50);
}
}
}
void main(void)
{
delay(500);
init();
count=2;
count1=2;
while(1)
{
while(count!=0)
{
count--;
send(0x03,0x01); //主机---从机1交换数据子函数
send(0x03,0x02);
display();
}
while(count1!=0)
{ count1--;
send(0x04,0x01); //主机---从机1交换数据子函数
send(0x04,0x02);
display();
}
if(count1==0)
{
count1=2;
count=2;
}
}
}
荣华富贵8
- 粉丝: 222
- 资源: 7653
最新资源
- MATLAB代码:多种调度模式下的光储电站经济性最优储能容量配置分析 关键词:光储电站 优化配置 经济性分析 参考文档:《多种调度模式下的光储电站经济性最优储能容量配置分析》仅参考 仿真平台:MATL
- 基于自抗扰(ADRC)的永磁同步电机矢量控制
- 锂电池项目三菱Q06UDV,威纶通触摸屏程序 LG化学全自动锂电池化成分容一体机 (2套PLC程序+1套普洛菲斯触摸屏程序) 三菱PLC程序大型锂电项目: 项目说明如下: 1.plc程序,触摸屏程序
- FPGA图像处理, 每个算法都包括matlab算法、modelsim仿真、小梅哥AC620上板工程、正点原子新起点 开拓者上板工程
- MATLAB环境下一种基于小波散射网络的纹理图像分类方法与基于小波散射变和深度学习的寄生虫感染图像分类方法 算法运行环境为MATLAB R2021b 1.主要讲解如何利用小波散射网络对二维纹理图像进行
- 移相全桥电路,psfb,dcdc
- 基于博途1200PLC和组态王的起重机仿真控制系统
- 基于博途1200 plc的邮件分拣控制系统 软件版本:V15
- mmc模块化多电平流器仿真,7电平闭环控制,外环控直流电压,有功,无功均有,已单独加了电容电压平衡和二倍频环流抑制,采用载波移相调制 可供学习参考
- 记录算法工程师实习招聘面试准备过程中所掌握的知识.zip
- 对于学习者来说,最好的习惯之一应该是进行有规律的自测,重新校准自己知道什么、不知道什么。每日面试小测
- MATLAB代码:基于数据驱动的模型预测控制电力系统机组组合优化 关键词:数据驱动 模型预测控制 闭环 机组组合问题 优化调度 参考文档:Feature-driven-Economic-Impro
- 模糊PID控制器的C语言实现.zip
- 六轴机械臂DH正向建模及调用GPU梯度下降法求解逆向解_Gradient-De
- 利用stm32进行机械臂的制作与控制。_robotic-control.zip
- 有关于机械手臂移动_Move_hand.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈