基于AT89C51单片机的双机串行通信设计Word文档格式.doc
《基于AT89C51单片机的双机串行通信设计Word文档格式.doc》由会员分享,可在线阅读,更多相关《基于AT89C51单片机的双机串行通信设计Word文档格式.doc(22页珍藏版)》请在冰点文库上搜索。
![基于AT89C51单片机的双机串行通信设计Word文档格式.doc](https://file1.bingdoc.com/fileroot1/2023-5/13/aaf46084-579b-466f-b079-47def97564ea/aaf46084-579b-466f-b079-47def97564ea1.gif)
5硬件设计………………………………………………………..……………….......…....6
5.151单片机串行接口的结构……………………………………………….........….6
5.2整体电路设计………………………………………………………..…….........…8
6软件设计………………………………………………………..……………..…..…..….9
7联合调试………………………………………………………..………………..…....…11
8总结………………………………………………………..………………..………..…..12
参考文献………………………………………………………..………………..……......…13
附录………………………………………………………..………………..……….........….14
1设计目的
1.通过设计相关模块充分熟悉51单片机的最小系统的组成和原理;
2.通过软件仿真熟悉keil和proteus的配合使用;
3.通过软件编程熟悉51的C51编程规范;
2设计要求
两片单片机之间进行串行通信,A机将数据发送给B机,在B机的数码管上静态显示。
3基本原理
3.1串行通信
计算机与外界的信息交换称为通信。
在通信领域内,有两种数据通信方式:
并行通信和串行通信。
随着计算机网络化和微机分级分布式应用系统的发展,通信的功能越来越重要。
通信是指计算机与外界的信息传输,既包括计算机与计算机之间的传输,也包括计算机与外部设备,如终端、打印机和磁盘等设备之间的传输。
串行通信是指使用一条数据线,将数据一位一位地依次传输,每一位数据占据一个固定的时间长度。
其只需要少数几条线就可以在系统间交换信息,特别适用于计算机与计算机、计算机与外设之间的远距离通信。
3.2AT89C51单片机的主要工作特性
·
内含4KB的FLASH存储器,擦写次数1000次;
内含28字节的RAM;
具有32根可编程I/O线;
具有2个16位可编程定时器;
具有6个中断源、5个中断矢量、2级优先权的中断结构;
具有1个全双工的可编程串行通信接口;
具有一个数据指针DPTR;
两种低功耗工作模式,即空闲模式和掉电模式;
具有可编程的3级程序锁定定位;
AT89C51的工作电源电压为5(1±
0.2)V且典型值为5V,最高工作频率为24MHz.
AT89C51各部分的组成及功能:
外部中断
TXD
RXD
P0P1P2P3
扩展控制
振荡器和时钟电路
数据存储器
128字节
程序存储器
14KB
CPU
两个16位定时器
计数器
中断
控制
总线扩展控制器
并行可编程
I/O口
可编程
串行口
内部总线
3.2.1中央处理器
(1)运算器
运算器主要用来实现算术、逻辑运算和位操作。
其中包括算术和逻辑运算单元ALU、累加器ACC、B寄存器、程序状态字PSW和两个暂存器等。
ALU是运算电路的核心,实质上是一个全加器,完成基本的算术和逻辑运算。
算术运算包括加、减、乘、除、增量、减量、BCD码运算;
逻辑运算包括“与”、“或”、“异或”、左移位、右移位和半字节交换,以及位操作中的位置位、位复位等。
暂存器1和暂存器2是ALU的两个输入,用于暂存参与运算的数据。
ALU的输出也是两个:
一个是累加器,数据经运算后,其结果又通过内部总线返回到累加器;
另一个是程序状态字PSW,用于存储运算和操作结果的状态。
累加器是CPU使用最频繁的一个寄存器。
ACC既是ALU处理数据的来源,又是ALU运算结果的存放单元。
单片机与片外RAM或I/O扩展口进行数据交换必须通过ACC来进行。
B寄存器在乘法和除法指令中作为ALU的输入之一,另一个输入来自ACC。
运算结果存于AB寄存器中。
(2)控制器
控制器是识别指令并根据指令性质协调计算机内各组成单元进行工作的部件,主要包括程序计数器PC、PC增量器、指令寄存器、指令译码器、定时及控制逻辑电路等,其功能是控制指令的读入、译码和执行,并对指令执行过程进行定时和逻辑控制。
AT89C51单片机中,PC是一个16位的计数器,可对64KB程序存储器进行寻址。
复位时PC的内容是0000H.
(3)存储器
单片机内部的存储器分为程序存储器和数据存储器。
AT89C51单片机的程序存储器采用4KB的快速擦写存储器FlashMemory,编程和擦除完全是电器实现。
(4)外围接口电路
AT89C51单片机的外围接口电路主要包括:
4个可编程并行I/O口,1个可编程串行口,2个16位的可编程定时器以及中断系统等。
3.2.2存储器组织和特殊功能寄存器
AT89C51的存储器将程序存储器和数据存储器分开,并有各自的存储空间和访问指令。
它有4个存储空间:
片内存储器、片外存储器、片内数据存储器及片外存储器。
3.2.3时钟电路和工作时序
(1)振荡器电路原理振荡器
Rf
XTAL1
PD
&
÷
6
3
Q
2
(2)振荡电路的接法
外部振荡器信号
NC
XTAL2
GND
C1
C2
CND
3.3波特率选择
波特率(BoudRate)就是在串口通信中每秒能够发送的位数(bits/second)。
MCS-51串行端口在四种工作模式下有不同的波特率计算方法。
其中,模式0和模式2波特率计算很简单,请同学们参看教科书;
模式1和模式3的波特率选择相同,故在此仅以工作模式1为例来说明串口通信波特率的选择。
在串行端口工作于模式1,其波特率将由计时/计数器1来产生,通常设置定时器工作于模式2(自动再加模式)。
在此模式下波特率计算公式为:
波特率=(1+SMOD)*晶振频率/(384*(256-TH1))
其中,SMOD——寄存器PCON的第7位,称为波特率倍增位;
TH1——定时器的重载值。
在选择波特率的时候需要考虑两点:
首先,系统需要的通信速率。
这要根据系统的运作特点,确定通信的频率范围。
然后考虑通信时钟误差。
使用同一晶振频率在选择不同的通信速率时通信时钟误差会有很大差别。
为了通信的稳定,我们应该尽量选择时钟误差最小的频率进行通信。
下面举例说明波特率选择过程:
假设系统要求的通信频率在20000bit/s以下,晶振频率为12MHz,设置SMOD=1(即波特率倍增)。
则TH1=256-62500/波特率。
根据波特率取值表,我们知道可以选取的波特率有:
1200,2400,4800,9600,19200。
列计数器重载值,通信误差如下表:
因此,在通信中,最好选用波特率为1200,2400,4800中的一个。
3.4通信协议的使用
通信协议是通信设备在通信前的约定。
单片机、计算机有了协议这种约定,通信双方才能明白对方的意图,以进行下一步动作。
假定我们需要在PC机与单片机之间进行通信,在双方程式设计过程中,有如下约定:
0xA1:
单片机读取P0端口数据,并将读取数据返回PC机;
0xA2:
单片机从PC机接收一段控制数据;
0xA3:
单片机操作成功信息。
在系统工作过程中,单片机接收到PC机数据信息后,便查找协议,完成相应的操作。
当单片机接收到0xA1时,读取P0端口数据,并将读取数据返回PC机;
当单片机接收到0xA2时,单片机等待从PC机接收一段控制数据;
当PC接收到0xA3时,就表明单片机操作已经成功。
3.5双机通信
两台机器的通信方式可分为单工通信、半双工通信、双工通信,他们的通信原理及通信方式为:
单工通信:
是指消息只能单方向传输的工作方式。
单工通信信道是单向信道,发送端和接收端的身份是固定的,发送端只能发送信息,不能接收信息;
接收端只能接收信息,不能发送信息,数据信号仅从一端传送到另一端,即信息流是单方向的。
通信双方采用“按——讲”(PushToTalk,PTT)单工通信属于点到点的通信。
根据收发频率的异同,单工通信可分为同频通信和异频通信。
半双工通信:
这种通信方式可以实现双向的通信,但不能在两个方向上同时进行,必须轮流交替地进行。
也就是说,通信信道的每一段都可以是发送端,也可以是接端。
但同一时刻里,信息只能有一个传输方向。
如日常生活中的例子有步话机通信等。
双工通信:
双工通信是指在同一时刻信息可以进行双向传输,和打电话一样,说的同时也能听,边说边听。
这种发射机和接收机分别在两个不同的频率上能同时进行工作的双工机也称为异频双工机。
双工机的特点是使用方便,但线路设计较复杂,价格也较高。
4设计方案
软件通过通信协议进行发送接收,主机接10,21,32,43,54,65,76,87,98,09后给从机(从机静态显示),当从机接收到后,向从机发送代表0-f的数码管编码数组,相应显示10,21,32,43,54,65,76,87,98,09。
5硬件设计
5.151单片机串行接口的结构
(1)数据缓冲器(SBUF)
接受或发送的数据都要先送到SBUF缓存。
有两个,一个缓存,另一个接受,用同一直接地址99H,发送时用指令将数据送到SBUF即可启动发送;
接收时用指令将SBUF中接收到的数据取出。
(2)串行控制寄存器(PCON)
SCON用于串行通信方式的选择,收发控制及状态指示,各位含义如下:
SM0
SM1
SM2
REN
TB8
RB8
TI
RI
SM0,SM1:
串行接口工作方式选择位,这两位组合成00,01,10,11对应于工作方式0、1、2、3。
串行接口工作方式特点见下表
工作方式
功能
波特率
0
8位同步移位寄存器(用于I/O扩展)
fORC/12
1
10位异步串行通信(UART)
可变(T1溢出率*2SMOD/32)
11位异步串行通信(UART)
fORC/64或fORC/32
SM2:
多机通信控制位。
REN:
接收允许控制位。
软件置1允许接收;
软件置0禁止接收。
TB8:
方式2或3时,TB8为要发送的第9位数据,根据需要由软件置1或清0。
RB9:
在方式2或3时,RB8位接收到的第9位数据,实际为主机发送的第9位数据TB8,使从机根据这一位来判断主机发送的时呼叫地址还是要传送的数据。
TI:
发送中断标志。
发送完一帧数据后由硬件自动置位,并申请中断。
必须要软件清零后才能继续发送。
RI:
接收中断标志。
接收完一帧数据后由硬件自动置位,并申请中断。
必须要软件清零后才能继续接收。
(3)输入移位寄存器
接收的数据先串行进入输入移位寄存器,8位数据全移入后,再并行送入接收SBUF中。
(4)波特率发生器
波特率发生器用来控制串行通信的数据传输速率的,51系列单片机用定时器T1作为波特率发生器,T1设置在定时方式。
波特率时用来表示串行通信数据传输快慢程度的物理量,定义为每秒钟传送的数据位数。
(5)电源控制寄存器PCON
其最高位为SMOD。
5.2整体电路设计
51单片机的串行接口是一个全双工的接口,它可以作为UART(通用异步接受和发送器)用,也可以作为同步移位寄存器用,本系统共用两块单片机,每块单片机均选用AT89S51,最小系统也都一样。
由于两块单片机的主要任务是通信,为了得到准确的波特率,采用振荡频率为11.0592MHz的晶振,最终设计电路如下图3所示,发送方的数据由串行口TXD段输出,经过传输线将信号传送到接收端。
信号到达接收方串行口的接收端。
接受方接收后,通过P1口在数码管上显示接收的信息。
6软件设计
通过通信协议进行发送接收,主机先送CDH给从机,当从机接收到CDH后,向主机回答DCH。
主机收到DCH后就把数码表TAB[16]中的10个数据送给从机,并发送检验和。
从机收到16个数据并计算接收到数据的检验和,与主机发送来的检验和进行比较,若检验和相同则发送00H给主机;
否则发送FFH给主机,重新接受。
从机收到16个正确数据后送到一个数码管显示。
6.1串行通信软件实现
(1)串行口工作于方式3;
用定时器1产生4800bit/s的波特率,晶振频率为11.0592MHZ。
(2)功能:
将本机ROM中数码表TAB[16]中的16个数发送到从机,并保存在从机内部ROM中,从机收到这16个数据后送到一个数码管循环显示。
(3)通信协议:
主机首先发送连络信号(CDH),从机接收到之后返回一个连络信号(DCH)表示从机已准备好接收。
(4)通信过程使用第九位发送奇偶校验位。
(5)从机接收到一个数据后,立即进行奇偶校验,若数据没有错误,则返回00H,否则返回FFH。
(6)主机发送一个数据后,等待从机返回数据;
若为00H,则继续发送下一个数据,若为FFH,则重新发送数据。
6.2程序流程图
6.3接收方程序流程图
主程序开始
检验和相等?
程序初始化
接收数据,计算检验和
N
发送00H至主机
接收完成?
清除标志位
发送FFH,
重新接收
显示
7联合调试
在protues上进行仿真实验。
首先使用KeilC将编写完成的程序编译生成HEX文件,将HEX文件烧录到两片单片机中,进行仿真实验,结果如下图所示,可以看到,接收端已将接受到的数据完整的显示了出来。
注:
1.仿真的过程中并没有体现出单片机的最小系统的组成元素:
时钟电路和复位电路,但是实际的硬件电路中这两部分是必不可少的,此外,在实际测试中,程序是事先烧进单片机里的.
2.在数码管的共阴极与地之间接三极管是为了放大数码管的驱动电流,让数码管更加清楚的显示数据。
8课设中的心得体会
经过繁忙而又紧张的课程设计,终于顺利的完成了设计任务。
虽然在这段时间 里每天都那么繁忙,但是在这忙碌的过程中却得到了许多的收获。
经过课程设计,在查阅资料的过程中,学习了基于单片机的C语言程序设计,了解了单片机串行通信的基本知识,对于以后的学习和工作都有很大的益处。
在学习的过程中,也遇到了一些困难,比如开始的时候,由于发送端和接收端的通信协议没有做好,导致数据不能正确的传输,在解决问题的过程中,对于通信协议的实现有了深刻的认识。
参考文献
【1】胡伟.单片机C程序设计及应用实例.北京:
人民邮电出版社,2003
【2】韩毅刚.计算机通信技术.北京:
北京航空航天大学出版社,2007
【3】李朝青.单片机与PC机网络通信技术.北京:
北京航空航天大学出版,2007
【4】胡洪波.单片机原理与应用实验教程.湘潭大学出版社,2009.7
【5】单片机课程设计指导书皮大能北京理工大学出 2012.7
【6】8051单片机实践与应用吴金戎清华大学出版社 2003.8
【7】单片机技术基础教程与实践夏路易电子工业出版2008.1
【8】单片机原理及应用张毅刚高等教育出版社2012.11
附录
程序清单
#include<
reg51.h>
//字形码****按列取模
charcodetable[]={
0x5E,0x22,0x52,0xAC,0x7E,0xA1,0x52,0xBF, 0x7E,0xA8,0xD2,0xA5,0x5E,0x22,0x00,0x04,
0x7F,0xF8,0x46,0x60,0x41,0x80,0x46,0x60,
0xFF,0xFC,0x40,0x02,0x00,0x0E,0x00,0x00,
0x08,0x20,0x30,0x20,0x20,0x40,0x0AA,0x40,
0xAA,0x90,0xAA,0x90,0xA1,0x54,0xFE,0x32,
0xA1,0x15,0xAA,0x98,0xAA,0x90,0xAA,0x40,
0x20,0x40,0x28,0x20,0x30,0x20,0x00,0x00,
0x02,0x00,0x06,0x00,0x7A,0xFC,0x12,0x80,
0x12,0x80,0xFF,0xFF,0x12,0x88,0x32,0x84,
0x16,0xF8,0x02,0x00,0x1F,0xE0,0x00,0x02,
0x00,0x01,0xFF,0xFE,0x00,0x00,0x00,0x00,
0x01,0x00,0x02,0x00,0x04,0x00,0x1F,0xFF,
0xE1,0x00,0x02,0x00,0x0C,0x00,0xF0,0x00,
0x1F,0xFF,0x11,0x10,0x11,0x10,0x13,0x10,
0x11,0x30,0x30,0x10,0x10,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x38,0x00,0x7F,0xCC,
0x7F,0xCC,0x38,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, //显示空屏,如果只有一个字或将字全部移出必须设置一个空屏幕
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
};
voiddelay(intc)
{
inti,j;
for(i=0;
i<
c;
i++)
for(j=0;
j<
10;
j++)
;
}
voidmain()
unsignedchari,j,k;
//i:
每个字的显示循环;
j每个字的显示码除以2;
k每列刷新次数
unsign