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

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

3天内不再提示

UART通信简介,UART如何工作

FPGA之家 来源:FPGA之家 作者:FPGA之家 2022-09-09 09:56 次阅读

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

2e3698c6-2fd7-11ed-ba43-dac502259ad0.png

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

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

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

2e85ff10-2fd7-11ed-ba43-dac502259ad0.png

UART如何工作

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

2ebf6048-2fd7-11ed-ba43-dac502259ad0.png

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

2efaa856-2fd7-11ed-ba43-dac502259ad0.png

1

开始位

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

2

数据框

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

3

奇偶校验位

奇偶校验描述数字的均匀性或奇数。奇偶校验位是接收UART在传输过程中判断是否有任何数据发生变化的一种方法。电磁辐射、不匹配的波特率或长距离传输时,数据都有可能发生变化。接收UART读取数据帧后,它会计算值为1的位数,并检查总数是偶数还是奇数。

如果奇偶校验位为0(偶校验),则数据帧中的1位应总计为偶数。如果奇偶校验位是1(奇校验),则数据帧中的1位应总计为奇数。当奇偶校验位与数据匹配时,UART知道传输没有错误。但如果奇偶校验位为0,然而1位应总计为奇数;或者奇偶校验位是1,并且1位应总计是偶数,则数据帧中的位已经改变。

4

停止位

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

UART传输步骤

1)发送UART从数据总线并行接收数据↓↓

2f10b47a-2fd7-11ed-ba43-dac502259ad0.png

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

2f5b9fc6-2fd7-11ed-ba43-dac502259ad0.png

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

2f7a386e-2fd7-11ed-ba43-dac502259ad0.png

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

2fd4f31c-2fd7-11ed-ba43-dac502259ad0.png

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

2ff36270-2fd7-11ed-ba43-dac502259ad0.png

UART的优缺点

优点:只使用两根电线;不需要时钟信号;有一个奇偶校验位;只要双方设置后,就可以改变数据包的结构;有完整的文档并且具有广泛的使用。

缺点:数据帧的大小限制为最多9位;不支持多个从属或多个主系统;每个UART的波特率必须在10%之内。

审核编辑 :李倩

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

    关注

    96

    文章

    12665

    浏览量

    133154
  • 调制解调器
    +关注

    关注

    3

    文章

    822

    浏览量

    38393
  • 串口通信
    +关注

    关注

    32

    文章

    1578

    浏览量

    54876

