硬件学习笔记--89 MCU主频对Uart波特率影响及采样点

一、不同倍频对URAT串口实际波特率的影响

UART通信的双方需要约定一个相同的波特率,即每秒传输的比特数。在单片机/嵌入式系统中,这个波特率通常是由一个定时器(通常是波特率发生器)对系统时钟进行分频而产生的。

1.分频误差:

在通信和时钟系统中,分频误差(Baud Rate Error,BR Error) 是指由于分频器(Divider)的设置限制,导致实际生成的波特率与目标波特率之间的偏差。这种误差在异步串行通信(如UART)或时钟同步中尤为重要,可能直接影响通信的稳定性。

  1. MCU URAT串口的实际波特率

波特率由系统时钟分频得到,分频系数必须为整数,例如

系统时钟频率为FCLK=32M,目标波特率为115200bps,4倍频采样,则分频系数应为

但实际只能取整数,因此取69,则分频波特率为

即MCU此时URAT串口实际波特率为115942bps。如果采用16倍采样则

分频系数取17

由此可见由于分频系数只能取整数导致实际波特率偏离目标值且会随着采样倍频变化而变化,可通过以下方法改善此问题

(1)部分MCU支持小数分频器,可设置非整数分频系数。

(2)选用更高频率的主时钟,减少分频系数小数部分的影响。

(3)选择低误差的波特率和倍频数组合。

不同主频的影响

二、不同倍频数在采样上的不同

URAT采样的不同倍频数的主要区别是将1bit分成不同份数,如4倍频分为4份,数据位采样点为第3份(停止位采样点为第二份);16倍频分为16份,数据位采样点为第9份(停止位采样点为第8份)。采样点处出现异常波形(如上升下降沿、异常尖刺或占空比异常)则采样会出现异常。由于波特率一定的情况下,1bit时间固定,因此份数越多则采样时间越短相对越靠近中心。以速率115200bps为例分析高电平占空比偏高对采样的影响。

115200bps下1bit时长为8.6us,假设对一低一高波形采样,设开始变低的瞬间为时间零点,理想情况下如下图:

数据位采样点在第三份,则对图中低电平、高电平采样时间分别为横轴中4.3us-6.45us、12.9us-15.05us。

当波形产生异常时,如高电平占空比变高则波形变为如下情况

此时由于低电平的采样点被高电平侵占,使得低电平采样失败。

如果将4倍频改为16倍频,而高电平占空比不变的情况下

结论:16倍频下,采样点由4倍频的4份中的第3份变为16份中的第9份,即采样时间变为图中横轴上的4.3us-4.8375us、12.9us-13.4375us,此时高电平不再侵占低电平采样点,可见对高电平占空比变高的容忍度有所提升。

相关推荐
_李小白3 小时前
【智能驾驶:视觉感知后处理 阅读笔记】Day4: 相机成像模型与畸变
笔记·数码相机
十月的皮皮4 小时前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
JAVA面经实录9174 小时前
前端系统化学习计划表(含完整知识思维导图)
前端·学习
破晓单片机4 小时前
067、STM32项目分享:语音儿童学习书桌系统
stm32·单片机·嵌入式硬件
worilb4 小时前
Spring Cloud 学习与实践(9):Gateway + JWT 统一鉴权
学习·spring cloud·gateway
欢乐熊嵌入式编程5 小时前
嵌入式 + MQTT:数据上传到阿里云实战(从0到1完整教程)
stm32·单片机·mqtt·freertos·嵌入式架构·efr32
10WTW015 小时前
微机原理 8259A 可编程中断控制器
单片机·嵌入式硬件
MartinYeung55 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
辣香牛肉面7 小时前
CintaNotes个人笔记管理软件v3.14(v3.13.0 绿色汉化版)
笔记
solicitous7 小时前
学习了解充电桩协议OCPP——J规范
学习