MCS51系列单片机双机并行互连的实现方法
51单片机实现双机通信(自己整理的)

左边1号机,右边2号机,,功能实现1号机程序#include<reg51.h>#define uint unsigned int#define uchar unsigned charsbit p10=P1^0;uchar a,b,kk;//uchar code d_c[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff}; void delay_ms(uchar y){uchar i;while(y--)for(i=0;i<120;i++);}void put(uchar x) //发送函数{SBUF=x; //SBUF:串行口数据缓冲器while(TI==0); //等待发送结束TI=0;}void main(){uchar j;SCON=0x40; //串行口工作方式1,8位通用异步发送器TMOD=0x20; //定时器1工作方式2PCON=0x00; //波特率不倍增TH1=0xf4;TL1=0xf4; //波特率2400TR1=1; //定时器1开始计时P2=0xc0;while(1){if(p10==0&&j==0){delay_ms(15);while(p10==0);kk=1;P2=0xf9;j=1;}if(p10==0&&j==1){delay_ms(15);while(p10==0);kk=2;P2=0xa4;j=2;}if(p10==0&&j==2){delay_ms(15);while(p10==0);kk=3;P2=0xb0;j=0;}if(kk==1)put('A');if(kk==2)put('B');if(kk==3)put('C');delay_ms(10);}}/*********************************************************************** if(p10==0&&j==0){delay_ms(15);while(p10==0);kk=0;P2=~0xf9;j=1;}if(p10==0&&j==1){delay_ms(15);while(p10==0);kk=1;P2=~0xa4;j=2;}if(p10==0&&j==2){delay_ms(15);while(p10==0);kk=2;P2=~0xc0;j=0;}if(kk==0)put('A');if(kk==1)put('B');if(kk==2)put('C');delay_ms(100);*********************************************************** if(p10==0){delay_ms(15);while(p10==0);number=(number+1)%4;}switch(oper){case 0:break;case 1:put('A');P2=~0xf9;break;case 2:put('B');P2=~0xa4;break;case 3:put('C');P2=~0xc0;break;}delay_ms(10);******************************************************************** if(p10==0){delay_ms(15);while(p10==0);j=(j+1)%3;}switch(j){case 0:put('A');P2=~0xf9;break;case 1:put('B');P2=~0xa4;break;case 2:put('C');P2=~0xc0;break;}delay_ms(10);*/2号机程序。
3.1MCS-51单片机的并行IO口

一、并行I/O口的功能结构
2、接口功能 (2)通用I/O接口
(四)P0口
此时“控制”信号为“0”,多路开关 MUX向下,输出驱动器处于开漏状态,故需 外接上拉电阻,这种情况下,电路结构与P1 相同,所以也是一个准双向口,当要作为输 入时,必须先向口锁存器写“1”。
一、并行I/O口的功能结构
(四)P0口
这是由接口的特殊结构所决定的。每一个 口都包含一个锁存器,一个输出驱动器和两 个(P3口为3个)输入缓冲器。各口的结构也 P 3 有些差异,下面分别介绍。
一、并行I/O口的功能结构
1、接口结构
(一)P1口
P1口一位的结构如下图所示:
图2.15
一、并行I/O口的功能结构
1、接口结构
(一)P1口
接口结构中锁存器起输出锁存作用, 8位锁存器组成特殊功能寄存器P1,场 效应管和上拉电阻组成输出驱动器,以 增大负载能力,三态门1和三态门2分别 用于控制输入引脚和锁存器的状态。
作为I/O口应用的一个实例,下面介绍 8031单片机的最小应用系统如下图所示
二、产生接口控制信号的指令
(四)P0口
8051指令系统中能与接口打交道的指令 大体可分两类 1.一般的输入/输出指令 2.“读-修改-写”指 令
二、产生接口控制信号的指令
1.一般的输入输出指令
(四)P0口
输入指令执行时,内部产生“读引脚”信号, 直接从口线读入,亦称“读引脚”指令。 下面是属于这种指令的各种实例:
二、产生接口控制信号的指令
(四)P0口 2.“读-修改-写”指令 INC P2 接口锁存器加1 DEC P1 接口锁存器内容减1 DJNZ P3,LOOP 减1后不为零则跳转 还有三条虽不明显,但也属此列: MOV P1.1,C CLR P1.1 SETB P1.1 将进位位送接口的某位 清接口的某一位 接口的某一位置位
51单片机的双击通信

