0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

UART是什么,其背后的原理你搞懂了吗

电子设计 来源:电子设计 作者:电子设计 2020-10-31 04:08 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

还记得当年的打印机,鼠标和调制解调器吗?他们都有巨大笨重的连接器和粗电缆,并且必须拧到你的电脑上。这些设备正是使用 UART 协议与计算机进行通信。虽然 USB 几乎完全取代了旧的电缆和连接器,但 UART 绝对没有过时。您会发现目前许多项目中使用 UART 的 GPS 模块、蓝牙模块和 RFID 读卡器模块等连接到 Raspberry PiArduino 或其他微控制器上。

通用异步收发传输器(Universal Asynchronous Receiver/Transmitter),通常称作 UART。它将要传输的资料在串行通信与并行通信之间加以转换。作为把并行输入信号转成串行输出信号的芯片,UART 通常被集成于其他通讯接口的连结上。

它不是像 SPI 和 I2C 这样的通信协议,而是微控制器中独立的物理电路或独立的 IC。

UART 最好的一点是它只使用两根线就可以在设备之间传输数据,UART 背后的原理很容易理解。

UART 通信简介

在 UART 通信中,两个 UART 直接相互通信。发送 UART 将来自 CPU 等控制设备的并行数据转换为串行形式,并将其串行发送到接收 UART,接收 UART 然后将串行数据转换回接收设备的并行数据。在两个 UART 之间传输数据只需要两根线。数据从发送 UART 的 Tx 引脚流向接收 UART 的 Rx 引脚:

UART 以异步方式发送数据,这意味着没有时钟信号将发送 UART 的位输出与接收 UART 的位采样同步。发送 UART 不是时钟信号,而是将开始和停止位添加到正在传输的数据包中。这些位定义数据包的开始和结束,因此接收 UART 知道何时开始读取位。

当接收 UART 检测到起始位时,它开始以称为波特率的特定频率读取输入位。波特率是数据传输速度的度量,以每秒位数(bps)表示。两个 UART 必须以大致相同的波特率运行。发送和接收 UART 之间的波特率只能相差 10%左右。

两个 UART 还必须配置为发送和接收相同的数据包结构。


UART 如何工作
UART 传输数据依靠的是 UART 总线,数据总线用于通过 CPU,存储器或微控制器等其他设备将数据发送到 UART。数据以并行形式从数据总线传输到发送 UART。在发送 UART 从数据总线获得并行数据之后,它将添加起始位,奇偶校验位和停止位,从而创建数据包。接下来,数据包在 Tx 引脚上逐位串行输出。UART 接收端则在其 Rx 引脚上逐位读取数据包。然后,接收 UART 将数据转换回并行形式,并删除起始位,奇偶校验位和停止位。最后,接收 UART 将数据包并行传输到接收端的数据总线:



UART 传输的数据被组织成数据包。每个数据包包含 1 个起始位,5 到 9 个数据位(取决于 UART),可选的奇偶校验位以及 1 或 2 个停止位:


开始位
当 UART 数据传输线不传输数据时,它通常保持在高电压电平。为了开始数据传输,发送 UART 将传输线从高电平拉至低电平一个时钟周期。当接收 UART 检测到高电压到低电压转换时,它开始以波特率的频率读取数据帧中的位。

数据框
数据框包含要传输的实际数据。如果使用奇偶校验位,则它可以是 5 位到 8 位长。如果不使用奇偶校验位,则数据帧可以是 9 位长。在大多数情况下,数据首先以最低有效位发送。

奇偶校验位
奇偶校验描述数字的均匀性或奇数。奇偶校验位是接收 UART 在传输过程中判断是否有任何数据发生变化的一种方法。电磁辐射、不匹配的波特率或长距离传输时,数据都有可能发生变化。接收 UART 读取数据帧后,它会计算值为 1 的位数,并检查总数是偶数还是奇数。如果奇偶校验位为 0(偶校验),则数据帧中的 1 位应总计为偶数。如果奇偶校验位是 1(奇校验),则数据帧中的 1 位应总计为奇数。当奇偶校验位与数据匹配时,UART 知道传输没有错误。但如果奇偶校验位为 0,然而 1 位应总计为奇数;或者奇偶校验位是 1,并且 1 位应总计是偶数,则数据帧中的位已经改变。

停止位
为了通知传输数据包的结束,UART 发送端会将数据传输线从低电压驱动至高电压至少两位持续时间。

UART 传输步骤

1. 发送 UART 从数据总线并行接收数据:


2. 发送 UART 将起始位,奇偶校验位和停止位添加到数据帧:

3. 整个数据包从发送 UART 串行发送到接收 UART。接收 UART 以预先配置的波特率对数据线进行采样:


4. 接收 UART 丢弃数据帧中的起始位,奇偶校验位和停止位:



5. 接收 UART 将串行数据转换回并行并将其传输到接收端的数据总线:


UART 的优点和缺点

没有任何一种通信协议是完美的,以下是一些优点和缺点,可帮助您确定它们是否符合您项目的需求:

优点
只使用两根电线


不需要时钟信号


有一个奇偶校验位


只要双方设置后,就可以改变数据包的结构


有完整的文档并且具有广泛的使用

缺点
数据帧的大小限制为最多 9 位


