|
|
包含校验位时,有9位数据的情况,以下是从官方手册拷贝过来的:
1 V9 o' L6 M" F+ z' Z9 i& v( l, f% D% {/ W' p2 Y
DR[8:0]:数据值 (Data value)
5 i7 r2 g9 P1 l( h4 Y( P$ f包含了发送或接收的数据。由于它是由两个寄存器组成的,一个给发送用(TDR),一个给接收$ \4 d6 k4 b" V* D6 F; t K6 W
用(RDR),该寄存器兼具读和写的功能。 TDR寄存器提供了内部总线和输出移位寄存器之间的- z I$ v& R8 ~ q- J8 T! n) G, K- ~
并行接口(参见图248)。 RDR寄存器提供了输入移位寄存器和内部总线之间的并行接口。$ e+ d& {2 o1 A3 I' J3 K
当使能校验位(USART_CR1中PCE位被置位)进行发送时,写到MSB的值(根据数据的长度不, ~) S/ E8 y5 {8 d, ?- o
同, MSB是第7位或者第8位)会被后来的校验位该取代。
& g y# y+ ^7 p i D* O/ I当使能校验位进行接收时,读到的MSB位是接收到的校验位9 `: x9 ^/ U1 w- C& p
, ~- B t: p8 \
你再看一下USART_CR1的M、PCE:( n( n$ a4 O1 ?. k( {% X
M:字长 (Word length)
+ T& a7 I; m1 V' L9 U该位定义了数据字的长度,由软件对其设置和清零
4 P& ~/ m2 i# t8 y8 j% f: C6 f0:一个起始位, 8个数据位, n个停止位;
$ k# P2 g2 i" q2 k' x( r/ ?9 R& ?1:一个起始位, 9个数据位, n个停止位。& B- G. n1 b$ M+ m8 d( ]
注意:在数据传输过程中(发送或者接收时),不能修改这个位
; P7 J" W& {( y
& i. `) F4 c4 E( F; MPCE:检验控制使能 (Parity control enable)% H9 D& E" D) e
用该位选择是否进行硬件校验控制(对于发送来说就是校验位的产生;对于接收来说就是校验位' s9 G5 `- R, Q+ [/ s% |5 V
的检测)。当使能了该位,在发送数据的最高位(如果M=1,最高位就是第9位;如果M=0,最高
. D; A- k7 B- K/ S位就是第8位)插入校验位;对接收到的数据检查其校验位。软件对它置’1’或清’0’。一旦设置了
( t `4 \$ k8 H H该位,当前字节传输完成后,校验控制才生效。
4 M4 b. E* H h' f1 k: z. {5 B4 X0:禁止校验控制;% j# g1 l2 E9 @- @& m' l
1:使能校验控制 |
|