一设计题目:双机通信系统二实验描述:设计一个双机通信系统,实现按键数据的互发及显示功能。
三实验要求:利用两片8051单片机完成双机通信(A机和B机),A、B机发至对方数据可用数码管显示,通信过程用按键控制,发送内容自定。
四实验元件:ST89C51(两片)、电容(30PF*4、10UF*4)、数码管(共阳)、晶振(11.059 2MHZ)、小按键等。
五具体设计:1:设计介绍1.1 串行通信介绍广义地讲,终端(如计算机等)与其他终端、终端与外部设备(如打印机、显示器等)之间的信息交换称为数据通信(Data Communication)。
数据通信方式有两种:串行通信和并行通信。
并行通信:数据的各位同时进行传送(接收和发送),其优点是传递速度快、效率高,多用在实时、快速的场合。
串行通信:数据逐位传送,优点是数据只需要一根数据线就能完成传送,联结介质简单,成本低。
1.2 8051简介51内部结构:8051单片机包含中央处理器、程序存储器(ROM)、数据存储器(RAM)、定时/计数器、并行接口、串行接口和中断系统等几大单元及数据总线、地址总线和控制总线等三大总线,·中央处理器:中央处理器(CPU)是整个单片机的核心部件,是8位数据宽度的处理器,能处理8位二进制数据或代码,CPU负责控制、指挥和调度整个单元系统协调的工作,完成运算和控制输入输出功能等操作。
·数据存储器(RAM):8051内部有128个8位用户数据存储单元 8051内部有128个8位用户数据存储单元和128个专用寄存器单元,它们是统一编址的,专用寄存器只能用于存放控制指令数据,用户只能访问,而不能用于存放用户数据,所以,用户能使用的的RAM只有128个,可存放读写的数据,运算的中间结果或用户定义的字型表。
·程序存储器(ROM):8051共有4096个8位掩膜ROM,用于存放用户程序,原始数据或表格。
·定时/计数器(ROM):8051有两个16位的可编程定时/计数器,以实现定时或计数产生中断用于控制程序转向。
MCS-51单片机的并行接口

1.1 P0口
口结构
P0口
“读-改-写”类指令 先读端口,然后对读入的数据进行修改,最后再写回到端口 不直接读取引脚上的数据而读锁存器Q端内容,是为了消除错
读引脚电平的可能性
P0口
P0既可用作地址/数据总线,又可用作通用I/O端口 用作输出端口时,输出级为开漏电路,在驱动NMOS电路时应
例 某接口电路与单片机使用一条线传送握手信号。双方约定, 单片机先向接口发送一个1和一个0,随后接口电路向单片机回 送一个1
单片机原理与应用
单片机原理与应用
MCS-51单片机的并行接口
MCS-51单片机本身提供了4个8位的并行端口,分别记做P0、 P1、P2和P3,共有32条I/O口线
都是双向端口,每个口包含一个锁存器(即特殊功能寄存器P0、 P1、P2和P3)、一个输出驱动器和输入缓冲器
端口和其中的锁存器都表示为P0、P1、P2、P3 结构不同,功能各异
1.4 P3口
口结构
P3口
作为通用I/O口使用时,工作原理与P1、P2口类似,但第二功 能输出端应保持高电平,使锁存器输出端Q内容能通过与非门
P3口的各位都具有第二功能
P3口
P3口的第二功能输入信号
P3.0——RxD,串行口数据接收 P3.2—— INT0#,外部中断0请求信号输入 P3.3—— INT1#,外部中断1请求信号输入 P3.4——T0,定时器/计数器0外部计数脉冲输入 P3.5——T1,定时器/计数器1外部计数脉冲输入
ORL ANL XRL CPL
P1, #3CH ;将P1中间4位置位
P1, #0C3H ;将P1中间4位清零
P1, #03H ;将P1最低2位取反
P1.5
;取反P1.5
MCS-51系列单片机主从式并行互连的实现方法

