基于51单片机非串口双机通信.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于单片机的双机非串口通信系统 一、总体设计: 在一块单片机上判断按键以及拟定接收协议,当时钟信号为高电平且按键按下,将键值通过普通IO口发送出去,另一块单片机收到IO口发送来的键值后,将对应键值以0-9方式显示在数码管上。 设计思路: 双机普通IO口通信采用了限制更小的链接方式,即将一个单片机的输出作为另一个的输入进行显示。这种方式需要自己拟定发送方和接收方之间的协议。程序书写相对比较麻烦。 总体设计: 硬件设计: 单片机主机P1.0口上接一按键,P1.4,P1.5接从机的P1.4,P1.5。从机的P2口上接一位的数码管。 三、软件设计: 流程图: 主机: Main: Key : 检测按键是否按下,如有按键按下则发送数据 Send:发送数据,时钟线高电平时发送,低电平时忽略,不操作。 从机: Main: accept:接收数据,依据发送的协议将时钟周期分为16个,其中8个高电平,8个低电平,每当为高电平时则读出数据线上的数据,为低电平时不读数据。 Display: 四、总结 该协议是仿照IIC协议所做的,程序指定时钟线为高时数据有效,(由仿真时的示波器可以看出其时序图),发送数据时,是将数据不断左移,并将其最高位发送出去,接受端与此类似,将所接收到的数据不断左移,直至八位数据填充满 附:源程序 B主机: #includereg52.h #define uint unsigned int #define uchar unsigned char sbit DAT=P1^4; //定义数据线 sbit SKL=P1^5; //定义时钟线 uchar tmp[]={0,0,0,0,0,0,0,0}; uchar table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; //共阴极Led显示数字0~9 /*定义延时函数*/ void delay(uint x) { uint i,j; for(i=x;i0;i--) for(j=100;j0;j--); } /*定义接收函数*/ void accept() { uint i=0,r=0; //定义变量 while(i16){ if((SKL==1)(i%2==0)){ //判断时钟信号是否为1 tmp[r]=DAT; //将数据赋给数组 i++;r++;} //变量自增 if((SKL==0)(i%2==1)){i++;} //判断时钟信号是否为0 } } /*显示子程序*/ void display(uchar x) { P2=table[x]; //将传入的参数在P2口输出 delay(1300); //调用延时子程序 } /*主函数*/ void main() { uchar n,num,temp=0x00; //定义变量 while(1) {accept(); //接受子程序 for(n=0;n8;n++) { temp=(temp1)|tmp[n] ; //将变量值左移并或上数组值并赋给temp } display(temp); //调用延时程序 } } A主机: #includereg52.h #define uint unsigned int #define uchar unsigned char sbit s0=P1^0; //定义按键 sbit DAT=P1^4;//定义数据线 sbit SKL=P1^5;//定义时钟线 /*定义延时函数,在12M晶振中,延时时长为xms*/ uchar dat=0; void delay(uint x) { uint i,j; for(i=x;i0;i--) for(j=100;j0;j--); } /* 发送子程序 */ void send(uchar d) { uint i; //定义局部变量 for(i=0;i8;i++) { d=d1; //数据左移 SKL=1; //时钟信号拉高 DAT=CY; //将最高位赋值给数据 delay(1); //调用延时 SKL=0

文档评论(0)

0520 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档