|
|
包含校验位时,有9位数据的情况,以下是从官方手册拷贝过来的:* N0 ~- y& V/ L, w
# Q( \) M! _8 w4 B( O, n
DR[8:0]:数据值 (Data value)2 a1 T h& P# d' z5 Q9 \% y r4 ]. k
包含了发送或接收的数据。由于它是由两个寄存器组成的,一个给发送用(TDR),一个给接收
# j' M/ c# _' ?4 M, |用(RDR),该寄存器兼具读和写的功能。 TDR寄存器提供了内部总线和输出移位寄存器之间的4 O- }* J3 Q! E R6 }. g
并行接口(参见图248)。 RDR寄存器提供了输入移位寄存器和内部总线之间的并行接口。
+ D/ q" _- [' X) ^' |当使能校验位(USART_CR1中PCE位被置位)进行发送时,写到MSB的值(根据数据的长度不% U2 r4 M5 @4 m: a3 a6 l; c# o# f a
同, MSB是第7位或者第8位)会被后来的校验位该取代。. r! N9 P) \6 {% l$ F
当使能校验位进行接收时,读到的MSB位是接收到的校验位( l* i1 t( X6 M q# M
, k; t2 [1 a6 i" M) Z
你再看一下USART_CR1的M、PCE:- \' z; {& k$ ]0 i
M:字长 (Word length)$ m3 j; ~% A- G
该位定义了数据字的长度,由软件对其设置和清零
% d- L( Y5 f8 x: G, U& z$ Z0:一个起始位, 8个数据位, n个停止位;
/ J# B$ t$ E# t9 m* N3 a& L+ ?1:一个起始位, 9个数据位, n个停止位。: n& u: a7 s9 `; o# F
注意:在数据传输过程中(发送或者接收时),不能修改这个位3 j& C; L1 d8 Y
" E! ^' I1 n1 ?3 i
PCE:检验控制使能 (Parity control enable)
% l7 ]" \! ^$ l' T用该位选择是否进行硬件校验控制(对于发送来说就是校验位的产生;对于接收来说就是校验位
" A* C+ j( |& f3 _' i的检测)。当使能了该位,在发送数据的最高位(如果M=1,最高位就是第9位;如果M=0,最高
' B/ L& @) B& {! V; x位就是第8位)插入校验位;对接收到的数据检查其校验位。软件对它置’1’或清’0’。一旦设置了& x4 e% |* A |
该位,当前字节传输完成后,校验控制才生效。+ k# ] W6 ^- L$ P5 S2 G& \
0:禁止校验控制;
2 ~- B9 q/ }6 b# e% w7 ?1:使能校验控制 |
|