- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)