您好,欢迎访问三七文档
单片机原理及应用主目录上一页下一页结束第9章串行接口及串行通信技术教学目标9.1串行通信基础知识9.2AT89C51的串行接口9.3AT89C51串行接口的应用与编程9.4多机通信9.5PC机与单片机间的串行通信9.6实训指导本章小结思考题与习题单片机原理及应用主目录上一页下一页结束教学目标通过本章教学,要求达到以下目标:1.串行通信的基本概念:了解并行/串行通信的概念;理解串行通信中的异步/同步通信的基本概念;理解波特率的概念,学会计算波特率的方法;4了解串行通信的三种制式及校验方法。单片机原理及应用主目录上一页下一页结束2.AT89C51串行口:串行接口结构及其功能;理解串行数据缓冲器SBUF的功能和读写方法;熟悉SCON的结构、控制作用和设置方法;了解电源控制寄存器PCON,熟悉SMOD位。3.串行口的工作方式:理解串行通信4种工作方式的特点和区别;掌握串行工作方式0的应用;熟悉串行工作方式1、2、3应用程序的编制方法。单片机原理及应用主目录上一页下一页结束4.多机通信原理:理解多机通信的原理、过程和编制多机通信应用程序的方法。单片机原理及应用主目录上一页下一页结束计算机与外界的信息交换称为通信。通信的基本方式可分为并行通信和串行通信两种。所谓并行通信是指数据的各位同时在多根数据线上发送或接收。串行通信是数据的各位在同一根数据线上依次逐位发送或接收。9.1串行通信基础知识单片机原理及应用主目录上一页下一页结束目前串行通信在单片机双机、多机以及单片机与PC机之间的通信等方面得到了广泛应用。图9.1并行通信示意图P0.7P0.6P0.5P0.4P0.3P0.2P0.1P0.0P2.7RDWRRDWRCSD7D6D5D4D3D2D1D0825589C51图9.2串行通信示意图89C51外设TXDTXDRXDRXD发送接收单片机原理及应用主目录上一页下一页结束9.1.1异步通信和同步通信串行通信按同步方式可分为异步通信和同步通信两种基本通信方式。1.同步通信(SynchronousCommunication)同步通信是一种连续传送数据的通信方式,一次通信传送多个字符数据,称为一帧信息。数据传输速率较高,通常可达56000bps或更高。其缺点是要求发送时钟和接收时钟保持严格同步。单片机原理及应用主目录上一页下一页结束同步字符数据字符1数据字符2…数据字符n-1数据字符n校验字符(校验字符)图9.3同步通信数据传送格式2.异步通信(AsynchronousCommunication)在异步通信中,数据通常是以字符或字节为单位组成数据帧进行传送的。收、发端各有一套彼此独立,互不同步的通信机构,由于收发数据的帧格式相同,因此可以相互识别接收到的数据信息。同步通信的数据帧格式如图9.3所示。单片机原理及应用主目录上一页下一页结束D0D1D2D3D4D5D6D70/11111D70/1100D0D1第n字符帧空闲位停止位奇偶校验停止位8位数据8位数据起始位起始位奇偶校验第n-1字符帧第n+1字符帧图9.4异步通信帧格式8位数据异步通信信息帧格式如图9.4所示。单片机原理及应用主目录上一页下一页结束(1)起始位:在没有数据传送时,通信线上处于逻辑“1”状态。当发送端要发送1个字符数据时,首先发送1个逻辑“0”信号,这个低电平便是帧格式的起始位。其作用是向接收端表示发送端开始发送一帧数据。接收端检测到这个低电平后,就准备接收数据信号。单片机原理及应用主目录上一页下一页结束(2)数据位:在起始位之后,发送端发出(或接收端接收)的是数据位,数据的位数没有严格的限制,5~8位均可。由低位到高位逐位传送。(3)奇偶校验位:数据位发送完(接收完)之后,可发送一位用来检验数据在传送过程中是否出错的奇偶校验位。奇偶校验是收发双方预先约定好的有限差错检验方式之一。有时也可不用奇偶校验。单片机原理及应用主目录上一页下一页结束(4)停止位:字符帧格式的最后部分是停止位,逻辑“1”电平有效,它可占1/2位、1位或2位。停止位表示传送一帧信息的结束,也为发送下一帧信息作好准备。单片机原理及应用主目录上一页下一页结束9.1.2串行通信的波特率波特率(BaudRate)是串行通信中一个重要概念,它是指传输数据的速率,亦称比特率。波特率的定义是每秒传输二进制数码的位数。如:波特率为1200bps是指每秒钟能传输1200位二进制数码。波特率的倒数即为每位数据传输时间。例如:波特率为1200bps,每位的传输时间为:1)(833.01200msdT==单片机原理及应用主目录上一页下一页结束波特率和字符的传输速率不同,若采用图9.4的数据帧格式,并且数据帧连续传送(无空闲位),则实际的字符传输速率为1200/11=109.09帧/秒。波特率也不同于发送时钟和接收时钟频率。同步通信的波特率和时钟频率相等,而异步通信的波特率通常是可变的。单片机原理及应用主目录上一页下一页结束9.1.3串行通信的制式1.单工制式(Simplex)单工制式是指甲乙双方通信只能单向传送数据。单工制式如图9.5所示。在串行通信中,数据是在两个站之间传送的。按照数据传送方向,串行通信可分为三种制式。发送器A接收器B图9.5单工制式单片机原理及应用主目录上一页下一页结束2.半双工制式(Halfduplex)半双工制式是指通信双方都具有发送器和接收器,双方既可发送也可接收,但接收和发送不能同时进行,即发送时就不能接收,接收时就不能发送。半双工制式如图9.6所示。发送接收发送接收A端B端图9.6半双工制式单片机原理及应用主目录上一页下一页结束3.全双工制式(Fullduplex)全双工制式是指通信双方均设有发送器和接收器,并且将信道划分为发送信道和接收信道,两端数据允许同时收发,因此通信效率比前两种高。全双工制式如图9.7所示。发送接收接收发送A端B端图9.7全双工制式单片机原理及应用主目录上一页下一页结束9.1.4串行通信的校验串行通信的目的不只是传送数据信息,更重要的是应确保准确无误地传送。因此必须考虑在通信过程中对数据差错进行校验,因为差错校验是保证准确无误地通信的关键。常用差错校验方法有奇偶校验、累加和校验以及循环冗余码校验等。单片机原理及应用主目录上一页下一页结束1.奇偶校验奇偶校验的特点是按字符校验,即在发送每个字符数据之后都附加一位奇偶校验位(1或0),当设置为奇校验时,数据中1的个数与校验位1的个数之和应为奇数;反之则为偶校验。收、发双方应具有一致的差错检验设置,当接收1帧字符时,对1的个数进行检验,若奇偶性(收、发双方)一致则说明传输正确。奇偶校验只能检测到那种影响奇偶位数的错误,比较低级且速度慢,一般只用在异步通信中。单片机原理及应用主目录上一页下一页结束2.累加和校验累加和校验是指发送方将所发送的数据块求和,并将“校验和”附加到数据块末尾。接收方接收数据时也是先对数据块求和,将所得结果与发送方的“校验和”进行比较,若两者相同,表示传送正确,若不同则表示传送出了差错。“校验和”的加法运算可用逻辑加,也可用算术加。累加和校验的缺点是无法检验出字节或位序的错误。单片机原理及应用主目录上一页下一页结束3.循环冗余码校验(CRC)循环冗余码校验的基本原理是将一个数据块看成一个位数很长的二进制数,然后用一个特定的数去除它,将余数作校验码附在数据块之后一起发送。接收端收到该数据块和校验码后,进行同样的运算来校验传送是否出错。目前CRC已广泛用于数据存储和数据通信中,并在国际上形成规范,市面上已有不少现成的CRC软件算法。单片机原理及应用主目录上一页下一页结束9.2AT89C51的串行接口AT89C51内部有一个可编程全双工串行通信接口。该部件不仅能同时进行数据的发送和接收,也可作为一个同步移位寄存器使用。下面将对其内部结构、工作方式以及波特率进行介绍。单片机原理及应用主目录上一页下一页结束9.2.1串行接口的结构及功能图9.8AT89C51串行口结构框图发送SBUF(99H)接收SBUF(99H)同步时钟门电路发送控制器接收控制器输入移位寄存器串行口控制寄存器(98H)内部总线≥1串行口中断TIRITXD(P3.1)RXD(P3.0)单片机原理及应用主目录上一页下一页结束1.串行数据缓冲器SBUFSBUF是串行口缓冲寄存器,包括发送寄存器和接收寄存器,以便能以全双工方式进行通信。此外,在接收寄存器之前还有移位寄存器,从而构成了串行接收的双缓冲结构,这样可以避免在数据接收过程中出现帧重叠错误。发送数据时,由于CPU是主动的,不会发生帧重叠错误,因此发送电路不需要双重缓冲结构。单片机原理及应用主目录上一页下一页结束在逻辑上,SBUF只有一个,它既表示发送寄存器,又表示接收寄存器,具有同一个单元地址99H。但在物理结构上,则有两个完全独立的SBUF,一个是发送缓冲寄存器SBUF,另一个是接收缓冲寄存器SBUF。如果CPU写SBUF,数据就会被送入发送寄存器准备发送;如果CPU读SBUF,则读入的数据一定来自接收缓冲器。即CPU对SBUF的读写,实际上是分别访问上述两个不同的寄存器。单片机原理及应用主目录上一页下一页结束2.串行控制寄存器SCON串行控制寄存器SCON用于设置串行口的工作方式、监视串行口的工作状态、控制发送与接收的状态等。它是一个既可以字节寻址又可以位寻址的8位特殊功能寄存器。其格式如图9.9所示。单片机原理及应用主目录上一页下一页结束见表9-1图9.9串行口控制寄存器SCONRITIRB8TB8RENSM2SM1SM0SCON98H99H9AH9BH9CH9DH9EH9FH位地址0:双机1:多机多机通信0:禁止1:允许接收控制发送数据第9位接收数据第9位发送中断标志接收中断标志单片机原理及应用主目录上一页下一页结束(1)SM0SM1:串行口工作方式选择位。其状态组合所对应的工作方式如表9-1所示。SM0SM1工作方式功能说明000同步移位寄存器输入/输出,波特率固定为fosc/1201110位异步收发,波特率可变(T1溢出率/n,n=32或16)10211位异步收发,波特率固定为f0sc/n,n=64或32)11311位异步收发,波特率可变(T1溢出率/n,n=32或16)表9-1串行口工作方式单片机原理及应用主目录上一页下一页结束(2)SM2:多机通信控制器位。在方式0中,SM2必须设成0。在方式1中,当处于接收状态时,若SM2=1,则只有接收到有效的停止位“1”时,RI才能被激活成“1”(产生中断请求)。在方式2和方式3中,若SM2=0,串行口以单机发送或接收方式工作,TI和RI以正常方式被激活并产生中断请求;若SM2=1,RB8=1时,RI被激活并产生中断请求。单片机原理及应用主目录上一页下一页结束(4)TB8:方式2和方式3中要发送的第9位数据。该位由软件置位或复位。在方式2和方式3时,TB8是发送的第9位数据。在多机通信中,以TB8位的状态表示主机发送的是地址还是数据:TB8=1表示地址,TB8=0表示数据。TB8还可用作奇偶校验位。(3)REN:串行接受允许控制位。该位由软件置位或复位。当REN=1,允许接收;当REN=0,禁止接收。单片机原理及应用主目录上一页下一页结束(6)TI:发送中断标志位。TI=1,表示已结束一帧数据发送,可由软件查询TI位标志,也可以向CPU申请中断。注意:TI在任何工作方式下都必须由软件清0。(5)RB8:接收数据第9位。在方式2和方式3时,RB8存放接收到的第9位数据。RB8也可用作奇偶校验位。在方式1中,若SM2=0,则RB8是接收到的停止位。在方式0中,该位未用。单片机原理及应用主目录上一页下一页结束(7)RI:接收中断标志位。RI=1,表示一帧数据接收结束。可由软件查询RI位标志,也可以向CPU申请中断。注意:RI在任何工作方式下也都必须由软件清0。在AT89C51中,串行发送中断TI和接收中断RI的中断入口地址是同是0023H,因此在中断程序中必须由软件查询TI和RI的状态才能确定究竟是接收还是发送中断,进而作出相应的处理。单片
本文标题:51单片机串口通信
链接地址:https://www.777doc.com/doc-3737592 .html