资源描述
单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,*,单片机UART串行接口,在,并行通信,中,一个并行数据占多少位二进制数,就要多少根传输线,这种方式的特点是,通信速度快,,但,传输线多,,,价格较贵,,适合,近距离,传输。,串行通信,仅需12根传输线,故在,长距离,传输数据时比较,经济,,但由于它每次只能传送1位,所以,传送速度较慢,。,2,图7.1 基本通信方式图示,3,711 同步通信和异步通信方式,串行通信分,同步,和,异步,两种方式。,4,1异步通信ASYNC,在异步通信中数据或字符是逐帧(frame)传送的。,帧定义为一个字符的完整的通信格式,通常也称为帧格式。最常见的帧格式一般是先用一个起始位“0”表示字符的开始;然后是58位数据,规定低位在前,高位在后;其后是奇偶校验位;最后是停止位,用以表示字符的结束,停止位可以是1位、1.5位、2位,不同的计算机规定有所不同。从起始位开始到停止位结束就构成完整的1帧。,5,起始位,通信线上没有数据传送时,为高电平(逻辑1);当要发送数据时,首先发1个低电平信号(逻辑0),此信号称为“起始位”,表示开始传输1帧数据。,数据位,起始位之后的位即数据位。数据位可以是5、6、7或8位(不同计算机的规定不同),上图的数据位为8位。一般从最低位开始传送,最高位在最后。,6,奇偶校验位,数据位之后的位为奇偶校验位(有的方式具有)。此位可用于判别字符传送的正确性,其有3种可能的选择,即奇、偶、无校验,用户可根据需要选择(在有的格式中,该位可省略)。在80C51单片机中,此位还可以用来确定该帧字符信息的性质(地址或数据)。,停止位,校验位后为停止位,用于表示1帧结束,用高电平(逻辑1)表示。停止位可以是1、15或2位,不同计算机的规定有所不同。,7,异步通信的主要特点如下:,进行串行通信的单片机的时钟相互独立;其时钟频率可以不相同;在通信时不要求有同步时钟信号。由于异步通信是逐帧进行传输的,各位之间的时间间隔应该相同,所以,必须保证2个单片机之间有相同的传送波特率。,如果传送波特率不同,则时间间隔不同;当误差超过5时,就不能正常进行通信。由于信息传输可以是随时不间断地进行的,因而帧与帧之间的时间间隔可以是不固定的,间隙处为高电平。,8,由于异步通信每传送一帧有固定格式,通信双方只需按约定的帧格式来发送和接收数据,所以硬件结构比同步通信方式简单。此外,它还能利用校验位检测错误,所以这种通信方式应用较广泛。,在单片机中主要是采用异步通信方式。,9,2同步通信SYNC,在同步通信中,数据或字符开始处是用一同步字符来指示(一般约定为l2个字符),以实现发送端和接收端同步,一旦检测到约定同步字符,,下面就连续、顺序地发送和接收数据,。,10,由于同步通信数据块传送时去掉了每个数字都必须具有的字符开始和结束的标志,且它一次可以发送一个数据段(多个数据),因此,,其速度高于异步通信,;但这种方式要求接收和发送时钟严格,保持同步,,在通信时通常要求有同步时钟信号,对硬件结构要求较高。由于这种方式易于进行串行外围扩展,所以目前很多型号的单片机都增加了串行同步通信接口,如目前已得到广泛应用的I,2,C串行总线和SPI串行接口等。,11,712 串行通信的数据传送速率,传送速率,是指数据传送的速度。,用b/s或bps(比特秒)表示,称为,比特率,。在二进制的情况下,比特率与波特率数值相等,因而在单片机的串行通信中,常称为,波特率,。,假如数据传送的速率为120个字符每秒,每个字符由1个起始位、8个数据位和1个停止位组成,则其传送波特率为:,10b120s1200bs1200波特,每一位的传送时间即为波特率的倒数:,12,异步通信的数据传送速率一般为50b/s100kb/s,常用于计算机到CRT终端,以及双机或多机之间的通信等。,13,713 串行通信的方式,在串行通信中,数据是在两机之间传送的。按照数据传送方向,串行通信可分为单工(Simplex)制式、半双工(half duplex)制式和全双工(full duplex)制式。,14,图72 串行通信方式示意图,(1)单工制式,在单工制式下,数据在甲机和乙机之间只允许,单方向,传送。两机之间只需1条数据线。,15,(2)半双工制式,在半双工制式下,数据在甲机和乙机之间允许双方向传送,但它们之间只有一个通信回路,,接收和发送,不能同时,进行,只能分时发送和接收(即甲机发送,乙机接收,或者乙机发送,甲机接收),因而两机之间只需1条数据线。,16,(3)全双工制式,在全双工制式下,甲、乙两机之间数据的发送和接收可以同时进行,称为“全双工传送”。全双工形式的串行通信必须使用2条数据线。,不管哪种形式的串行通信,在两机之间均应有,公共地线,。,17,*信号的调制与解调,当异步通信的距离在15m之内时,计算机之间可以直接进行通信。而当传输距离较远时,通常是用电话线传送。由于电话线频带不够宽,再加上远距离传输时信号不可避免地衰减,因而使信号发生明显的畸变。,在,发送,时要用,调制器,(modulator)把数字信号转换为模拟信号,并加以放大再传送,这个过程叫做调制。,在,接收,时,,再用,解调器,(demodulator)检测此模拟信号,并把它转换成数字信号再送入计算机接口,这个过程即解调。,18,714 通信协议,通信协议是指在计算机之间进行数据传输时的一些约定,包括通信方式、波特率、命令码的约定等。为保证计算机之间能准确、可靠地通信,相互之间必须遵循统一的通信协议。在通信之前一定要先设置好通信协议。,19,72 80C51串行口简介,80C51的串行口是一个,可编程的全双工串行通信接口,,通过软件编程它可以作通用异步接收和发送器UART(Universal Asynchronous ReceiverTransmitter)用,也可作同步移位寄存器用。其帧格式可有8位、10位和11位,,并能设置各种波特率,,使用灵活方便。,20,721 串行口结构与工作原理,80C51串行口主要由,接收与发送,缓冲寄存器,SBUF,、输入移位寄存器以及串行控制寄存器,SCON,等组成。波特率发生器可以利用定时器T1或T2控制发送和接收的速率。,SCON,用于存放串行口的控制和状态信息;,发送数据缓冲寄存器SBUF,用于存放准备发送出去的数据;,接收数据缓冲寄存器SBUF,用于接收由外部输入到输入移位寄存器中的数据。80C51串行口正是通过对上述专用寄存器的设置、检测与读取来管理串行通信的。,21,图73 串行口结构框图,22,在进行串行通信时,外界数据通过引脚RXD(P3.0)输入。输入数据首先逐位进入输入移位寄存器,由串行数据转换为并行数据,然后再送入接收寄存器。在接收寄存器中采用了双缓冲结构,以避免在接收到第2帧数据前,CPU未及时响应接收寄存器前一帧的中断请求,没把前一帧数据读走,而造成2帧数据重叠的错误。在发送时,串行数据通过引脚TXD(P3.1)输出。由于CPU是主动的,因此不会产生写重叠问题,一般不需要双缓冲器结构。要发送的数据通过发送控制器控制逻辑门电路逐位输出。,23,722 串行口寄存器,与串行口工作有关的寄存器共有6个,分别是串行口控制寄存器,SCON,、接收与发送缓冲寄存器,SBUF,、电源控制寄存器,PCON,、中断允许控制寄存器,IE,、中断优先级寄存器,IP,。,24,1串行口控制寄存器SCON,串行口控制寄存器SCON用于串行通信的方式选择、接收和发送控制,并可反映串行口的工作状态。,SCON,9FH,9EH,9DH,9CH,9BH,9AH,99H,98H,(98H),SM0,SM1,SM2,REN,TB8,RB8,TI,RI,25,SCON7和SCON6位,SM0和SM1,串行方式选择位,表71 串行口工作方式选择,SM0 SM1,工作方式,功能描述,波特率,0 0,0 1,0 0,1 1,方式0,方式1,方式2,方式3,8位同步移位寄存器,10位UART,11位UART,11位UART,fosc/12,可变,fosc/64和fosc/32,可变,26,SCON.5位,SM2,多机通信控制位。,在方式2和方式3中,,SM2,主要用于进行多机通信控制。当串行口以方式2或方式3接收时,如果,SM2=1,,允许多机通信,且接收到第9位RB8为0时,则RI不置1不接收主机发来的数据;如果,SM2=1,,且RB8为1,则RI置1,产生中断请求,将接收到的8位数据送入SBUF。当SM2=0时,不论RB8为0还是1,都将收到的8位数据送入SBUF,并产生中断。,在方式1中,当处于接收状态时,若,SM2=1,,则只有接收到有效的停止位时,RI才置1。在方式0中,SM2应置0。,27,SCON.4位,REN,允许串行接收位。,REN=1,时,允许接收;,REN=O,时,禁止接收。由软件置位或清除。,28,SCON.3位,TB8,发送数据的第9位(D8)。,在方式2或方式3中,根据需要由软件置位或复位。双机通信时,它可约定作奇偶校验位;在多机通信中,可作为区别地址帧或数据帧的标识位。一般由指令设定,地址帧,时,设,TB8为1,;而设定,数据帧,时,设,TB8为0。,方式0和方式1中没用该位。,29,SCON.2位,RB8,接收数据的第9位(D8)。,在方式2或方式3中,,RB8,的状态与,TB8,相呼应,(如可以是约定的奇偶校验位,也可以是约定的地址/数据标识位)。例如,当SM2=1时,如果RB8为0,则说明收到的是数据帧。,30,SCON.1位,TI,发送中断标志位。,在方式0中,发送完8位数据后,由硬件置位;在其他方式中,在发送停止位之初由硬件置位。,TI=1,时,可申请中断,也可供软件查询用。,在任何方式中,都必须由软件来清除TI,。,SCON.0位,RI,接收中断标志位。,在方式0中,接收完8位数据后,由硬件置位;在其他方式中,在接收停止位的中间,由硬件置位。,RI=1,时,可申请中断,也可供软件查询用。,在任何方式中,都必须由软件清除RI,。,31,SCON的低2位与中断有关。,SCON的地址为98H,可以位寻址。复位时,SCON的所有位均清0。,32,2数据缓冲寄存器SBUF,数据缓冲寄存器,SBUF,实际上是2个寄存器:,发送数据缓冲寄存器,和,接收数据缓冲寄存器,。接收与发送缓冲寄存器SBUF采用同一个地址代码99H,其寄存器名亦同样为SBUF。CPU通过不同的操作命令,区别这2个寄存器,所以不会因为地址代码相同而产生错误。,当CPU发出写SBUF命令,时,即向发送缓冲寄存器中装载新的信息,同时启动数据串行发送;当,CPU发出读SBUF命令,时,即读接收缓冲寄存器的内容。,33,3电源控制寄存器PCON,电源控制寄存器PCON主要用于电源控制,PCON的最高位SMOD是串行口的波特率倍增位:,当SMOD为,1,时,波特率,加倍,;当SMOD为,O,时,波特率,不变,。,PCON,D7,D6,D5,D4,D3,D2,D1,D0,(87H),SMOD,GF1,GF0,PD,IDL,34,4中断允许控制寄存器,IE,中断允许控制寄存器,IE,用于控制与管理单片机的中断系统。,IE,的,ES,位用于控制串行口的中断:,当,ES,=,O,时,,禁止,串行口中断;,当,ES,=,1,时,,允许,串行口中断。,35,5中断优先级寄存器,IP,中断优先级寄存器,IP,用于管理单片机中各中断源中断优先级。,IP,的,PS,位用于设置串行口中断的优先级:,当,PS,=,0,时,串行口中断为,低优先级,;,当,PS,=,1,时,串行口中断为,高优先级,。,36,723 80C51的帧格式,80C51串行口通过编程可设置四种工作方式及三种帧格式。,37,方式0,以,8位数据为一帧,,不设起始位和停止位,先发送或接收最低位。,方式1,以,10位为一帧,传输,设有1个起始位“0”、8个数据位和1个停止位“1”。,38,方式2和3,以11位为一帧传输,设有1个起始位“0”、8个数据位、1个可编程位(第9数据位)D,8,和1个停止位“1”。,可编程位D,8,由软件置“1”或清“0”,该位可作检验位,也可作它用。,39,724 波特率的设置,在串行通信前,首先要,设置收发双方对发送或接收的数据传送速率,,即,波特率,。通过软件对80C51串行口编程可设定4种工作方式。这4种方式波特率的计算方法不同:,方式0和方式2的波特率是,固定,的,,而,方式1和方式3的波特率是,可变,的,由定时器T1或T2(AT89S52)的溢出率控制,。,40,1 方式0和方式2的波特率,方式0,中,每个机器周期发送或接收1位数据,,且不受SMOD的影响。,方式2,的波特率取决于PCON中SMOD之值。,当SMOD0时,波特率为fosc的164;,若SMOD1,则波特率为fosc的132,即:,41,2方式1和方式3的波特率,80C51串行口方式1和方式3的波特率由定时器T1的溢出率与SMOD的值决定,即:,T1溢出率取决于计数速率和定时器的预置值。,计数速率与TMOD寄存器中CT的状态有关。,当CT,0,时,计数速率fosc12;,当CT,1,时,计数速率取决于外部输入时钟频率。,42,当定时器T1作波特率发生器使用时,通常是选用,自动重装载方式,,即,方式2,。设计数初值为X,那么每过(256X)个机器周期,定时器1就会产生一次溢出。为了避免因溢出而产生不必要的中断,此时应禁止T1中断。溢出周期为:,溢出率为溢出周期之倒数,所以:,则定时器T1方式2的初始值为:,43,表7.2 定时器T1的常用波特率,串行口,工作方式,波特率,(kbps),fosc,MHz,SMOD,定时器1,C/T,模式,初值,方式0,1000,12,方式2,375,12,1,方式1,3,62.5,12,1,0,2,FFH,19.2,11.059,1,0,2,FDH,9.6,11.059,0,0,2,FDH,4.8,11.059,0,0,2,FAH,2.4,11.059,0,0,2,F4H,1.2,11.059,0,0,2,E8H,0.11,6,0,0,2,72H,0.11,12,0,0,1,FFEBH,44,【例1】已知80C51单片机时钟振荡频率为11.0592MHz选用定时器T1工作方式2作波特率发生器,波特率为2400波特,求时间常数。,解:设波特率控制位SMOD0,定时器T1的时间常数为:,所以TH1TL1F4H。,45,由于上述公式包含除法,所以当晶振频率与波特率不同时,计算值有时会有,一定误差,。例如,如果晶振频率为12MHz,波特率要求为2400,在SMOD=0时,TH1=F3H,波特率的实际计算值为2404,误差为0.11。但如果2个单片机的波特率相同,例如均为2404,则不会影响通信;,如果2个单片机的波特率误差超过2.5,则可能会引起通信错误。,46,AT89S52单片机的定时器T2也可作为波特率发生器,。,47,7.3 串行通信工作方式,通过软件编程可使串行通信有4种工作方式。,48,731 方式0,在,方式0,下,串行口作,同步移位寄存器,用,以8位数据为1帧,先发送或接收最低位,每个机器周期发送或接收一位,故其波特率是固定的,为fosc12。串行数据由,RXD,(P3.0)端输入或输出。同步移位脉冲由,TXD,(P3.1)端送出。这种方式常用于扩展I/O口。采用不同的指令实现输入或输出。,49,(1)发 送,当执行“,MOV SBUF,A,”指令时,CPU将1字节的数据写入发送缓冲寄存器SBUF(99H),串行口即把8位数据以fosc12的波特率,从RXD端送出,(低位在前)。发送完成后,置中断标志位TI为1。如要继续发送应将TI清0。,50,(2)接 收,由于,REN,是串行口允许接收控制位,因此在准备接收时,首先要用软件置REN为1,使其允许接收;然后,执行“MOV A,SBUF”指令,CPU即开始从RXD端以fosc12波特率输入数据(低位在前),当接收到8位数据时,置中断标志RI为1。读取数据后,一定要将RI清0。,51,串行控制寄存器中,TB8和RB8位在方式0中未用。每当发送或接收完8位数据时,由硬件将发送中断TI或接收中断RI标志置位。,不管是中断方式还是查询方式,都不会清除TI或RI标志,必须用软件清0。,在方式0中,,SM2位必须为0,。,52,图73 串行口结构框图,53,732 方式1,在,方式1,下,串行口为10位通用异步接口。发送或接收1帧数据,包括1位起始位“0”、8位数据位和1位停止位“1”,其传送波特率可调。,54,(1)发 送,当执行“,MOV SBUF,A,”指令时,CPU将1字节的数据写入发送缓冲寄存器SBUF(99H),就启动发送器发送,数据从引脚TXD(P31)端输出。当,发送完1帧数据后,,,TI标志置1,,在中断方式下将申请中断,通知CPU可以发送下一个数据。如要继续发送,必须将TI清0,。,55,图73 串行口结构框图,56,(2)接 收,接收时,先使,REN置1,,使串行口处于允许接收状态,RI标志为0,串行口采样引脚RXD(P30)。当采样到1至0的跳变时,确认是起始位“0”,就开始接收1帧数据。当停止位到来时,RB8位置1,同时,中断标志位RI也置1,在中断方式下将申请中断,通知CPU从SBUF取走接收到的1个数据。,不管是中断方式,还是查询方式,,都不会清除TI或RI标志,必须用软件清0。,57,733 方式2和方式3,方式2和方式3,均为,11,位异步通信方式,只是波特率的设置方法不同,其余完全相同。这两种方式发送或接收1帧的信息包括1位起始位“0”、8位数据位、1位可编程位和1位停止位“1”。其信息传送波特率与SMOD有关。,58,(1)发 送,发送前,首先根据,通信协议,由软件设置TB8(如作奇偶校验位或地址数据标识位),然后,将要发送的数据写入SBUF即可启动发送器。,发送过程是由执行任何一条以SBUF作为目的寄存器的指令而启动的(,写SBUF指令,),把8位数据装入SBUF,同时,串行口还自动把TB8装到发送移位寄存器的第9位数据位置上,并通知发送控制器要求进行一次发送,然后即从TXD(P31)端输出1帧数据。,59,图73 串行口结构框图,60,(2)接 收,在接收时,先,置位REN为1,,使串行口处于允许接收状态,同时还要将RI清0。在满足这个条件的前提下,再根据SM2的状态(因为SM2是方式2和方式3的多机通信控制位)和所接收到的RB8的状态,才能决定此串行口在信息到来后是否会使RI置1。如果RI置1,在中断方式下将申请中断,接收数据。,当,SM2=0,时,不管RB8为0还是为1,RI都置1,此串行口将接收发来的信息。,当,SM2=1,,且,RB8为1,时,表示在多机通信情况下,接收的信息为,地址帧,,此时RI置1。串行口将接收发来的地址。,当,SM2=1,,且,RB8为0,时,表示接收的信息为,数据帧,,,但不是发给本从机的,,此时RI不置1,因而SBUF中所接收的数据帧将丢失。,61,在方式2和方式3下,同样不管是中断方式,还是查询方式,都不会清除TI或RI标志。在发送和接收之后,也都必须,用软件清TI和RI位。,62,734 多机通信,80C51的,方式2和方式3,有一个专门的应用领域,即,多机通信,。这一功能使它可以方便地应用于集散式分布系统中。这种系统采用一台主机和多台从机。,图74 多机通信连接图,63,多机通信的实现,主要靠主、从机之间正确地设置与判断多机通信控制位SM2和发送或接收的第9数据位(D8)。,在编程前,,首先要给各从机定义地址编号,,如分别为00H、01H、02H。当主机想发送一数据块给几个从机中的一个时,它,首先送出一个地址字节,,以辨认从机。地址字节和数据字节可用第9数据位(,TB8,)来区别,,地址为1,数据为0,。所以,在,主机,发送地址帧时,地址数据标识位TB8应设置为“1”,以表示是地址帧。,如:,MOVSCON,#0D8H;设串行口为方式3,,TB8置“1”,准备发地址,64,此时,所有的从机初始化时均置SM21,使它们只处于接收地址帧的状态。,如:MOVSCON,#0F0H;置串行口为方式3,SM21,允许接收,当从机接收到从主机发来的信息后,第9位RB8若为“1”,则置位中断标志RI,并在中断后判断主机送来的地址与本从机地址是否相符。若相符,则被寻址的从机就清除其SM2标志,即,SM20,,准备接收即将从主机送来的数据帧;,未被选中的从机仍保持SM21,。,65,当主机发送数据帧时,应置TB80。此时,虽然各从机都能接收到,但,由于TB80,所以只有SM20的那个被寻址的从机才能接收到数据,,那些未被选中的从机将不理睬进入到串行口的数据字节,继续进行它们自己的工作,直到一个新的地址字节到来,这样就实现了主机控制的主从机之间的通信。,综上所述,,通信只能在主从机之间进行,从机之间的通信只有经主机才能实现。,66,多机之间的通信过程可归纳如下:,(1)主、从机均初始化为方式2或方式3,置,SM21,,允许中断。,(2),主机置TB81,,,发送要寻址的从机地址,。,(3)所有从机均接收主机发送的地址,并进行地址比较。,(4)被寻址的从机确认地址后,置本机,SM20,,向主机返回地址,供主机核对。,(5)核对无误后,主机向被寻址的从机发送命令,通知从机接收或发送数据。,(6)通信只能在主、从机之间进行,两个从机之间的通信需通过主机作中介。,(7)本次通信结束后,主、从机重置SM21,主机可再对其他从机寻址。,67,在实际应用中,因为单片机功能有限,因而在较大的测控系统中,常常把单片机应用系统作为前端机(下位机或从机)直接用于控制对象的数据采集与控制,而把PC机作为中央处理机(上位机或主机)用于数据处理和对下位机的监控管理。它们之间的信息交换主要是采用串行通信,此时单片机可直接利用其串行接口,而PC机可利用其配备的8250或8251、16450等可编程串行接口芯片。,实现单片机与PC机串行通信的关键是在通信协议的约定上要一致,,例如,应,设定相同的波特率及帧格式,等。在正式工作之前,双方应先互发联络信号,以确保通信收发数据的准确性。,68,74 串行口应用举例,本节将介绍串行口在作IO扩展及一般异步通信和多机通信中的应用原理及实例。,69,741 用串行口扩展IO口,串行口的方式0主要,用于扩展并行IO口,。此处将给出实用线路和简单的控制指令。,70,例7.1 用并行输入8位移位寄存器74HC165,扩展16位并行输入口,。编程实现从16位扩展口读入20字节数据,并把它们转存到内部RAM的50H63H中。,图75 利用串行口扩展输入口,71,解:在此采用74HC165与单片机相连实现I/O口扩展,是利用80C51的3根口线扩展为16根输入口线的实用电路,其由2块74HC165串接而成。74HC165是并入串出移位寄存器(也可选用其他同样功能的CMOS器件)。图中,,CK为时钟脉冲输入端,D,0,D,7,为并行输入端,S,IN,、Q,H,分别为数据的输入、输出端,。前级的数据输出端Q,H,与后级的信号输入端S,IN,相连。S/L=0时,允许并行置入数据;S/L=1时,允许串行移位。,72,MOVR7,#20;设置读入字节数,MOVR0,#50H;设片内RAM指针,SETBF0;设置读入字节奇偶数标志,RCV0:CLRP1.0;允许并行置入数据,SETBP1.0;允许串行移位,RCV1:MOVSCON,#10H;设串行口方式0并启动接收,JNBRI,$;等待接收一帧数据,CLRRI;清接收中断标志,MOVA,SBUF;取缓冲器数据,MOVR0,A,INCR0,CPLF0,JBF0,RCV2;判是否接收完偶数帧,接收完则,DECR7 重新并行置入,SJMPRCV1;否则再接收一帧,RCV2:DJNZR7,RCV0;判是否已读入预定的字节数,;对读入数据进行处理,73,程序中F0用来作读入字节数的奇偶性标志。由于每次由扩展口并行置入到移位寄存器的是2个字节数据,置入1次,串行口应接收2帧数据。故已接收的数据字节数为奇数时F00,不再并行置入数据就直接启动接收过程;否则F01,在启动接收过程前,应该先在外部移位寄存器中置入新的数据。,74,【例72】用2片8位串入并出移位寄存器74HC164作扩展输出口。,编程使这16个发光二极管交替为间隔点亮状态,循环交替时间为2s。,图76 利用串行口扩展输出接口,75,74HC164是串行输入、并行输出移位寄存器。Q0Q7为并行输出端;A、B为串行输入端;CLR为清除端,零电平时,使74HC164输出清“0”;CK为时钟脉冲输入端,在CK脉冲的上升沿作用下实现移位。在CK0,CLR1时,74HC164保持原来数据状态。,由于74HC164无并行输出控制端,在串行输入过程中其输出端的状态会不断变化,故在某些使用场合,在74HC164与输出装置之间还应加上输出可控的缓冲级(如74HC244),以便在串行输入过程结束后再输出。图中的输出装置是16位发光二极管。由于74HC164在低电平输出时允许通过的电流可达8mA,故不需再加驱动电路。,76,ST:MOVSCON,#00H;设串行口为方式0,MOVA,#55H;二极管间隔点亮初值,LP2:MOVR0,#2;输出口字节数,CLRP1.0;对74HC164清0,SETBP1.0;允许数据串行移位,LP1:MOVSBUF,A;启动串行口发送,JNBTI,$;等待1帧发送结束,CLRTI;清串行口发送中断标志位,DJNZR0,LP1;判断预定字节数发送完否,LCALLDEL2s;调延时2s子程序(略),CPLA;交替点亮二极管,SJMPLP2;循环显示,77,从理论上讲,74HC164或74HC165可以无限地串级上去,进一步扩展输入输出并行口,但这种扩展方法,输入输出的速度不高,移位时钟频率为fosc12。若fosc=12MHz,则每移1位需1s。,78,742 用串行口进行异步通信,图77 双机异步通信连接图,79,【例73】编程把甲机片内RAM的60H7FH单元中的数据块从串行口输出。定义在工作方式3下发送,TB8用作奇偶校验位。采用定时器T1方式2作波特率发生器,波特率为4800,fosc=11.0592MHz,定时器初始预置值TH1=TL1=0FAH。,编程使乙机从甲机接收32个字节数据块,并存入片外1000H101FH单元。接收过程中要求判奇偶校验标志RB8。若出错,则置F0标志为1,若正确则置F0标志为0,然后返回。,80,解:编写发送子程序如下:,MOVTMOD,#20H;设置定时器T1为方式2,MOVTL1,#0FAH;设预置值,MOVTH1,#0FAH,SETBTR1;启动定时器T1,MOVSCON,#0C0H;设置串行口为方式3,MOVPCON,#00H;SMOD0,MOVR0,#60H;设数据决指针,MOVR7,#20H;设数据长度20H,TRS:MOVA,R0;取数据送至A,MOVC,P,MOVTB8,C;奇偶位P送至TB8,MOVSBUF,A;数据送至SBUF,启动发送,WAIT:JNBTI,$;判1帧是否发送完,CLRTI,INCR0;更新数据单元,DJNZR7,TRS;循环发送至结束,RET;返回,81,在进行双机通信时,两机应用相同的工作方式和波特率,因而接收子程序编程如下:,MOVTMOD,#20H;设置定时器T1为方式2,MOVTL1,#0FAH;设预置值,MOVTH1,#0FAH,SETBTR1;启动定时器T1,MOVSCON,#0C0H;设置串行口为方式3,MOVPCON,#00H;SMOD0,MOVDPTR,#1000H;设置数据块指针,MOVR7,#20H;设数据块长度,SETBREN;允许接收,WAIT:JNBRI,;判断1帧是否接收完,CLRRI,MOVA,SBUF;读入1帧数据,JNBPSW.0,PZ;奇偶位P为0,则转,JNBRB8,ERR;P=1,RB8=0,则出错,SJMPYES;二者全为1,则正确,82,PZ:JBRB8,ERR;二者全为0,则正确;P0,RB81,则出错,YES:MOVXDPTR,A;正确,存放数据,INCDPTR;修改地址指针,DJNZR7,WAIT;判断数据块接收完否,CLRPSW.5;接收正确,且接收完,清F0标志,RET;返回,ERR:SETBPSW.5;出错,则置F0标志为1,RET;返回,上例是在方式3下进行收发,用奇偶位进行校验。,83,84,在方式1下进行双机通信,用累加和进行校验的方法。,【例74】设甲机发送乙机接收,波特率为2400波特,两机晶振均为6MHz。要求甲机将外部数据存储器4000H40FFH单元的内容向乙机发送,在发送数据之前将数据块长度发送给乙机,发送完256B后,向乙机发送一个累加校验和。,乙机接收甲机发送的数据,并写入以300H为首址的外部数据存储器中。首先接收数据长度,接着接收数据,当接收完256B后,接收校验码,进行累加和校验。数据传送结束时,向甲机发送一个状态字节,表示传送是正确或出错。,85,解:因波特率已指定为2400波特,首先需要确定定时初值和SMOD的值。,此时,若取SMOD0,则X24949249,误差较大;,取SMODl,则X242.98243F3H,误差较小。,发送程序作如下约定:,定时器T1按方式2工作,计数初值为F3H,SMOD1。,串行口按方式1工作,允许接收。,R6设为数据块长度寄存器,R5设为累加和寄存器,。,86,1甲机发送程序清单,TRT:MOVTMOD,#20H;设定时器T1工作在方式2,MOVTH1,#0F3H;设定时器T1的初值,MOVTL1,#0F3H,SETBTR1;启动定时器T1,MOVSCON,#50H;串行口初始化为方式1,允许接收,MOVPCON,#80H;SMOD1,RPT:MOVDPTR,#4000H,MOVR6,#00H;长度寄存器初始化,长度为,256,字节,MOVR5,#00H;校验和寄存器初始化,MOVSBUF,R6;发送长度,JNBTI,;等待发送,CLRTI,87,L1:MOVXA,DPTR;读取数据,MOVSBUF,A;发送数据,ADDA,R5;形成累加和送至R5,MOVR5,A,INCDPTR;修改地址指针,JNBTI,$;等待发送,CLRTI,DJNZR6,L1;判断是否发送完256个数据,MOVSBUF,R5;发校验码,MOVR5,#00H,JNBTI,$,CLRTI,JNBRI,$;等乙机回答,CLRRI,MOVA,SBUF,JZL8;发送正确则返回,AJMPRPT;发送有错则重发,L8:RET,88,2乙机接收程序清单,接收程序的通信约定同发送程序。,RSU:MOVTMOD,#20H;T1初始化,MOVTH1,#0F3H,MOVTL1,#0F3H,SETBTR1,MOVSCON,#50H,MOVPCON,#80H,RPT:MOVDPTR,#300H,JNBRI,,CLRRI,MOVA,SBUF;接收发送长度,MOVR6,A,MOVR5,#00H;累加和寄存器清“0”,89,WTD:JNBRI,,CLRRI,MOVA,SBUF;接收数据,MOVXDPTR,A;存储数据,INCDPTR;修改地址指针,ADDA,R5,MOVR5,A,DJNZR6,WTD;未接收完,继续,JNBRI,$;接收校验码,CLRRI,MOVA,SBUF,XRLA,R5;比较校验码,MOVR5,#00H,JZL6;正确则转至L6,90,MOVSBUF,#0FFH;出错送0FFH,JNBTI,$,CLRTI,AJMPRPT;重新接收,L6:MOVSBUF,#00H;正确回送00H,JNBTI,$;发送完返回,CLRTI,RET,91,此课件下载可自行编辑修改,仅供参考!感谢您的支持,我们努力做得更好!谢谢,
展开阅读全文