【小知识】使用串口8bit,7bit和6bit数据格式的奇偶校验问题

这里以STM32H7为例进行说明,先看支持的校验格式:

 

 

主要是三种,6bit数据 + 1bit校验,7bit数据+1bit校验,8bit数据+1bit校验:

 

 

而发送寄存器和接收寄存器都是9bit格式的:

 

 

那么重点来了,校验位是串口外设硬件完成的,对应的数值也在发送/接收寄存器上。操作8bit数据+1bit格式的时候感觉不出来,因为我们一般都是仅读取寄存器的8bit。

操作6bit数据 + 1bit校验,7bit数据+1bit校验就有问题了,会把校验位数值也读出来。

简单的测试
7bit数据+1bit校验的串口回环(RX和TX短接)奇校验效果:

发送hex数值11 ,22, 33, 44后,反馈的数据把校验位也给读出来了91, A2,B2,C4,即bit7都是1。

 

 

软件屏蔽校验位后,正常效果:

 

 

posted @ 2021-12-01 16:09  硬汉嵌入式  阅读(290)  评论(0编辑  收藏  举报