硬汉嵌入式论坛

 找回密码
 立即注册
查看: 1174|回复: 0
收起左侧

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

[复制链接]

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
106994
QQ
发表于 2021-11-30 13:08:07 | 显示全部楼层 |阅读模式
这里以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。



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



回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-5-13 11:41 , Processed in 0.154413 second(s), 25 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表