不支持多个从属或多个主系统


每个 UART 的波特率必须在 10%之内

审核编辑:符乾江


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 电路
    +关注

    关注

    173

    文章

    6063

    浏览量

    177474
  • uart
    +关注

    关注

    22

    文章

    1304

    浏览量

    106107
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    UART的缺点介绍

    传输的数据,需要额外的机制(例如基于软件的寻址)来区分和处理预期数据。 速度有限: UART 的速度受到设计和实现的限制。虽然这种限制对于慢速通信系统来说不是问题,但对于高速应用来说可能是一个重大
    发表于 11-27 06:36

    UART 串口通信还能玩出什么花样?

    还记得打印机、鼠标和调制解调器曾经使用粗线和笨重连接器吗?那些必须拧进电脑里的连接器?这些设备很可能使用UART与电脑通信。虽然USB几乎完全取代了那些老式的线缆和连接器,但UART绝非过时之物。你
    的头像 发表于 11-24 19:05 167次阅读
    <b class='flag-5'>UART</b> 串口通信还能玩出什么花样?

    UART无法收发/乱码的排查

    ?共地了吗? 3、引脚复用: 确认使用的 UART 引脚配置正确,且复用功能已开启。 4、中断/DMA: 如果使用中断或 DMA,相关配置和使能是否正确? 5、电平转换: 如果需要连接 PC 或其他
    发表于 11-18 07:05

    多路UART数据转发芯片 支持1主4从UART接口 UART扩展芯片

    UART接口
    稳控自动化
    发布于 :2025年11月13日 13:27:11

    多路UART数据转发芯片 支持1主4从UART接口 UART扩展芯片

    多路UART数据转发芯片 支持1主4从UART接口 UART扩展芯片 EU104 是一款高性能 UART 数据转发芯片,采用 SOP16 紧凑封装,工作电压范围为 2.0V 至 5.5
    的头像 发表于 11-12 10:33 148次阅读

    像这种受电端/负载端的电压诱骗芯片和电源端//负载端的协议芯片有什么区别,没搞懂

    像这种受电端/负载端的电压诱骗芯片和电源端//负载端的协议芯片有什么区别,没搞懂*附件:CH224K.pdf
    发表于 09-28 11:52

    UART 扩展芯片 数据转发多串口扩展 1主4从,高效通信

    uart
    稳控自动化
    发布于 :2025年08月11日 14:20:36

    所以你做出来了吗

    所以你做出来了吗,求
    发表于 06-16 01:43

    芯知识|广州唯创电子语音芯片UART通信协议解析:发码长度与校验码计算

    一、UART通信协议概述UART(通用异步收发器)是一种广泛应用于嵌入式系统的串行通信协议,核心特点为无需时钟同步,通过起始位、数据位、校验位和停止位构成数据帧。在语音芯片应用中,UART
    的头像 发表于 05-27 08:48 525次阅读
    芯知识|广州唯创电子语音芯片<b class='flag-5'>UART</b>通信协议解析:发码长度与校验码计算

    升压电路一文搞懂 升压电路技术文档合集

    升压电路图集合,升压电路设计方案,电路设计技巧,升压电路一文搞懂;给大家分享 升压电路技术文档合集
    的头像 发表于 05-15 15:58 1.7w次阅读
    升压电路一文<b class='flag-5'>搞懂</b> 升压电路技术文档合集

    基于小凌派RK2206开发板:OpenHarmony如何使用IoT接口控制UART外设

    1、实验简介本实验将演示如何在小凌派-RK2206开发板上使用IOT库的UART接口,进行UART编程开发。例程将创建一个任务,通过配置UART引脚,实现UART读写操作。例程源代码:
    的头像 发表于 04-22 14:22 794次阅读
    基于小凌派RK2206开发板:OpenHarmony如何使用IoT接口控制<b class='flag-5'>UART</b>外设

    开源直接用!UDP-UART数据透传来了

    今天就来分享一下UDP-UART透传示例,源码开放,可根据实际需求灵活应用。 一、UDP-UART透传简介 UDP-UART透传是一种将UDP数据流直接传输到UART接口的通信方式。它
    的头像 发表于 02-05 17:14 563次阅读
    开源直接用!UDP-<b class='flag-5'>UART</b>数据透传来了

    UC-006:4线UART至PC接口

    电子发烧友网站提供《UC-006:4线UART至PC接口.pdf》资料免费下载
    发表于 01-14 16:30 0次下载
    UC-006:4线<b class='flag-5'>UART</b>至PC接口

    传感光缆原理你清楚吗

    传感光缆特别是光纤传感光缆,原理主要基于光的传输和调制特性。以下是对传感光缆原理的详细解释: 一、基本原理 传感光缆利用光的全反射原理在光纤内部传输信号。光纤是一种非常细的玻璃或塑料材料,具有较高
    的头像 发表于 01-07 11:12 1133次阅读

    屏蔽网线原理你了解吗

    屏蔽网线的原理主要基于独特的结构和材料设计,以下是关于屏蔽网线原理的详细解释: 一、结构特点 屏蔽网线在绝缘层内部增加了一层或多层金属屏蔽层,这些金属屏蔽层通常由铝箔或金属编织网构成。这种设计使得
    的头像 发表于 01-02 11:02 1596次阅读