1.方式0
方式0时,串行口为同步移位寄存器的输入输出方式。主要用于扩展并行输入或输出口。数据由RXD(P3.0)引脚输入或输出,同步移位脉冲由TXD(P3.1)引脚输出。发送和接收均为8位数据,低位在先,高位在后。波特率固定为fosc/12。
方式0输出
方式0输入
2.方式1
方式1是10位数据的异步通信口。TXD为数据的发送引脚,RXD是数据的接受引脚。传送一帧数据的格式如图所示,其中1位起始位,8位数据位,1位停止位。
方式1输出
方式1输入
用软件置REN=1时,接收器以所选择波特率的16倍速率采样RXD引脚电平,检测到RXD引脚输入电平发生负跳变时,则说明起始位有效,将其移入输入移位寄存器,并开始接收这一帧信息的其余位。接收过程中,数据从输入移位寄存器右边移入,起始位移至输入移位寄存器最左边时,控制电路进行最后一次移位。当RI=0,且SM2=0时,将接收到的9位数据的前八位数据装入接收SBUF,第九位(停止位)进入RB8,并置RI=1,请求中断。
3.方式2、方式3
方式2或方式3时,为11位数据的异步通信口,TXD为数据发送引脚,RXD为数据接收引脚。
方式2、方式3,起始位1位、数据位9位(含附加的第九位,发送时为SCON中的TB8,接收时为SCON中的RB8)、停止位1位,一帧数据为11位。方式2的波特率固定为晶振频率的1/32或1/64。方式3的波特率由定时器T1的溢出率决定。
方式2、方式3的输出
发送开始时,先把起始位0输出到TXD引脚,然后发送移位寄存器的输出位(D0)到TXD引脚。每一个移位脉冲都使输出移位寄存器的各位右移一位,并由TXD引脚输出。
第一次移位时,停止位‘1’移入输出移位寄存器的第9位上,以后每次移位,左边都移入‘0’。当停止位移入输出位时,左边其余位全为‘0’,检测电路检测到这一条件时,使控制电路进行最后一次移位,并置TI=1,向CPU请求中断。
方式2、方式3的输入
接收时,数据从右边移入输入移位寄存器,在起始位‘0’移到最左边时,控制电路进行最后一次移位。当RI=0,且SM2=0时,接收到的数据装入接收缓存器SBUF和RB8(接收数据的第9位),置RI=1,请求中断。如果条件不满足,则数据丢失,且不置位RI,继续搜索RXD引脚的负跳变。
波特率的计算
方式0的波特率:fosc/12
方式2的波特率:(2^SMOD/64)*fosc
方式1的波特率:(2^SMOD/32)*(TI溢出率)
方式3的波特率:(2^SMOD/32)*(TI溢出率)