2 S1 f8 s; O& {( i3 u7 p+ I
# X% {, B5 t9 C& }; }7 W
引腳功能:
: A% j5 f& O8 G1 t) J+ i9 X4 b: S$ n* z0 u, FMCS-51是標準的40引腳雙列直插式集成電路芯片,引腳分布請參照----單片機引腳圖: + \7 h5 v( ~- c" f: ^* l$ n
l P0.0~P0.7 P0口8位雙向口線(在引腳的39~32號端子)。
" K* Z5 ]. t6 m/ yl P1.0~P1.7 P1口8位雙向口線(在引腳的1~8號端子)。
6 d2 e* M }& q/ Yl P2.0~P2.7 P2口8位雙向口線(在引腳的21~28號端子)。 4 a _$ f7 b# f2 V6 [7 ?
l P3.0~P3.7 P2口8位雙向口線(在引腳的10~17號端子)。
# @2 d" _8 a$ \5 X8 A" h/ }這4個I/O口具有不完全相同的功能,大家可得學好了,其它書本里雖然有,但寫的太深,對于初學者來說很難理解的,我這里都是按我自已的表達方式來寫的,相信你也能夠理解的。
+ H& q; A, K; W+ q% v+ S3 PP0口有三個功能:
0 ]5 G" i3 _6 v4 p$ C$ ]8 Z1、外部擴展存儲器時,當做數(shù)據(jù)總線(如圖1中的D0~D7為數(shù)據(jù)總線接口) 9 p2 h; N+ v6 }, g2 _
2、外部擴展存儲器時,當作地址總線(如圖1中的A0~A7為地址總線接口)
% b- v5 V1 ^2 g2 V8 R3、不擴展時,可做一般的I/O使用,但內(nèi)部無上拉電阻,作為輸入或輸出時應在外部接上拉電阻。 : X" Y( L+ f: g
P1口只做I/O口使用:其內(nèi)部有上拉電阻。 B- I% m# {7 Z/ b
P2口有兩個功能:
/ k* [% w' F1 U% \7 ^1、擴展外部存儲器時,當作地址總線使用
7 K7 o' l3 _# O2、做一般I/O口使用,其內(nèi)部有上拉電阻; # ~: L0 E/ t% @5 _& H7 `; s
P3口有兩個功能: 7 D2 R: C, }, h7 b+ k) y/ _8 I' T
除了作為I/O使用外(其內(nèi)部有上拉電阻),還有一些特殊功能,由特殊寄存器來設置,具體功能請參考我們后面的引腳說明。 : F7 G* g0 P4 D& [
有內(nèi)部EPROM的單片機芯片(例如8751),為寫入程序需提供專門的編程脈沖和編程電源,這些信號也是由信號引腳的形式提供的, * x/ c6 R$ n8 I+ @& D
即:編程脈沖:30腳(ALE/PROG) 3 U+ Y% ~ t8 `6 \ D4 G! A
編程電壓(25V):31腳(EA/Vpp)
5 H- [2 U1 a& l4 S接觸過工業(yè)設備的兄弟可能會看到有些印刷線路板上會有一個電池,這個電池是干什么用的呢?這就是單片機的備用電源,當外接電源下降到下限值時,備用電源就會經(jīng)第二功能的方式由第9腳(即RST/VPD)引入,以保護內(nèi)部RAM中的信息不會丟失。 3 l% a% f# V8 S( g
(注:這些引腳的功能應用,除9腳的第二功能外,在“新動力2004版”學習套件中都有應用到。)
6 a. ?$ B: z: g" y在介紹這四個I/O口時提到了一個“上拉電阻”那么上拉電阻又是一個什么東東呢?他起什么作用呢?都說了是電阻那當然就是一個電阻啦,當作為輸入時,上拉電阻將其電位拉高,若輸入為低電平則可提供電流源;所以如果P0口如果作為輸入時,處在高阻抗狀態(tài),只有外接一個上拉電阻才能有效。
/ r3 A! ?( {7 T1 l/ K. T9 |( t ALE 地址鎖存控制信號:在系統(tǒng)擴展時,ALE用于控制把P0口的輸出低8位地址送鎖存器鎖存起來,以實現(xiàn)低位地址和數(shù)據(jù)的隔離。參見圖2(8051擴展2KB EEPROM電路,在圖中ALE與4LS373鎖存器的G相連接,當CPU對外部進行存取時,用以鎖住地址的低位地址,即P0口輸出。 $ x1 A) G7 |) R# {3 U w0 q
由于ALE是以晶振六分之一的固定頻率輸出的正脈沖,當系統(tǒng)中未使用外部存儲器時,ALE腳也會有六分之一的固定頻率輸出,因此可作為外部時鐘或外部定時脈沖使用。
2 O. y/ H p! `; c& \! o" A; t$ t PSEN 外部程序存儲器讀選通信號:在讀外部ROM時PSEN低電平有效,以實現(xiàn)外部ROM單元的讀操作。
) y* f5 A8 w' V9 T Y) K& m1、內(nèi)部ROM讀取時,PSEN不動作; - X) _; l( S) x3 u2 m: D
2、外部ROM讀取時,在每個機器周期會動作兩次;
1 c' Z# z3 L a( p+ Z3、外部RAM讀取時,兩個PSEN脈沖被跳過不會輸出; , F( L3 i( t; X: @$ I, V( S
4、外接ROM時,與ROM的OE腳相接。 # {6 a" V0 H4 b4 ]+ {2 ?3 I, p
參見圖2—(8051擴展2KB EEPROM電路,在圖中PSEN與擴展ROM的OE腳相接) , o s: I4 B) Y6 G4 g( y. l
EA/VPP 訪問和序存儲器控制信號
2 f( H2 k( R3 R1、接高電平時:
% E* S7 ? W( FCPU讀取內(nèi)部程序存儲器(ROM)
# n; l. W3 V7 W: l) G9 R. b擴展外部ROM:當讀取內(nèi)部程序存儲器超過0FFFH(8051)1FFFH(8052)時自動讀取外部ROM。 0 K# F! U' ?' p5 x) @' X: x
2、接低電平時:CPU讀取外部程序存儲器(ROM)。
4 ~) W' k) l; z/ [# ~& g3 V) V3、8751燒寫內(nèi)部EPROM時,利用此腳輸入21V的燒寫電壓。
( i' V7 s3 N% {5 R2 r
RST 復位信號:當輸入的信號連續(xù)2個機器周期以上高電平時即為有效,用以完成單片機的復位初始化操作。 R0 f8 U1 `# o( M/ w$ w% Z- m# j$ W
XTAL1和XTAL2 外接晶振引腳。當使用芯片內(nèi)部時鐘時,此二引腳用于外接石英晶體和微調(diào)電容;當使用外部時鐘時,用于接外部時鐘脈沖信號。
VCC:電源+5V輸入
$ l! K) b! ?% U VSS:GND接地。
: x# l0 Z; U5 G
各端口工作原理講解 $ x: y6 y' k+ I6 L5 M# c
并行端口
( F) B3 Z" ^+ oP0端口
( H \6 |% N: {6 Y* V& i* ]+ O$ z- @總線I/O端口,雙向,三態(tài),數(shù)據(jù)地址分時復用,該端口除用于數(shù)據(jù)的輸入/輸出外,在8031單片機外接程序存儲器時,還分時地輸出/輸入地址/指令。由Po端口輸出的信號無鎖存,輸入的信息有讀端口引腳和讀端口鎖存器之分。P0端口8位中的一位結構圖見下圖: - w/ a* X! r- ?3 L% u& [8 e
, V1 b4 J9 } e: B

* T; N, D F/ d7 m4 k 由上圖可見,P0端口由鎖存器、輸入緩沖器、切換開關與相應控制電路、場效應管驅(qū)動電路構成。 在輸出狀態(tài)下,當切換開關MUX向下時,從內(nèi)部總線來的數(shù)據(jù)經(jīng)鎖存器反相和場效應管T2反相,輸出到端口引腳線上。此時,場效應管T1關斷,因而這種輸出方式應為外接上拉電阻的漏極開路式。當切換開關MUX向上時,一位地址/數(shù)據(jù)信號分時地輸出到端口線上。此外,由T1、T2的通斷組合,形成高電平、低電平與高阻浮動三態(tài)的輸出。 在輸入狀態(tài)下,從鎖存器和從引腳上讀來的信號一般是一致的,但也有例外。例如,當從內(nèi)部總線輸出低電平后,鎖存器Q=0,Q=1,場效應管T2開通,端口線呈低電平狀態(tài)。此時無論端口線上外接的信號是低電乎還是高電平,從引腳讀入單片機的信號都是低電平,因而不能正確地讀入端口引腳上的信號。又如,當從內(nèi)部總線輸出高電平后,鎖存器Q=1,Q=0,場效應管T2截止。如外接引腳信號為低電平,從引腳上讀入的信號就與從鎖存器讀入的信號不同。為此,8031單片機在對端口P0一P3的輸入操作上,有如下約定:為此,8031單片機在對端口P0一P3的輸入操作上,有如下約定:凡屬于讀-修改-寫方式的指令,從鎖存器讀入信號,其它指令則從端口引腳線上讀入信號。 讀-修改-寫指令的特點是,從端口輸入(讀)信號,在單片機內(nèi)加以運算(修改)后,再輸出(寫)到該端口上。下面是幾條讀--修改-寫指令的例子。
" T1 E; O7 S1 v' |$ T1 x
* E1 H- @" g9 @ C i$ U( C; s& d' k- N0 L9 L
& Y [9 } L9 X+ B: ?% y( v; w) \ANL P0,#立即數(shù) | " ~) F& _& h1 r- X( c& V1 \. C% t- e
0→立即數(shù)P0 |
# g F7 J6 F# ]' H$ m# h& R8 e4 k# }+ R
ORL P0,A | & C6 P. b5 k# A0 I
0→AP0 |
/ w g9 _6 y* J/ z" L' Y
7 A, d: N, G; wINC P1 |
2 K2 r6 h% A5 [: S1 X3 m 1+1→P1 | + p; |# ` r$ Q3 }& u( ?+ i8 \5 Y
( t: O7 h2 E2 O( I$ h5 ]) H2 V
DEC P3 | 5 u! M5 X$ N, \% w
;P3-1→P3 | ' i9 p7 U9 X9 Y D; ?
5 [& _' T2 M7 R+ f/ n" i7 p
CPL P2 | ( ^! f! O* Y6 @
;P2→P2 |
$ L& v# ?5 H/ r3 ^這樣安排的原因在于讀-修改-寫指令需要得到端口原輸出的狀態(tài),修改后再輸出,讀鎖存器而不是讀引腳,可以避免因外部電路的原因而使原端口的狀態(tài)被讀錯。 P0端口是8031單片機的總線口,分時出現(xiàn)數(shù)據(jù)D7一D0、低8位地址A7一AO,以及三態(tài),用來接口存儲器、外部電路與外部設備。P0端口是使用最廣泛的I/O端口。 6 @: i0 [) @) B( r9 u
P1端口: / h0 A* G* U/ k5 ~
通用I/0端口,準雙向靜態(tài)口。輸出的信息有鎖存,輸入有讀引腳和讀鎖存器之分。P1端口的一位結構見下圖. 由圖可見,P1端口與P0端口的主要差別在于,P1端口用內(nèi)部上拉電阻R代替了P0端口的場效應管T1,并且輸出的信息僅來自內(nèi)部總線。由內(nèi)部總線輸出的數(shù)據(jù)經(jīng)鎖存器反相和場效應管反相后,鎖存在端口線上,所以,P1端口是具有輸出鎖存的靜態(tài)口。 由下圖可見,要正確地從引腳上讀入外部信息,必須先使場效應管關斷,以便由外部輸入的信息確定引腳的狀態(tài)。為此,在作引腳讀入前,必須先對該端口寫入l。具有這種操作特點的輸入/輸出端口,稱為準雙向I/O口。8031單片機的P1、P2、P3都是準雙向口。P0端口由于輸出有三態(tài)功能,輸入前,端口線已處于高阻態(tài),無需先寫入l后再作讀操作。 1 W6 h8 \; F7 J( G5 D

' j E8 z) l6 d4 `. D7 _- ~! f 單片機復位后,各個端口已自動地被寫入了1,此時,可直接作輸入操作。如果在應用端口的過程中,已向P1一P3端口線輸出過0,則再要輸入時,必須先寫1后再讀引腳,才能得到正確的信息。此外,隨輸入指令的不同,H端口也有讀鎖存器與讀引腳之分。 Pl端口是803l單片機中唯一僅有的單功能I/O端口,并且沒有特定的專用功能,輸出信號鎖存在引腳上,故又稱為通用靜態(tài)口。
# u* Z* F( x* uP2端口: P2端口的一位結構見下圖:
1 w5 {# @) p$ h * V, I" r- d: K9 @' F% F" p; z1 \# u
由圖可見,P2端口在片內(nèi)既有上拉電阻,又有切換開關MUX,所以P2端口在功能上兼有P0端口和P1端口的特點。這主要表現(xiàn)在輸出功能上,當切換開關MUX向左時,從內(nèi)部總線輸出的一位數(shù)據(jù)經(jīng)反相器和場效應管反相后,輸出在端口引腳線上;當MUX向右時,輸出的一位地址信號也經(jīng)反相器和場效應管反相后,輸出在端口引腳線上。 由于8031單片機必須外接程序存儲器才能構成應用電路,而P2端口就是用來周期性地輸出從外存中取指令的地址(高8位地址),因此,P2端口的切換開關MUX總是在進行切換,分時地輸出從內(nèi)部總線來的數(shù)據(jù)和從地址信號線上來的地址。因此P2端口是動態(tài)的I/O端口。輸出數(shù)據(jù)雖被鎖存,但不是穩(wěn)定地出現(xiàn)在端口線上。其實,這里輸出的數(shù)據(jù)往往也是一種地址,只不過是外部RAM的高8位地址。 在輸入功能方面,P2端口與P0和H端口相同,有讀引腳和讀鎖存器之分,并且P2端口也是準雙向口。 可見,P2端口的主要特點包括: ①不能輸出靜態(tài)的數(shù)據(jù); ②自身輸出外部程序存儲器的高8位地址; ②執(zhí)行MOVX指令時,還輸出外部RAM的高位地址,故稱P2端口為動態(tài)地址端口。 P3端口: 雙功能靜態(tài)I/O口P3端口的一位結構見下圖。

8 C6 a( p8 K: J' S7 V( W由上圖可見,P3端口和Pl端口的結構相似,區(qū)別僅在于P3端口的各端口線有兩種功能選擇。當處于第一功能時,第二輸出功能線為1,此時,內(nèi)部總線信號經(jīng)鎖存器和場效應管輸入/輸出,其作用與P1端口作用相同,也是靜態(tài)準雙向I/O端口。當處于第二功能時,鎖存器輸出1,通過第二輸出功能線輸出特定的內(nèi)含信號,在輸入方面,即可以通過緩沖器讀入引腳信號,還可以通過替代輸入功能讀入片內(nèi)的特定第二功能信號。由于輸出信號鎖存并且有雙重功能,故P3端口為靜態(tài)雙功能端口。
0 T( V! V- Q0 T; ~1 CP3口的特殊功能(即第二功能):
* ?# y! r* E% }9 r& l0 [
$ Q9 I6 O5 |4 _; l3 i% }1 }9 c/ Q
& P. R6 ^: l. ]) h* ~3 t% D G3 W1 j" S. u' l, `! R; b) q
: _- s0 `3 ]3 w
口線 |
3 m0 Y: F$ ?2 O. [' i6 e- w
1 w- d$ W& P6 ?1 ~& r# A 第二功能 | 5 z m+ h: \/ q- W( e
" q! i# V* B% ^% T8 ~ 信號名稱 |
+ `% A. i6 \" p) j
, X7 r7 X2 |* y0 C* t
5 Z' V4 ?0 S8 s, s P3.0 | / A* r; o6 B) P L: \, K
RXD |
% Z+ }: `1 J0 b) _2 I- ~串行數(shù)據(jù)接收 |
) b' p0 x- A0 k5 {% v5 ^
$ A/ H3 j% P$ [8 d& i
" h ]; P* H a/ ^: f P3.1
|
0 z/ H' C: E7 U# JTXD | ' {5 t% |( @- _* u# n
串行數(shù)據(jù)發(fā)送 |
9 a Z1 Z1 K* Z) Y/ X( v& O! B# B/ a
. k/ A! c3 E! f% k P3.2
| + v+ U9 q/ a, r) L& Q
INT0 | 7 |! D5 C. x- o- I( A: v
外部中斷0申請 |
2 c' c0 t1 M- e4 i' F5 e0 @4 f
0 Z% w0 e% v9 |& B3 V, k5 ~5 \3 p- w" q
P3.3
| 7 Y2 D: v/ X+ k' V" I
INT1 | : N& @: Z! J/ \; u$ ]
外部中斷1申請 |
' r3 A! }$ N& L1 t8 n/ m/ f% o! V" z1 h. q6 o! k6 p; a
+ ^ o" E C/ | L- Q3 v P3.4
| . \- z" S* J# M& R+ T6 s+ ?
T0 | ! S" q; K' f* _) e5 O5 ?' w8 L
定時器/計數(shù)器0計數(shù)輸入 |
# V( F# _3 \; @6 v e
7 e# _4 |+ Y0 v4 \. Z
' }; H0 g* j$ Q- }7 Q- Z1 m P3.5
|
/ J+ S+ v* Z; U4 d' y2 Y1 O# Z: cT1 | - J1 B8 [) T: N1 D, @8 v) ], n
定時器/計數(shù)器1計數(shù)輸入 |
( U" @! t' x3 g. r' O; u9 B) B5 u" R5 S
- g' q1 |' P" ^0 c! d1 |" F2 P P3.6
|
" J/ z: O+ G7 Y& `3 GWR |
# g/ l; H+ H0 ` m1 T2 @6 _' K, x外部RAM寫選通 |
& U1 w9 e# L7 Y' ?: Y$ X/ J! g" B2 x: }* C
. k) o- P; ?; }0 H
P3.7
|
; V7 s; ^4 ^ R3 r8 nRD |
Y( f3 [% |; Y1 G- W外部RAM讀選通 | $ @6 q% c4 s1 I3 {1 d M8 H% e; G
使P3端品各線處于第二功能的條件是:
! X& T2 M; \ Y" q' X1\串行I/O處于運行狀態(tài)(RXD,TXD); 0 o9 g4 S% [, W" }) T3 c. S! Z1 i
2\打開了處部中斷(INT0,INT1); 0 M0 m/ |* m; W4 U! w
3\定時器/計數(shù)器處于外部計數(shù)狀態(tài)(T0,T1)
( f/ @6 N& X! u4 T1 U7 o4\執(zhí)行讀寫外部RAM的指令(RD,WR)
) ~: f& w; P5 V* X+ W2 i. d* t在應用中,如不設定P3端口各位的第二功能(WR,RD信叼的產(chǎn)生不用設置),則P3端口線自動處于第一功能狀態(tài),也就是靜態(tài)I/O端口的工作狀態(tài)。在更多的場合是根據(jù)應用的需要,把幾條端口線設置為第二功能,而另外幾條端口線處于第一功能運行狀態(tài)。在這種情況下,不宜對P3端口作字節(jié)操作,需采用位操作的形式。
" f/ s& u4 y* N8 z端口的負載能力和輸入/輸出操作: 8 g8 d& M1 }* i( w) P( E
P0端口能驅(qū)動8個LSTTL負載。如需增加負載能力,可在P0總線上增加總線驅(qū)動器。P1,P2,P3端口各能驅(qū)動4個LSTTL負載。 前已述及,由于P0-P3端口已映射成特殊功能寄存器中的P0一P3端口寄存器,所以對這些端口寄存器的讀/寫就實現(xiàn)了信息從相應端口的輸入/輸出。例如: MOV A, P1 ;把Pl端口線上的信息輸入到A MoV P1, A ;把A的內(nèi)容由P1端口輸出 MOV P3, #0FFH ;使P3端口線各位置l
& U' {% d' M+ e串行端口: MCS-51系列單片機片內(nèi)有一個串行I/O端口,通過引腳RXD(P3.0)和TXD(P3.1)可與外設電路進行全雙工的串行異步通信。
( z$ l+ t( g& {2 p+ j9 }1.串行端口的基本特點 8031單片機的串行端口有4種基本工作方式,通過編程設置,可以使其工作在任一方式,以滿足不同應用場合的需要。其中,方式0主要用于外接移位寄存器,以擴展單片機的I/O電路;方式1多用于雙機之間或與外設電路的通信;方式2,3除有方式l的功能外,還可用作多機通信,以構成分布式多微機系統(tǒng)。 串行端口有兩個控制寄存器,用來設置工作方式、發(fā)送或接收的狀態(tài)、特征位、數(shù)據(jù)傳送的波特率(每秒傳送的位數(shù))以及作為中斷標志等。 串行端口有一個數(shù)據(jù)寄存器SBUF(在特殊功能寄存器中的字節(jié)地址為99H),該寄存器為發(fā)送和接收所共同。發(fā)送時,只寫不讀;接收時,只讀不寫。在一定條件下,向陽UF寫入數(shù)據(jù)就啟動了發(fā)送過程;讀SBUf就啟動了接收過程。 串行通信的波特率可以程控設定。在不同工作方式中,由時鐘振蕩頻率的分頻值或由定時器Tl的定時溢出時間確定,使用十分方便靈活。
/ V2 X7 }7 p2 K+ h2.串行端口的工作方式 ①方式0 8位移位寄存器輸入/輸出方式。多用于外接移位寄存器以擴展I/O端口。波特率固定為fosc/12。其中,fosc為時鐘頻率。 在方式0中,串行端口作為輸出時,只要向串行緩沖器SBUF寫入一字節(jié)數(shù)據(jù)后,串行端口就把此8位數(shù)據(jù)以等的波特率,從RXD引腳逐位輸出(從低位到高位);此時,TXD輸出頻率為fosc/12的同步移位脈沖。數(shù)據(jù)發(fā)送前,僅管不使用中斷,中斷標志TI還必須清零,8位數(shù)據(jù)發(fā)送完后,TI自動置1。如要再發(fā)送,必須用軟件將TI清零。 串行端口作為輸入時,RXD為數(shù)據(jù)輸入端,TXD仍為同步信號輸出端,輸出頻率為fosc/12的同步移位脈沖,使外部數(shù)據(jù)逐位移入RxD。當接收到8位數(shù)據(jù)(一幀)后,中斷標志RI自動置。如果再接收,必須用軟件先將RI清零。 串行方式0發(fā)送和接收的時序過程見下圖。 ②方式1 2 G- ]4 Z' d. w# `* n8 Y

" b( Q( ^7 K* C4 f; A# y10位異步通信方式。其中,1個起始位(0),8個數(shù)據(jù)位(由低位到高位)和1個停止位(1)。波特率由定時器T1的溢出率和SMOD位的狀態(tài)確定。 一條寫SBUF指令就可啟動數(shù)據(jù)發(fā)送過程。在發(fā)送移位時鐘(由波特率確定)的同步下,從TxD先送出起始位,然后是8位數(shù)據(jù)位,最后是停止位。這樣的一幀10位數(shù)據(jù)發(fā)送完后,中斷標志TI置位。 在允許接收的條件下(REN=1),當RXD出現(xiàn)由1到O的負跳變時,即被當成是串行發(fā)送來的一幀數(shù)據(jù)的起始位,從而啟動一次接收過程。當8位數(shù)據(jù)接收完,并檢測到高電乎停止位后,即把接收到的8位數(shù)據(jù)裝入SBUF,置位RI,一幀數(shù)據(jù)的接收過程就完成了。 方式1的數(shù)據(jù)傳送波特率可以編程設置,使用范圍寬,其計算式為: 波特率=2SMOD/32×(定時器T1的溢出率) 其中,SMOD是控制寄存器PCON中的一位程控位,其取值有0和l兩種狀態(tài)。顯然,當SMOD=0時,波特率=1/32(定時器Tl溢出率),而當SMOD=1時,波特率=1/16(定時器T1溢出率)。所謂定時器的溢出率,就是指定時器一秒鐘內(nèi)的溢出次數(shù)。波特率的算法,以及要求一定波特率時定時器定時初值的求法,后面將詳細討論。 · 串行方式1的發(fā)送和接收過程的時序見下圖。 ③方式2,3 11位異步通信方式。其中,1個起始位(0),8個數(shù)據(jù)位(由低位到高位),1個附加的第9位和1個停止住(1)。方式2和方式3除波特率不同外,其它性能完全相同。方式2,3的發(fā)送、接收時序見下圖。 由圖可見,方式2和方式3與方式l的操作過程基本相同,主要差別在于方式2,3有第9位數(shù)據(jù)。
* X& i, \- d2 X6 H
, u! l9 V6 k, r3 p/ L& F X 發(fā)送時,發(fā)送機的這第9位數(shù)據(jù)來自該機SCON中的TB8,而接收機將接收到的這第9位數(shù)據(jù)送入本機SCON中的RB8。這個第9位數(shù)據(jù)通常用作數(shù)據(jù)的奇偶檢驗位,或在多機通信中作為地址/數(shù)據(jù)的特征位。 方式2和方式3的波特率計算式如下: 方式2的波特率=2SMOD/64×fosc 方式3的波特率=2SMOD/32×定時器T1的溢出率 由此可見,在晶振時鐘頻率一定的條件下,方式2只有兩種波特率,而方式3可通過編程設置成多種波特率,這正是這兩種方式的差別所在。 3.串行端口的控制寄存器 串行端口共有2個控制寄存器SCON和PCON,用以設置串行端口的工作方式、接收/發(fā)送的運行狀態(tài)、接收/發(fā)送數(shù)據(jù)的特征、波特率的大小,以及作為運行的中斷標志等。 + d5 b/ X- a$ n5 x- g. \9 l

+ Y$ t* H- g; Z- t; M f/ |
) o2 @& }/ A% |3 Z: T. W4 ` O
8 X8 K/ U' {2 R! v5 S |