|
包含校验位时,有9位数据的情况,以下是从官方手册拷贝过来的:
) ? @' N* d, |
5 c$ i# ]; o4 h) y7 HDR[8:0]:数据值 (Data value)
- u8 n0 D$ p" s4 l* i4 S q包含了发送或接收的数据。由于它是由两个寄存器组成的,一个给发送用(TDR),一个给接收0 P3 l. S8 K; m; V* r
用(RDR),该寄存器兼具读和写的功能。 TDR寄存器提供了内部总线和输出移位寄存器之间的% y0 _# Y# u& o+ r( q4 Y
并行接口(参见图248)。 RDR寄存器提供了输入移位寄存器和内部总线之间的并行接口。5 F4 X2 q' Q) n% R# o
当使能校验位(USART_CR1中PCE位被置位)进行发送时,写到MSB的值(根据数据的长度不
6 r2 `! R3 x0 ]8 |* @: t% Z# z- N同, MSB是第7位或者第8位)会被后来的校验位该取代。# x) Z+ V8 |4 Q2 _0 a; X
当使能校验位进行接收时,读到的MSB位是接收到的校验位
! {, J; _( M T7 ]0 z5 c# Y
# K. L& q- s: i& v5 f# h& [9 A2 N- z你再看一下USART_CR1的M、PCE:
. t+ c/ b$ q c/ P0 ^) ]9 p4 r* iM:字长 (Word length)
+ O4 n& }# u, ?" M W( ?) R该位定义了数据字的长度,由软件对其设置和清零
4 i% w: L% Q1 r# {0:一个起始位, 8个数据位, n个停止位;
& ~$ ^ E# a0 s: E! j# q) Y' `1:一个起始位, 9个数据位, n个停止位。
e$ Y1 Z0 C. }& _1 C注意:在数据传输过程中(发送或者接收时),不能修改这个位
9 J3 e9 V; w9 Y. d
+ W. m' _7 q6 }0 ]PCE:检验控制使能 (Parity control enable)
" w3 v) K' A6 Q$ G4 ] ^5 |用该位选择是否进行硬件校验控制(对于发送来说就是校验位的产生;对于接收来说就是校验位- N3 d! x2 r" z$ q3 {5 i# J
的检测)。当使能了该位,在发送数据的最高位(如果M=1,最高位就是第9位;如果M=0,最高
4 ]- m- R) ~- r/ X2 F; h1 }7 p, I位就是第8位)插入校验位;对接收到的数据检查其校验位。软件对它置’1’或清’0’。一旦设置了
4 ?9 J" k# p2 ^* Y* x该位,当前字节传输完成后,校验控制才生效。
8 Y$ j- K# v2 s" \% d+ I$ ~0:禁止校验控制;
1 C7 Z2 ^/ t8 M& O/ t6 v9 c1:使能校验控制 |
|