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

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

3天内不再提示

干货满满:带你看透UART总线的工作原理

454398 来源:alpha007 作者:alpha007 2022-12-08 16:42 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

还记得当年的打印机,鼠标和调制解调器吗?他们都有巨大笨重的连接器和粗电缆,并且必须拧到你的电脑上。这些设备正是使用 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%之内

审核编辑黄昊宇

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

    关注

    10

    文章

    3014

    浏览量

    91307
  • uart
    +关注

    关注

    22

    文章

    1304

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    无线充电器的工作原理核心

    无线充电器的工作原理核心
    的头像 发表于 12-06 10:19 26次阅读
    无线充电器的<b class='flag-5'>工作原理</b>核心

    利用开源uart2axi4实现串口访问axi总线

    microblaze和jtag-to-axi(jtag2axi)虽然也提供了访问axi总线的能力,但是依赖于xilinx平台。而uart-to-axi(uart2axi4)桥接器并不依赖任何平台
    的头像 发表于 12-02 10:05 1580次阅读
    利用开源<b class='flag-5'>uart</b>2axi4实现串口访问axi<b class='flag-5'>总线</b>

    圆满收官 | 虹科CAN总线专题全系列直播精华回顾已上线!

    个月的「CAN总线专题系列」技术直播。该系列直播共有8期干货满满的课程,涵盖基础协议解析、产品实操演示、实战案例分享、测试工具介绍、1V1互动答疑等多种形式的精彩内
    的头像 发表于 11-24 17:55 2534次阅读
    圆满收官 | 虹科CAN<b class='flag-5'>总线</b>专题全系列直播精华回顾已上线!

    RS485总线舵机工作原理

    ,解决了传统 PWM 舵机 “一对一控制、布线复杂、通信距离短” 的痛点,广泛用于机器人、自动化设备、智能家居等场景。 要理解其工作原理,需从硬件结构和工作流程两个核心维度拆解,同时明确 RS485 协议在其中的关键作用: 一、核心硬件结构:4 大模块协同
    的头像 发表于 09-23 11:11 465次阅读

    干货分享 | 功能安全常见疑难问题汇总

    针对实操问题的线上答疑活动,我们分类整理了一些热门问题及解答,可作为大家日后实践中的参考。干货满满,仔细阅读哦~关于功能安全机制及其诊断覆盖率问题Q外狗从功能上
    的头像 发表于 09-05 16:21 1990次阅读
    <b class='flag-5'>干货</b>分享 | 功能安全常见疑难问题汇总

    uart接收功能不工作是怎么回事?

    我正在 TL989x 系列开发板上工作,示例代码在 UART 发送和接收功能中起作用,发送功能可以工作但接收功能不工作,因此请给我 UART
    发表于 07-18 08:13

    干货】BOOST电路设计与工作原理讲解

    一基本工作原理当开关SW1闭合时,电流从电源VIN流出,路径为:VIN→L1→SW1→GND。此时电感储存磁能(电流逐渐增大),而电容C2向负载供电(维持VOUT电压)。当SW1关断时,电感中的电流
    的头像 发表于 06-12 19:33 2195次阅读
    【<b class='flag-5'>干货</b>】BOOST电路设计与<b class='flag-5'>工作原理</b>讲解

    GPIO配置的工作原理是什么?

    我使用 EZ-USB 配置实用程序,我想知道是否有人知道 GPIO 配置的工作原理。 例如,GPIO0 可以用作传感器复位,我知道这个 GPIO0 用于重置传感器,但我不明白的是选项用户 GPIO 例如GPIO 1可以是User GPIO0,这是什么意思呢?
    发表于 05-19 06:56

    微动开关的工作原理

    微动开关的工作原理
    的头像 发表于 04-17 09:00 2726次阅读

    光学传感器的工作原理与应用

    的疾病诊断,光学传感器的应用遍布生活的每一个角落。本文将带你深入了解光学传感器的工作原理、分类、应用及其未来的发展趋势。 光学传感器的工作原理 光学传感器的工作原理基于光学效应,即当光
    的头像 发表于 04-15 18:24 1322次阅读

    干货】BCUK电路讲解,工作原理+图文结合,通俗易懂,带你搞定

    时间 三部分详细介绍Buck电路的工作原理。让我们打起精神,擦亮眼睛,深刻体会简洁而不简单的Buck电路吧! 1、开关整流器基本原理Part 1 开关整流器基本原理导通时间关断时间 在[0,Ton
    发表于 03-11 10:44

    CAN总线的电路保护器件,通过二极管阵列的工作原理实现了对CAN总线的高效保护

    CAN总线的电路保护器件,通过二极管阵列的工作原理实现了对CAN总线的高效保护。它具有高速响应、低电流泄露、低电压降和高温工作的特点,适用于汽车和工业控制系统中的CAN
    的头像 发表于 03-03 13:26 879次阅读
    CAN<b class='flag-5'>总线</b>的电路保护器件,通过二极管阵列的<b class='flag-5'>工作原理</b>实现了对CAN<b class='flag-5'>总线</b>的高效保护

    移动电源的工作原理_移动电源结构

    移动电源的工作原理是将电能存储在内置电池中,然后通过适当的电压和电流输出,为电子设备提供所需的电能。以下是关于移动电源工作原理的详细解释:
    的头像 发表于 01-27 16:11 3287次阅读

    超级电容电池的工作原理

    超级电容电池是一种介于传统电容器与电池之间的新型储能装置。其工作原理主要基于电荷分离和电场存储,以下是关于超级电容电池工作原理的详细解释:
    的头像 发表于 01-27 11:17 1995次阅读

    CAN总线工作原理分析 CAN总线在汽车工业中的应用

    CAN总线工作原理分析 1. 概述 CAN总线是一种串行通信协议,由Bosch公司在1986年开发,主要用于汽车电子系统中。它允许多个设备共享同一通信线路,实现数据的高效传输。 2. 基本组
    的头像 发表于 12-20 17:33 4488次阅读