2 W9 q8 f. ^6 c5 v% r( c- R! p6 f
: q" n8 S+ i( S其中fosc为晶体震荡器频率
: V' {+ k$ s. }0 U0 bsm2:多机通信控制位。在方式0时,SM2一定要等于0。在方式1中,当(SM2)=1则只有接收到有效停止位时,RI才置1。在方式2或方式3当(SM2)=1且接收到的第九位数据RB8=0时,RI才置1。
5 l# T8 @: W4 W- X1 U( o* d1 h& e |
4 p5 l8 t: r) O5 X! D+ J3 ]' mREN:接收允许控制位。由软件置位以允许接收,又由软件清0来禁止接收。
" @$ X/ m' j2 e/ x9 q! S
% ~. ?& E5 t% o: r* tTB8: 是要发送数据的第9位。在方式2或方式3中,要发送的第9位数据,根据需要由软件置1或清0。例如,可约定作为奇偶校验位,或在多机通信中作为区别地址帧或数据帧的标志位。
6 i9 k9 E/ ?0 h) C& P X# i# S
# ?" t- V5 J( j) L( h9 n# I5 BRB8:接收到的数据的第9位。在方式0中不使用RB8。在方式1中,若(SM2)=0,RB8为接收到的停止位。在方式2或方式3中,RB8为接收到的第9位数据。
/ l- ?# b" J; K. e( O
/ v: O3 f; x S2 |) N
ti:发送中断标志。在方式0中,第8位发送结束时,由硬件置位。在其它方式的发送停止位前,由硬件置位。TI置位既表示一帧信息发送结束,同时也是申请中断,可根据需要,用软件查询的办法获得数据已发送完毕的信息,或用中断的方式来发送下一个数据。TI必须用软件清0。
: y/ @# o. ^) y
3 L3 a0 o/ F$ \/ M" H
RI:接收中断标志位。在方式0,当接收完第8位数据后,由硬件置位。在其它方式中,在接收到停止位的中间时刻由硬件置位(例外情况见于SM2的说明)。RI置位表示一帧数据接收完毕,可用查询的办法获知或者用中断的办法获知。RI也必须用软件清0。
9 C0 w# k! A- i3 c" U% C" g! }+ C5 Y5 J0 e( D
特殊功能寄存器PCON
, M" ^6 C0 p$ x- F3 [, m5 G4 K4 U- i5 o/ w% T9 z
PCON是为了在CHMOS的80C51单片机上实现电源控制而附加的。其中最高位是SMOD。
; z, w1 ]: O9 a5 O2 l! ]
7 [; G( _; x8 D# t0 T5 a; }串行口的工作方式
# F$ F& t6 X' n0 Z* ?6 S
8 c4 W# |! d( X# e* g) d5 W9 m8051单片机的全双工串行口可编程为4种工作方式,现分述如下:
. i+ c+ u$ j) |' J# g4 l: z& _: Q9 t2 T
方式0为移位寄存器输入/输出方式。可外接移位寄存器以扩展I/O口,也能外接同步输入/输出设备。8位串行数据者是从RXD输入或输出,TXD用来输出同步脉冲。
/ T0 ?7 n' g# S! E0 X, w8 @& S: v+ a# `( ^: ~ [" d
输出 串行数据从RXD管脚输出,TXD管脚输出移位脉冲。CPU将数据写入发送寄存器时,立即启动发送,将8位数据以fos/12的固定波特率从RXD输出,低位在前,高位在后。发送完一帧数据后,发送中断标志TI由硬件置位。
. R! i M, g5 A8 G) `
0 t, d* t5 m' j9 [) O输入 当串行口以方式0接收时,先置位允许接收控制位REN。此时,RXD为串行数据输入端,TXD仍为同步脉冲移位输出端。当(RI)=0和(REN)=1同时满足时,开始接收。当接收到第8位数据时,将数据移入接收寄存器,并由硬件置位RI。
$ [) L) R: z7 D1 x
7 ^8 t `" w2 @9 x0 E$ {* O下面两图分别是方式0扩展输出和输入的接线图。
8 `2 K* z# R8 r8 ]# h2 K) i/ R
1 u6 g) L/ ~% X* c- D7 `
# D# z! |6 g/ ^+ V q7 t0 t<单片机串行口接线图>
/ n& v* J/ R: E* P* a- l方式1为波特率可变的10位异步通信接口方式。发送或接收一帧信息,包括1个起始位0,8个数据位和1个停止位1。
]. `8 B' R2 P
# i. J( `) j: c8 x
输出 当CPU执行一条指令将数据写入发送缓冲SBUF时,就启动发送。串行数据从TXD管脚输出,发送完一帧数据后,就由硬件置位TI。
) i9 u; M1 b9 R6 t, G7 \. ?0 M) ~6 C# {- X0 A3 |! \6 A) F+ {3 }
输入 在(REN)=1时,串行口采样RXD管脚,当采样到1至0的跳变时,确认是开始位0,就开始接收一帧数据。只有当(RI)=0且停止位为1或者(SM2)=0时,停止位才进入RB8,8位数据才能进入接收寄存器,并由硬件置位中断标志RI;不然信息丢失。所以在方式1接收时,应先用软件清零RI和SM2标志。
8 v% F% L* @, t: t1 m' ~$ h* ~' D/ h! c+ g; u8 g. F/ ]7 E
方式2
- s. Q* ]& }6 Q2 f* `7 v7 j- V0 n/ G) t- u( F# W, e8 y; b
方式月为固定波特率的11位UART方式。它比方式1增加了一位可程控为1或0的第9位数据。
: T# ?) r9 W/ _" z, x! ^- a- l$ H7 n
输出: 发送的串行数据由TXD端输出一帧信息为11位,附加的第9位来自SCON寄存器的TB8位,用软件置位或复位。它可作为多机通信中地址/数据信息的标志位,也能作为数据的奇偶校验位。当CPU执行一条数据写入SUBF的指令时,就启动发送器发送。发送一帧信息后,置位中断标志TI。
3 D' o# h$ u9 U `. T
! d; u. D' K# g' ]" n7 S
输入: 在(REN)=1时,串行口采样RXD管脚,当采样到1至0的跳变时,确认是开始位0,就开始接收一帧数据。在接收到附加的第9位数据后,当(RI)=0或者(SM2)=0时,第9位数据才进入RB8,8位数据才能进入接收寄存器,并由硬件置位中断标志RI;不然信息丢失。且不置位RI。再过一位时间后,不管上述条件时否满足,接收电路即行复位,并重新检测RXD上从1到0的跳变。
! @7 E' S g% C9 M( ?; R; Y) }
; C: I. H9 i6 N8 x2 M5 j: u
工作方式3
" ^8 L: \/ f1 o
8 d& u8 a, ~: u' U
方式3为波特率可变的11位UART方式。除波特率外,其余与方式2相同。
! P+ q% P3 s& B3 ?# e' A6 F
7 X! O4 k+ Q7 z: L% Y波特率选择
5 S B3 {1 q( w* J S3 O8 e& w3 m; L4 e( b; O5 x( Z1 K
如前所述,在串行通信中,收发双方的数据传送率(波特率)要有一定的约定。在8051串行口的四种工作方式中,方式0和2的波特率是固定的,而方式1和3的波特率是可变的,由定时器T1的溢出率控制。
9 u2 U9 F( e6 j! Q* f9 o$ n: }) }4 N1 \4 _8 ^9 O- s4 X! X
方式0
& r. ?% w I7 Y- n% `: c1 W# V/ P- q1 U7 W; G) }
方式0的波特率固定为主振频率的1/12。
( N4 _1 J3 m4 Q$ _& z/ v, Y; ^
5 {2 n0 l# U- g. I% O3 q方式2
( }8 k+ w+ E$ h i, \# J; x+ m+ F# p% B/ r' D; N
方式2的波特率由PCON中的选择位SMOD来决定,可由下式表示:
5 O; @' L# C M) d6 h% \6 q
5 `7 K5 |" A& W2 W* p5 ?波特率=2的SMOD次方除以64再乘一个fosc,也就是当SMOD=1时,波特率为1/32fosc,当SMOD=0时,波特率为1/64fosc
$ Y2 E9 A* {! @# d
; ` X M* A6 R% i3 M& F- }. p3.方式1和方式3
3 a' j5 a9 T9 U& F" g# ~
$ J8 A! E. }# J+ R, Z' s' K定时器T1作为波特率发生器,其公式如下:
& L5 E6 I- x' U) B8 g6 Q8 G
" o* ~$ p% U( f5 a) `
波特率=
![]()
定时器T1溢出率
0 m9 b6 Q1 r2 D6 G' ?% I- j$ M7 A% |7 B J9 z/ N+ t
T1溢出率= T1计数率/产生溢出所需的周期数
7 Z: A, t, p. l9 W7 ]. `0 T( L- `' C& J! |/ `
式中T1计数率取决于它工作在定时器状态还是计数器状态。当工作于定时器状态时,T1计数率为fosc/12;当工作于计数器状态时,T1计数率为外部输入频率,此频率应小于fosc/24。产生溢出所需周期与定时器T1的工作方式、T1的预置值有关。
$ S* t R1 Y0 }! h) m5 }/ {" w: L7 @* E
定时器T1工作于方式0:溢出所需周期数=8192-x
% {9 W v+ u+ |9 K6 y, y& {: Y
% X' a6 l) ], N1 d# s定时器T1工作于方式1:溢出所需周期数=65536-x
' y; D: ~: ^ O' f( M
# t8 K3 Q* ?( o) U9 |0 ^
定时器T1工作于方式2:溢出所需周期数=256-x
' k- l9 y8 h, O/ z/ s9 F8 e6 B7 {
因为方式2为自动重装入初值的8位定时器/计数器模式,所以用它来做波特率发生器最恰当。
" |6 Q q. O0 J# _; m
/ [5 K9 D* a0 \! T, z+ ^3 Q当时钟频率选用11.0592MHZ时,取易获得标准的波特率,所以很多单片机系统选用这个看起来“怪”的晶体震荡器就是这个道理。
" Y* W7 C5 }5 {) y. b3 c2 y' Z4 O/ E/ K8 {$ F" Z0 j1 X) l7 C, y. W
下表列出了定时器T1工作于方式2常用波特率及初值。
/ ~. W( J6 \) o/ l+ ?, O
k) e2 ?, ~: _; e
# S; t7 o& i2 B) Z: ^
# t1 H6 M m+ m
9 e; h* q' ?' h. J