您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > l第7章89C51串行口及串行通信技术
2019年8月15日星期四1第七章89C51串行口及串行通信技术•本书前几章涉及的数据传送都是采用并行方式,如8051与存储器,存储器与存储器,8051与并行打印机之间的通信。89C51处理8位数据,若以并行传送方式一次传送一个字节的数据,至少需要8条数据线。当89C51与打印机连接时,除8条数据线外,还需要状态、应答等控制线。一些微机系统,如IBM-PC系列机,由于磁盘机、CRT、打印机与主机系统的距离有限,所以,使用多条电缆线以提高数据传送速度还是合算的。但是,计算机之间、计算机与其终端之间的距离有时非常远,此时,电缆线过多是不经济的2019年8月15日星期四2第七章89C51串行口及串行通信技术•串行通信只用一位数据线传送数据的位信号,即使加上几条通信联络控制线,也用不了很多电缆线。因此,串行通信适合远距离数据传送,如大型主机与其远程终端之间、处于两地的计算机之间采用串行通信就非常经济。当然,串行通信要求有转换数据格式、时间控制等逻辑电路,这些电路目前已被集成在大规模集成电路中(称为可编程串行通信控制器),使用很方便。2019年8月15日星期四3第七章89C51串行口及串行通信技术•本章将介绍89C51串行口的结构及应用,PC机与89C51间的双机通信,一台PC机控制多台89C51前沿机的分布式系统,以及通信接口电路和软件设计,并给出设计实例,包括接口电路、程序框图、主程序和接收/发送子程序。2019年8月15日星期四4第七章89C51串行口及串行通信技术7.1串行通信基本知识7.2串行口及应用7.3RS-232C标准接口总线及串行通信硬件设计7.489C51与89C51点对点异步通信7.589C51与PC机间通信软件的设计7.6PC机与多个单片机间的通信7.7思考题与习题返回2019年8月15日星期四57.1串行通信基本知识7.1.1数据通信7.1.2串行通信的传输方式7.1.3异步通信和同步通信7.1.4串行通信的过程及通信协议返回2019年8月15日星期四67.1.1数据通信•在实际工作中,计算机的CPU与外部设备之间常常要进行信息交换,一台计算机与其他计算机之间也往往要交换信息,所有这些信息交换均可称为通信。•通信方式有两种,即并行通信和串行通信。•通常根据信息传送的距离决定采用哪种通信方式。•例如,在IBM-PC机与外部设备(如打印机等)通信时,如果距离小于30m,可采用并行通信方式;当距离大于30m时,则要采用串行通信方式。89C51单片机具有并行和串行二种基本通信方式。返回2019年8月15日星期四77.1.1数据通信•并行通信是指数据的各位同时进行传送(发送或接收)的通信方式。•其优点是传送速度快;•缺点是数据有多少位,就需要多少根传送线。•例如,89C51单片机与打印机之间的数据传送就属于并行通信。•图7-1(a)所示为89C51与外设间8位数据并行通信的连接方法。并行通信在位数多、传送距离又远时就不太合适了。返回2019年8月15日星期四87.1.1数据通信•串行通信指数据是一位一位按顺序传送的通信方式。•它的突出优点是只需一对传输线(利用电话线就可作为传输线),这样就大大降低了传送成本,特别适用于远距离通信;•其缺点是传送速度较低。假设并行传送N位数据所需时间位T,那么串行传送的时间至少为NT,实际上总是大于NT的。•图7-1(b)所示为串行通信方式的连接方法。返回2019年8月15日星期四9图7-1数据通信方式返回2019年8月15日星期四107.1.2串行通信的传输方式•串行通信的传送方向通常有三种:1.单向(或单工)配置,只允许数据向一个方向传送;2.半双向(或半双工)配置,允许数据向两个方向中的任一方向传送,但每次只能有一个站点发送;3.全双向(全双工)配置,允许同时双向传送数据,因此,全双工配置是一对单向配置,它要求两端的通信设备都具有完整和独立的发送和接受能力。•图7-2所示为串行通信中的数据传送方式。返回2019年8月15日星期四11图7-2串行通信中的数据传送方式返回2019年8月15日星期四127.1.3异步通信和同步通信•串行通信有两种基本通信方式,即异步通信和同步通信。1、异步通信返回2019年8月15日星期四13异步通信返回甲机乙机甲机时钟乙机时钟串行异步方式2019年8月15日星期四141、异步通信在异步通信中,数据是一帧一帧(包括一个字符代码或一字节数据)传送的,每一帧的数据格式如图7-3所示返回2019年8月15日星期四15图7-3异步通信数据格式返回2019年8月15日星期四161、异步通信•在帧格式中,一个字符由四个部分组成:起始位、数据位、奇偶校验位和停止位。首先是一个起始为(0),然后是5位--8位数据(规定低位在前,高位在后),接下来是奇偶校验位(可省略),最后是停止位(1)。返回2019年8月15日星期四17•图7-3(a)表示一个字符紧接一个字符传送的情况,上一个字符的停止位和下一个字符的起始位是紧邻的;•图7-3(b)则是两个字符间有空闲位的情况,空闲位为1,线路处于等待状态。存在空闲位正是异步通信的特征之一。•例如,规定用ASCII编码,字符为七位,加一个奇偶校验位、一个起始位、一个停止位,则一帧共十位。1、异步通信返回2019年8月15日星期四182、同步通信甲机乙机时钟串行同步方式2019年8月15日星期四192、同步通信•同步通信中,由时钟来实现发送端和接收端同步,。•同步传送时,字符与字符之间没有间隙,也不用起始位和停止位,仅在数据块开始时用同步字符SYNC来指示,其数据格式如图7-4所示。返回2019年8月15日星期四20图7-4异步通信数据格式返回2019年8月15日星期四213、波特率(Baudrate)•波特率,即数据传送速率,表示每秒钟传送二进制代码的位数,它的单位是b/s。•波特率对于CPU与外界的通信是很重要的。•假设数据传送速率是120字符/s,而每个字符格式包含10个代码位(1个起始位、1个终止位、8个数据位)。这时,传送的波特率为:10b/字符×120字符/s=1200b/s返回2019年8月15日星期四223、波特率(Baudrate)•每一位代码的传送时间Td为波特率的倒数。Td=1b/(1200b/s)=0.833ms•异步通信的传送速率在50b/s--19200b/s之间,常用于计算机到终端机和打印机之间的通信、直通电报以及无线电通信的数据发送等。返回2019年8月15日星期四237.1.4串行通信的过程及通信协议1、串←→并转换与设备同步两个通信设备在串行线路上成功地实现通信必须解决两个问题:一是串←→并转换,即如何把要发送的并行数据串行化,把接收的串行数据并行化;二是设备同步,即同步发送设备与接收设备的工作节拍,以确保发送数据在接收端被正确读出。返回2019年8月15日星期四241、串←→并转换与设备同步(1)串←→并转换串行通信是将计算机内部的并行数据转换成串行数据,将其通过一根通信线传送;并将接收的串行数据再转换成并行数据送到计算机中。返回2019年8月15日星期四251、串←→并转换与设备同步•在计算机串行发送数据之前,计算机内部的并行数据被送入移位寄存器并一位一位地输出,将并行数据转换成串行数据。如图7-5所示。•在接收数据时,来自通信线路的串行数据被压入移位寄存器,满8位后并行送到计算机内部。如图7-6所示。•在串行通信控制电路中,串--并、并--串转换逻辑被集成在串行异步通信控制器芯片中。89C51单片机的串行口和PC中的8250都可实现这一功能。。返回2019年8月15日星期四26图7-5返回2019年8月15日星期四27图7-6返回2019年8月15日星期四28(2)设备同步•进行串行通信的两台设备必须同步工作才能有效地检测通信线路上的信号变化,从而采样传送数据脉冲。•设备同步对通信双方有两个共同要求:一是通信双方必须采用统一的编码方法;二是通信双方必须能产生相同的传送速率。返回2019年8月15日星期四29(2)设备同步•采用统一的编码方法确定了一个字符二进制表示值的位发送顺序和位串长度,当然还包括统一的逻辑电平规定,即电平信号高低与逻辑1和逻辑0的固定对应关系。•通信双方只有产生相同的传送速率,才能确保设备同步,这就要求发送设备和接收设备采用相同频率的时钟。发送设备在统一的时钟脉冲上发出数据,接收设备才能正确检测出与时钟脉冲同步的数据信息。返回2019年8月15日星期四302、串行通信协议•通信协议是对数据传送方式的规定,包括数据格式定义和数据位定义等。•通信双方必须遵守统一的通信协议。串行通信协议包括同步协议和异步协议两种。•在此只讨论异步串行通信协议和异步串性协议规定的字符数据的传送格式。返回2019年8月15日星期四312、串行通信协议(1)起始位•通信线上没有数据被传送时处于逻辑1状态。•当发送设备要发送一个字符数据时,首先发出一个逻辑0信号,这个逻辑低电平就是起始位。•起始位通过通信线传向接收设备,接收设备检测到这个逻辑低电平后,就开始准备接收数据位信号。•起始位所起的作用就是设备同步,通信双方必须在传送数据位前协调同步。返回2019年8月15日星期四322、串行通信协议(2)数据位当接收设备收到起始位后,紧接着就会收到数据位。数据位的个数可以是5、6、7或8。IBM-PC中经常采用7位或8位数据传送,89C51串行口采用8位或9位数据传送。这些数据位被接收到移位寄存器中,构成传送数据字符。在字符数据传送过程中,数据位从最低有效位开始发送,依次顺序在接收设备中被转换为并行数据。返回2019年8月15日星期四332、串行通信协议(3)奇偶校验位数据位发送完之后,可以发送奇偶校验位。奇偶校验用于有限差错检测,通信双方需约定已知的奇偶校验方式。如果选择偶校验,那么组成数据位和奇偶位的逻辑1的个数必须是偶数;如果选择奇校验,那么逻辑1的个数必须是奇数。返回2019年8月15日星期四342、串行通信协议(4)停止位约定在奇偶位或数据位(当无奇偶校验时)之后发送的是停止位。停止位是一个字符数据的结束标志,可以是1位,1.5位或2位的高电平。接收设备收到停止位之后,通信线路上便又恢复逻辑1状态,直至下一个字符数据的起始位到来。返回2019年8月15日星期四352、串行通信协议(5)波特率设置通信线上传送的所有位信号都保持一致的信号持续时间,每一位的信号持续时间都由数据传送速度确定,而传送速度是以每秒多少个二进制位来衡量的,这个速度叫波特率。如果数据以300个二进制位每秒在通信线上传送,那么传送速度为300波特,通常记为300b/s。返回2019年8月15日星期四362、串行通信协议(6)挂钩(握手)信号约定(见本章7.4节实例)返回2019年8月15日星期四377.2串行口及应用•89C51单片机除具有4个8位并行口外,还具有串行接口。•此串行接口是一个全双工串行通信接口,即能同时进行串行发送和接收数据。•它可以作UART(通用异步接收和发送器)用,也可以作同步移位寄存器用。•使用串行接口可以实现89C51单片机系统之间点对点的单机通信和89C51与系统机(如IBM-PC机等)的单机或多机通信。返回2019年8月15日星期四387.2串行口及应用•7.2.189C51串行口•7.2.289C51串行口的工作方式及应用返回2019年8月15日星期四397.2.189C51串行口1、结构2、串行口控制字及控制寄存器3、串行通信工作方式4、波特率设计返回2019年8月15日星期四401、结构•89C51通过引脚RXD(P3.0,串行数据接收端)和引脚TXD(P3.1,串行数据发送端)与外界进行通信。其内部结构简化示意图如图7-7所示。图中有两个物理独立的接收、发送缓冲器SBUF,它们占用同一地址99H,可同时发送、接收数据。发送缓冲器只能写入,不能读出;接收缓冲器只能读出,不能写入。•串行发送与接收的速率与移位时钟同步。89C51用定时器T1作为串行通信的波特率发生器,T1溢出率经2分
本文标题:l第7章89C51串行口及串行通信技术
链接地址:https://www.777doc.com/doc-309866 .html