原文标题:还没搞懂串口通信?一文带你读懂

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    UART串口通信实验及工作原理

    UART通信过程需要设置波特率、数据长度、开始/停止位等参数。波特率决定了发送数据的速度,而数据长度和开始/停止位则用于确保数据的正确传输和接收。
    的头像 发表于 03-21 17:10 1470次阅读
    <b class='flag-5'>UART</b>串口<b class='flag-5'>通信</b>实验及<b class='flag-5'>工作</b>原理

    UART串口通信协议是什么?

    UART (Universal Asynchronous Receiver/Transmitter) 是一种通信接口协议,用于实现串口通信。它是一种简单的、可靠的、广泛应用的串口通信
    的头像 发表于 03-19 17:26 301次阅读

    浅谈UART通信的异步通信机制

    波特率表示每秒钟传送的码元符号的个数,它是对符号传输速率的一种度量。在UART通信中,波特率用于描述通信速度,其单位是bps(每秒钟传输的bit的数量)。
    发表于 02-19 16:19 230次阅读
    浅谈<b class='flag-5'>UART</b><b class='flag-5'>通信</b>的异步<b class='flag-5'>通信</b>机制

    uart与usart区别 usart可以当uart用吗

    USART实际上包含了UART的功能,并增加了支持同步通信的能力。在大多数微控制器中,UART通常是USART功能的一部分,USART可以配置为UART模式进行异步
    发表于 01-17 15:46 4886次阅读
    <b class='flag-5'>uart</b>与usart区别 usart可以当<b class='flag-5'>uart</b>用吗

    UART、SPI、I2C比较 串口通信介绍

    UART、SPI、I2C比较 I2C线更少,比UART、SPI更为强大,但是技术上也更加麻烦些,因为I2C需要有双向IO的支持,而且使用上拉电阻,抗干扰能力较弱,一般用于同一板卡上芯片之间的通信
    的头像 发表于 11-09 18:06 755次阅读
    <b class='flag-5'>UART</b>、SPI、I2C比较 串口<b class='flag-5'>通信</b>介绍

    Stm32 HAL库开发-UART串口通信轮询方式

    UART的结构体有两个,如图,UART_InitTypeDef是初始化结构体,包含UART开始运行时的配置;UART_HandleTypeDef是句柄结构体,包含
    的头像 发表于 10-26 16:22 603次阅读
    Stm32 HAL库开发-<b class='flag-5'>UART</b>串口<b class='flag-5'>通信</b>轮询方式

    uart通信的详细讲解

    UART通信的基本原理、工作模式、波特率计算以及常见使用方式,帮助有一定单片机开发能力的人群更好地理解和应用UART通信。01
    的头像 发表于 09-22 08:22 1729次阅读
    <b class='flag-5'>uart</b><b class='flag-5'>通信</b>的详细讲解

    UART通信原理详解

    UART(Universal Asynchronous Receiver Transmitter)通用异步收发器,是一种通用串行、异步通信总线,该总线有两条数据线和一条地线,支持全双工异步通信。常用于单片机与单片机或外围辅助设备
    发表于 09-21 17:28 678次阅读
    <b class='flag-5'>UART</b><b class='flag-5'>通信</b>原理详解

    基于STM32的模拟UART串口通信工作原理

    UART即通用异步收发器,是一种串行通信方式。数据在传输过程中是通过一位一位地进行传输来实现通信的,串行通信方式具有传输线少,成本底等优点,缺点是速度慢。
    发表于 08-03 10:07 403次阅读
    基于STM32的模拟<b class='flag-5'>UART</b>串口<b class='flag-5'>通信</b><b class='flag-5'>工作</b>原理

    单片机常用通信协议之UART通信简介

    UART即通用异步收发器(UniversalAsynchronousReceiver/Transmitter),和IIC一样,其总线构成只有两根线,即TX和RX,但其可以同步收发,故UART为异步
    发表于 07-31 17:10 1371次阅读
    单片机常用<b class='flag-5'>通信</b>协议之<b class='flag-5'>UART</b><b class='flag-5'>通信简介</b>

    UART通信原理详解

    通用异步收发传输器,通常称作UART,是一种异步收发传输器。是异步通信协议。特性:两根线,全双工,异步通信,速度较慢。
    发表于 06-28 15:26 1356次阅读
    <b class='flag-5'>UART</b><b class='flag-5'>通信</b>原理详解

    基于STM32模拟UART串口通信

    UART即通用异步收发器,是一种串行通信方式。数据在传输过程中是通过一位一位地进行传输来实现通信的,串行通信方式具有传输线少,成本底等优点,缺点是速度慢。串行
    的头像 发表于 06-25 17:13 1270次阅读
    基于STM32模拟<b class='flag-5'>UART</b>串口<b class='flag-5'>通信</b>

    UART通用异步收发传输器简述

    UART——通用异步收发传输器,UART 作为异步串口通信协议的一种,工作原理是将传输数据的每个字符一位接一位地传输。在应用程序开发过程中使用频率较高的数据总线。
    的头像 发表于 06-25 14:48 621次阅读
    <b class='flag-5'>UART</b>通用异步收发传输器简述

    如何保护物联网设备中的UART通信

    许多协议在标准内实现安全性,并且是任何控制器的内置部分。但是,通过通用异步收发器 (UART) 连接的嵌入式设备不受保护。UART 是设备之间简单的数字通信接口之一。这是一种无 ACK 通信
    发表于 06-24 17:36 505次阅读
    如何保护物联网设备中的<b class='flag-5'>UART</b><b class='flag-5'>通信</b>

    UART接收的工作过程

    UART 全称为 Universal Asynchronous Receiver/Transmitter,译为通用异步收发传输器。它是一种通用串行数据总线,将数据在串行通信与并行通信之间进行转换,用于异步
    发表于 05-29 16:20 1003次阅读
    <b class='flag-5'>UART</b>接收的<b class='flag-5'>工作</b>过程