* c( b2 T1 m( q' B
* O/ x: q/ ?8 b/ l其中fosc为晶体震荡器频率
0 h2 }& ^. k, I# M- O
sm2:多机通信控制位。在方式0时,SM2一定要等于0。在方式1中,当(SM2)=1则只有接收到有效停止位时,RI才置1。在方式2或方式3当(SM2)=1且接收到的第九位数据RB8=0时,RI才置1。
* y4 l8 B5 Z8 \0 a3 u
' _! g x, T0 }7 P4 q7 q3 T
REN:接收允许控制位。由软件置位以允许接收,又由软件清0来禁止接收。
- X% _, J9 d0 _" F8 M6 D+ l; c
8 h+ `- J- I8 I& nTB8: 是要发送数据的第9位。在方式2或方式3中,要发送的第9位数据,根据需要由软件置1或清0。例如,可约定作为奇偶校验位,或在多机通信中作为区别地址帧或数据帧的标志位。
7 ~1 Q! y1 z4 v3 L+ U% W% B
1 Y/ D2 R, l) j8 l6 \9 i; JRB8:接收到的数据的第9位。在方式0中不使用RB8。在方式1中,若(SM2)=0,RB8为接收到的停止位。在方式2或方式3中,RB8为接收到的第9位数据。
- d9 n4 X Z. F4 @% Q0 }/ K) E1 `$ F
" `1 d4 w8 \8 y
ti:发送中断标志。在方式0中,第8位发送结束时,由硬件置位。在其它方式的发送停止位前,由硬件置位。TI置位既表示一帧信息发送结束,同时也是申请中断,可根据需要,用软件查询的办法获得数据已发送完毕的信息,或用中断的方式来发送下一个数据。TI必须用软件清0。
# k6 D; J1 ?$ g7 Q/ j; x- o: H7 ~ I, E) B- z# n
RI:接收中断标志位。在方式0,当接收完第8位数据后,由硬件置位。在其它方式中,在接收到停止位的中间时刻由硬件置位(例外情况见于SM2的说明)。RI置位表示一帧数据接收完毕,可用查询的办法获知或者用中断的办法获知。RI也必须用软件清0。
, x* z; Y; s9 o" f8 b; v+ ~# b
4 V- o/ h9 f! g p特殊功能寄存器PCON
( [9 k( s8 D0 ?( k. ]
8 d4 h( C$ Z/ t2 x9 d5 e/ I
PCON是为了在CHMOS的80C51单片机上实现电源控制而附加的。其中最高位是SMOD。
. L7 F. {9 z: r5 G; h* c! p. z4 @# |" n% L8 g( t, b
串行口的工作方式
7 U. h# Q: @) I I# n
! x* K2 [: O$ S7 K( s/ P
8051单片机的全双工串行口可编程为4种工作方式,现分述如下:
4 ?2 a7 ?* v& q0 N
2 Y" t. K# G; \1 U1 T方式0为移位寄存器输入/输出方式。可外接移位寄存器以扩展I/O口,也能外接同步输入/输出设备。8位串行数据者是从RXD输入或输出,TXD用来输出同步脉冲。
; L$ V L# q$ l2 T/ Y: \9 L
+ ^+ U+ Y8 |1 J; D2 n输出 串行数据从RXD管脚输出,TXD管脚输出移位脉冲。CPU将数据写入发送寄存器时,立即启动发送,将8位数据以fos/12的固定波特率从RXD输出,低位在前,高位在后。发送完一帧数据后,发送中断标志TI由硬件置位。
3 S7 m) t+ P' D) Z3 X4 e6 |
& i9 b3 U6 F, Y) u输入 当串行口以方式0接收时,先置位允许接收控制位REN。此时,RXD为串行数据输入端,TXD仍为同步脉冲移位输出端。当(RI)=0和(REN)=1同时满足时,开始接收。当接收到第8位数据时,将数据移入接收寄存器,并由硬件置位RI。
5 T& \2 h5 w1 g/ y+ @( G
$ c( T* b6 E; y
下面两图分别是方式0扩展输出和输入的接线图。
2 J" Y3 G F) V
6 ]( a8 R) o: ?. v# Z
P, E3 m/ @( G& \/ r<单片机串行口接线图>
1 Z# e, [5 u( R) f
方式1为波特率可变的10位异步通信接口方式。发送或接收一帧信息,包括1个起始位0,8个数据位和1个停止位1。
. N) k/ C0 z4 ?- ]
1 w, t3 |6 o- ?3 r9 j
输出 当CPU执行一条指令将数据写入发送缓冲SBUF时,就启动发送。串行数据从TXD管脚输出,发送完一帧数据后,就由硬件置位TI。
) o; u- J+ O( D' P' i/ [; `0 c# U( e* f6 U1 K" h! }
输入 在(REN)=1时,串行口采样RXD管脚,当采样到1至0的跳变时,确认是开始位0,就开始接收一帧数据。只有当(RI)=0且停止位为1或者(SM2)=0时,停止位才进入RB8,8位数据才能进入接收寄存器,并由硬件置位中断标志RI;不然信息丢失。所以在方式1接收时,应先用软件清零RI和SM2标志。
; p! p% {" [: P5 ?2 @
* _ G* P, [2 P c; w# p/ m, }
方式2
9 F5 u# L& v, c7 B, }8 v
) S7 R, N8 w! p+ g$ B3 Y3 W' P& @, B
方式月为固定波特率的11位UART方式。它比方式1增加了一位可程控为1或0的第9位数据。
; V" B/ u& s( X* l6 Z+ C& {6 P
/ y5 {7 ^, Y& Q/ P f
输出: 发送的串行数据由TXD端输出一帧信息为11位,附加的第9位来自SCON寄存器的TB8位,用软件置位或复位。它可作为多机通信中地址/数据信息的标志位,也能作为数据的奇偶校验位。当CPU执行一条数据写入SUBF的指令时,就启动发送器发送。发送一帧信息后,置位中断标志TI。
2 K$ T1 g/ q" p0 U
- P) g; t+ y( f* n: ?. ?' l/ [4 f
输入: 在(REN)=1时,串行口采样RXD管脚,当采样到1至0的跳变时,确认是开始位0,就开始接收一帧数据。在接收到附加的第9位数据后,当(RI)=0或者(SM2)=0时,第9位数据才进入RB8,8位数据才能进入接收寄存器,并由硬件置位中断标志RI;不然信息丢失。且不置位RI。再过一位时间后,不管上述条件时否满足,接收电路即行复位,并重新检测RXD上从1到0的跳变。
`% n A5 ?2 H1 [) o9 P
: g p; F0 R6 N' m! h# ^) |$ q工作方式3
& ~& q: X* l* H: B4 a* l
. Z" o+ e, S4 W1 f* f方式3为波特率可变的11位UART方式。除波特率外,其余与方式2相同。
0 Y7 _, P& Q$ [0 K N
/ o. f: [8 t1 B- o7 M$ B波特率选择
, p' R* F+ a; n
" D& x8 ^ D2 R/ E. K如前所述,在串行通信中,收发双方的数据传送率(波特率)要有一定的约定。在8051串行口的四种工作方式中,方式0和2的波特率是固定的,而方式1和3的波特率是可变的,由定时器T1的溢出率控制。
4 D f0 P: I2 x4 V# d% `' e
( ~. ~$ f7 z0 b: M9 |方式0
l- J: t( I/ X3 ~
/ t, W0 U+ Y' E! j
方式0的波特率固定为主振频率的1/12。
/ a/ ]5 v/ ~- ~; i
8 t( ^6 J; x* h# _4 h方式2
! L5 G! k) B' f' o$ a6 I1 n' T. ^6 S
方式2的波特率由PCON中的选择位SMOD来决定,可由下式表示:
" x- {* Z$ f# F$ w- B* {1 e$ I
" K( }6 h! i+ u d6 W
波特率=2的SMOD次方除以64再乘一个fosc,也就是当SMOD=1时,波特率为1/32fosc,当SMOD=0时,波特率为1/64fosc
5 M7 S/ S/ p* V
2 x6 d3 ?, D6 N3.方式1和方式3
. c5 F) d: _' y/ [
& Z- X+ v& i7 r; L定时器T1作为波特率发生器,其公式如下:
; {- N# ? O; E: B
6 I" E: `, n5 H; Z7 q. x3 w波特率=
![]()
定时器T1溢出率
% j- V1 j6 [/ Q' h3 K2 G* x) g$ P& d9 l& n1 F' z7 [; I
T1溢出率= T1计数率/产生溢出所需的周期数
8 L q7 n; g- j9 b, ~$ W6 m- w" m$ [
1 G4 q) ~; z+ ~6 c) c3 r. d% V式中T1计数率取决于它工作在定时器状态还是计数器状态。当工作于定时器状态时,T1计数率为fosc/12;当工作于计数器状态时,T1计数率为外部输入频率,此频率应小于fosc/24。产生溢出所需周期与定时器T1的工作方式、T1的预置值有关。
: f# T7 Z4 w% B0 n: P0 D4 j
! D9 _+ \% D8 s; y
定时器T1工作于方式0:溢出所需周期数=8192-x
# A" }( u6 `5 ? y6 |. u9 o
6 J7 A0 p$ g* P0 c& t定时器T1工作于方式1:溢出所需周期数=65536-x
; g8 I8 y% f; W( b! z# Z1 }
) V" V1 X4 Q( b7 Q6 E. \: P
定时器T1工作于方式2:溢出所需周期数=256-x
7 O: I! Z. J+ E
@, o# `! J) |# _& e- f W- f# q因为方式2为自动重装入初值的8位定时器/计数器模式,所以用它来做波特率发生器最恰当。
. b' F& k8 R+ M. I1 ]6 m! \
; L! [ k8 B7 X6 K8 H9 S c9 `5 Q3 H
当时钟频率选用11.0592MHZ时,取易获得标准的波特率,所以很多单片机系统选用这个看起来“怪”的晶体震荡器就是这个道理。
, c/ d$ `7 _" ~$ i( f
* ?( ^. Z. w3 @9 O. e% `; R3 `下表列出了定时器T1工作于方式2常用波特率及初值。
) k8 j7 ?$ V( j3 I, C
1 N# [3 R5 G! V
1 {- ]/ f+ n. {2 @
; c. ^5 `) k% N9 j
, P! k$ B' @0 y7 I