互 连 来 进 行 数 据 通 信 。根 据 单 片 机 I0 接 口 的 特 点 , 些 / 这 接 口的 引脚 可 直 接 相 连 , 而 使 两 单 片 机 之 间并 行 通 信 接 从 口的 实 现 不 用 另 外 的 硬 件 电 路 设 备 。基 于 这 种 情 况 , 计 设 时 可根 据 不 同 的 使 用 要 求 , 采 用 不 同 的 并 行 连 接 方 法 。 来 下 面介 绍 在 两个 单 片 机之 间 进 行 三 种 主 从 式 并 行 通 信 的实
如P O口和 P 1口 的 4根 线 做 控 制 信 号线 。
单 片机 A
8位端 口
DI R S B T
A K C
单片机 B
DR I IT N
C Ⅱ }[
C K H
A K C
图 2 主从 双 向 并行 通 信 接 口的 原 理 图
MC 5 S 1系列单 片机 主从 式并行
互 连 的实 现方 法
管 力锐 魏 丽娜
( 林 航 天 工 业 高等 专 科 学校 机 械 工 程 系 广 西 桂 桂林 5 10 ) 4 0 4
摘 要
关键 词
论文介绍了用两台 Mc 一5 系列单片机进行主从式单向并行通信、 s 1 主从双向并行通信和无主从双向并行通
MC - 5 系 列 单 片 机 ( 下 简 称 “ 片 机 ” 除 四 个 I 取 数 据 , 完 后 , 用 P . S 1 以 单 ) / 读 利 1 0发 B S 信 号 进 行 应 答 , 机 U Y 主 0 口外 , 有 R 还 AM 、 OM 两 个 1 R 6位 的 定 时 器/ 数 器 、 计 一 A 在 检 查 到 端 口线 P . 3 2上 C K 的 应 答 信 号 后 , 可 以发 S 就
MCS-51单片机并行口的结构与操作

华中科技大学光学与电子信息学院单片机( 2015 -- 2016学年度第一学期)题目:MCS-51单片机并行端口结构与操作院系:光学与电子信息学院班级:学号:学生姓名:指导教师:成绩:日期: 2015年 9月 21日MCS—51单片机并行口的结构与操作一、MCS—51单片机简介MCS—51单片机是美国INTE公司于1980年推出的产品,与MCS-48单片机相比,它的结构更先进,功能更强,在原来的基础上增加了更多的电路单元和指令,指令数达111条,MCS-51单片机可以算是相当成功的产品,一直到现在,MCS-51系列或其兼容的单片机仍是应用的主流产品,各高校及专业学校的培训教材仍与MCS—51单片机作为代表进行理论基础学习.MCS-51系列单片机主要包括8031、8051和8751等通用产品,其主要功能如下:8位CPU、4kbytes 程序存储器(ROM)、128bytes的数据存储器(RAM)、32条I/O口线、111条指令,大部分为单字节指令、21个专用寄存器、2个可编程定时/计数器、5个中断源,2个优先级、一个全双工串行通信口、外部数据存储器寻址空间为64kB、外部程序存储器寻址空间为64kB、逻辑操作位寻址功能、双列直插40PinDIP封装、单一+5V电源供电。
如图所示:1。
结构(1)中央处理单元(8位)数据处理、测试位,置位,复位位操作(2)只读存储器(4KB或8KB)永久性存储应用程序,掩模ROM、EPROM、EEPROM(3)随机存取内存(128B、128B SFR)在程序运行时存储工作变量和资料(4)并行输入/输出口(I / O)(32条)作系统总线、扩展外存、I / O接口芯片(5)串行输入/输出口(2条)串行通信、扩展I / O接口芯片(6)定时/计数器(16位、加1计数)计满溢出、中断标志置位、向CPU提出中断请求,与CPU之间独立工作(7)时钟电路内振、外振。
(8)中断系统五个中断源、2级优先。
51单片机双机串行通信设计

51单片机双机串行通信设计51单片机是一款广泛应用于嵌入式系统中的微控制器,具有高性能和低功耗的特点。
在一些场景中,需要使用51单片机之间进行双机串行通信,以实现数据传输和协同工作。
本文将介绍51单片机双机串行通信的设计,包括硬件连接和软件编程。
一、硬件连接1.串行通信口选择:51单片机具有多个串行通信口,如UART、SPI 和I2C等。
在双机串行通信中,可以选择其中一个串行通信口作为数据传输的接口。
一般来说,UART是最常用的串行通信口之一,因为它的硬件接口简单且易于使用。
2.引脚连接:选定UART口作为串行通信口后,需要将两个单片机之间的TX(发送)和RX(接收)引脚相连。
具体的引脚连接方式取决于所使用的单片机和外设,但一般原则上是将两个单片机的TX和RX引脚交叉连接。
二、软件编程1.串行通信初始化:首先需要通过软件编程来初始化串行通信口。
在51单片机中,可以通过设置相应的寄存器来配置波特率和其他参数。
具体的初始化代码可以使用C语言编写,并根据所使用的开发工具进行相应的配置。
2.发送数据:发送数据时,可以通过写入相应的寄存器来传输数据。
在51单片机中,通过将数据写入UART的发送寄存器,即可将数据发送出去。
发送数据的代码通常包括以下几个步骤:(1)设置发送寄存器;(2)等待数据发送完成;(3)清除数据发送完成标志位。
3.接收数据:接收数据时,需要通过读取相应的寄存器来获取接收到的数据。
在51单片机中,可以通过读取UART的接收寄存器,即可获取到接收到的数据。
接收数据的代码通常包括以下几个步骤:(1)等待数据接收完成;(2)读取接收寄存器中的数据;(3)清除数据接收完成标志位。
4.数据处理:接收到数据后,可以进行相应的数据处理。
根据具体的应用场景,可以对接收到的数据进行解析、计算或其他操作。
数据处理的代码可以根据具体的需求进行编写。
5.中断服务程序:在双机串行通信中,使用中断可以提高通信的效率。
MCS-51系列单片机双机互连方法探讨

MCS-51系列单片机双机互连方法探讨
王哲
【期刊名称】《现代商贸工业》
【年(卷),期】2009(021)021
【摘要】介绍了MCS-51系列两单片机之间采用单向并行通信接口、主从双向并行通信接口、无主从双向并行通信操作实现双机互连的方法,分析了在每一种并行通信接口方式下数据传送的特点,为单片机系统互连提供了新的方法.
【总页数】2页(P280-281)
【作者】王哲
【作者单位】陕西工业职业技术学院,陕西咸阳,712000
【正文语种】中文
【中图分类】TP368.1
【相关文献】
1.MCS-51系列单片机主从式并行互连的实现方法 [J], 管力锐;魏丽娜
2.MCS-51单片机双机通信实现程序原代码 [J], 王克俭;杨断利;王兰英;赵洋;杨素林地
3.MCS51系列单片机双机并行互连的实现方法 [J], 崔如春
4.基于MCS-51单片机技术实训台中的按键控制双机串行通信实训模块设计研究与实现 [J], 张玉馥
5.MCS-51系列单片机存储器与其位寻址研究 [J], 张文宇;黄程旭;杨桂梅;黄新蕊;朱硕;郑焙天;谭保华
因版权原因,仅展示原文概要,查看原文内容请购买。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MCS51系列单片机双机并行互连的实现方法
摘要:介绍了在同一系统内,MCS51系列两单片机之间采用单向并行通信接口、主从双向并行通信接口、无主从双向并行通信操作实现双机互连的方法,分析了在每一种通信接口工作方式下数据传送的特点。
在三种并行通信接口为单片机应用系统扩充硬件资源的设计提供了新的途径。
关键词:单片机并行通信接口数据传送
由于MCS51系列单片机具有性能稳定、工作可靠、价格低廉等特点,因此其应用相当广泛。
一个MCS51系列的单片机(如Atmel89cxx)内部包含有RAM、FLASH ROM、两个或者三个16位的定时器/计数器、一个通用异步串行通信控制器(UART)等多种资源。
但即便如此,在一些相对复杂的单片机应用系统中,仅仅一个单片机资源还是不够的,因此而常常需要扩充I/O接口、定时器/计数器、串行通信接口、RAM、ROM等。
采用通用的标准器件进行扩充是通常的做法,但将单片机本身作为一个通用的扩充器件来使用,也不失为一个好的方法。
在这种情况下,一个系统中就使用了两个或两个以上的单片机,而单片机之间就要通过互连来进行数据通信。
MCS51系列的单片机(以下简称单片机)都带有串口,利用串口进行互连通信极为方便,其各种连接方式在许多书籍和资料上都有介绍,在此不再重述。
但如果系统要求扩充的资源是对外连接的串口,或对相互之间的数据传送有一定的速度要求,则单片机的串口就不能用作系统内两单片机的通信接口了。
所幸的是,单片机的并行端口也能相互连接来进行数据通信。
根据单片机端口内部结构的特点,这些端口的端口线可以直接相连,从而使两单片机之间并行通信接口的实现不用另外的硬件电路设备。
基于这种情况,设计时,可根据不同的使用要求,来采用不同的并行连接方法。
下面介绍在两个单片机之间进行三种并行通信接口的实现方法。
1 单向并行通信接口的实现
在应用中,如果只需一个单片机向另一个单片机传送数据,则可以采用单向并行通信接口方式,这种方式较为简单。
图1所示为单向并行通信接口的组成方法。
图中,单片机A为数据发送方,单片机B为数据接收方,8位端口可以是P0~3的任何一个。
数据传送的流程是:单片机A将数据送到端口后,通过STB信号中断单片机B,单片机B进入中断并从端口读取数据,读完后,利用BUSY信号进行应答,单片机A在检查到端口线CHK上的应答信号后,就可以发送下一个数据了。
以上是采用中断方式进行数据传送的具体方法。
当然,单片机B也可以采用查询方式接收数据。
利用单向并行通信接口方法的优点是可以充分利用单片机的资源来扩充整个系统的串行通信接口、并行接口、定时器等部件。
2 主从并行通信接口的实现
主从并行通信接口的特点是两单片机之间能够通过并行通信接口将数据发送到对方,但这种方法必须有一个单片机处在主机状态,另一个单片机处在从机状态。
图2为主从并行通信接口原理图。
单片机A是主机,单片机B是从机,该接口使用了一个8位端口(如P0或P1)和4根控制信号线。
在主从工作方式下,该接口的工作方式有主机发送从机接收和主机接收从机发送等两种情况。
2.1 主机发送从机接收方式的主机工作流程
主发从收方式的工作流程如下:
(1)主机设置数据传送方法控制位DIR为0,以表示主机有数据发送到从机;
(2)主机在STB端口产生一个负脉冲,以使从机进入中断,并准备接收数据;
(3)主机将数据送8位数据端口,再设定ACK信号表示数据有效;
(4)主机检查CHK端口,等待从机从8位端口取走数据;
(5)数据发送完成返回。
2.2 主机接收从机发送时的主机工作流程
主机接收从机发送方式时的工作流程如下:
(1)主机设置数据传送方向控制位DIR为1,以表示主机将从从机读取数据;
(2)主机在STB端口产生一个负脉冲,以使从机进入中断,并准备发送数据;
(3)主机查询CHK端口,等待从机将数据送到8位端口上;
(4)主机从8位端口上读取数据,再设定ACK信号以表示数据已被读取;
(5)数据接收完成返回。
2.3 从机工作流程
在主从并行通信接口工作方式下,无论从机是接收数据还是发送数据,都是在中断(也可以是查询方式)方式下进行的,从机的工作流程如下:
(1)进入中断服务程序;
(2)检查数据传送的方向;
(3)如果DIR为0,则等待CHK信号有效,再从8位端读取数据,读完后设定ACK信号有效;
(4)如果DIR为1,从机将数据送到8位端上,再设定ACK为有效,并等待主机取走数据(即CHK信号有效);
(5)退出中断服务程序。
3 无主从双向并行通信接口的实现
无主从双向并行通信接口的特点是两个单片机处在平等的地位,两个单片机均可随时提出申请,向对方发送数据,当然也可通过简单的接口协议从对方读取数据。
这种情况下,就有可能出现两个单片机同时提出使用8位端口的申请而发生冲突,从而影响双方数据的传送。
要解决这个问题,就要求每一方必须在数据传送之前进行检查,以判断8位端口是否被对方所使用,从而避免冲突的发生。
图3是无从双向并行通信接口的原理图。
该接口中采用了5根控制信号线,其中CHK/ACK控制信号线,其中CHK/ACK控制信号线的功能可以复用。
8位端口可以是P0、P1或其它8位I/O口。
在无主从双向并行通信接口中,由于单片机A与单片机B没有主从关系而处在平等位置,所以单片机B与单片机A的数据接收发送流程完全相同。
这里只说明单片机A的数据接收发送流程。
3.1 数据发送流程
下面给出单片机A的数据发送流程:
(1)检查CHKREQ,判断单片机B是否提出了数据传送申请;
(2)如果单片机B提出了申请,则转a继续等待;否则,单片机A提出申请,将REQ置为有效;
(3)再次检查CHKREQ,判断单片机B是否同时提出了申请;
(4)如果单片机B提出了申请,则发生冲突;清除REQ并延时;然后执行(1);
(5)将数据送8位端口,设定STB有效;
(6)检查CHK,等待单片机B将数据取走;
(7)检查单片机A的数据是否全部送完,如没有则转执行(5);
(8)撤销REQ信号,释放8位端口;
(9)数据发送完成,退出流程。
3.2 数据接收流程
单片机A的数据接收流程如下:
(1)进入中断服务流程;
(2)从8位端口读取数据;
(3)设置ACK信号有效,表示数据已成功读取;
(4)退出中断服务流程。
4 三种并行接口方式的特性分析
本文介绍的三种并行通信接口连接方式能够适用于不同的要求。
下面分别对采用三种通信接口工作方式的数据通信响应时间进行分析。
假设单片机的工作时钟频率为24MHz,8位端口为P0口。
系统中每一个单片机只有一个中断源。
在单个中断源情况下的中断响应时间为3~8μs。
在单向并行通信接口工作方式下,数据只从单片机A向单片机B传送,假设接收方单片机B中断接收。
个字节的传送过程将包括数据发送端口、通知接收方、等待接收方的已接收应答等三个部分。
其程序的一般写法为:
MOV P0,#DATA
CLR STB
JB CHK,$
如各条指令的执行时间分别为1μs、1μs、3~8μs。
那么,这种方式下,一个字节的传送时间在10μs左右,最短可到5μs,因此数据的数传率较高。
在主从并行通信接口方式下,数据传送包括接收和发送两个方向,由于数据传送均在主机控制下进行,且数据的接收和发送两个方向的时间大体相等。
根据其数据传送流程,主机发送数据的程序如下:
CLR DIR
CLR STB
MOV P0,#DATA
SETB ACK
JB CHK,$
由于该程序前4条指令的执行时间均为1μs,最后一条指令的执行时间为等待从机的响应时间为3~8μs,这种方式下一个字节的传送时间在12μs左右,最短可到7μs,可见仍有效高的数传率。
在无主从并行通信接口方式下,文中只讨论了主动向对方发送数据的方式,而没有讨论主动从对方读取数据的方式,这是因为通过简单的接口协议可以使对方主动发送数据,从而达到读取数据的目的。
根据图3和其数据发送流程可知,在没有8位数据端口使用冲突的情况下,其数据传送的基本步骤与主从方式数据传送的步骤基本相同,但需要对8位端口的使用进行声明确认的撤销,这需要执行至少4条指令,时间约需4μs,因此,这种试上单字节数据的传送时间在11~18μs。
当遇上8位数据端口使用有冲突时,则数据传送的时间还会受8位数据端口被占时间的影响,因而变得不确定。
5 结束语
由于MCS51系列单片机已衍生出了许多规格和型号的产品,且使用起来方便灵活,应用相当广泛,因此讨论它们的一般应用是非常有意义的。
MCS51系列单片机的直接并行互连具有一定的实用价值,能简化许多应用系统的硬件设计。
在许多的应用系统中,完全可以把MCS51系列单片机当作普通的可编程器件来使用。
本文介绍的单向并行通信接口中的接收方单片机,主从并行通信接口中的从机都是这样使用的。