目录

UART 通信简介

UART工作原理

起始位

数据帧

奇偶校验位

停止位

UART 传输的步骤

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 配置为传输和接收相同的数据包结构。

需要的线数

2

最大速率

最大可达10Mb/s

同步或异步

异步

串行或并行

串行

主机的最大个数

1

从机的最大个数

1

UART工作原理

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

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

起始位

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

数据帧

数据框包含正在传输的实际数据。如果使用奇偶校验位,则长度可以是 5 位到 8 位。如果未使用奇偶校验位,则数据帧的长度可以为 5 位到 9 位。在大多数情况下,数据从数据帧中的最低位开始发送。

奇偶校验位

奇偶校验位的目的是检查数据帧在发送到接收有没有发生数据错误,奇偶校验描述数字的偶数或奇数。奇偶校验位是接收UART的一种方式,用于判断在传输过程中是否有数据发生了变化。接收的UART读取数据帧后,它会计算值为1的位数,并检查总数是偶数还是奇数。如果奇偶校验位为 0(偶数奇偶校验),则数据帧中的 1 位应加起来为偶数。如果奇偶校验位为 1(奇数奇偶校验),则数据帧中的 1 位应加起来为奇数。当奇偶校验位与数据匹配时,UART 知道传输没有错误。但是,如果奇偶校验位为 0,并且总数为奇数;或者奇偶校验位是1,而总数是偶数,UART知道数据帧中的位已经改变。

停止位

为了发出数据包结束的信号,发送UART将数据传输线从低电平转换到高电平至少要持续两个位的时间。

UART 传输的步骤

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

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

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

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

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

UART的优缺点

没有一个通信协议是完美的,但UART非常擅长它所做的事情。以下是一些优缺点:

优点

  • 仅使用两根线
  • 无需时钟信号
  • 具有奇偶校验位以便检查数据是否有误
  • 数据包的结构可以更改,只需在两端添加必要的位

缺点

  • 数据帧的大小限制为最大9位
  • 不支持多个主机或者从机
  • 每个UART的波特率必须在彼此的10%以内

【总线】一文看懂 UART 通信协议相关推荐

  1. 一文搞懂UART通信协议

    目录 1.UART简介 2.UART特性 3.UART协议帧 3.1.起始位 3.2.数据位 3.3.奇偶校验位 3.4.停止位 4.UART通信步骤 1.UART简介 UART(Universal ...

  2. AMBA总线协议(一)——一文看懂APB总线协议

    0.AMBA总线概括 AMBA AHB 总线协议介绍请点击以下链接: AMBA总线协议(二)一文看懂AMBA2 AHB2与AMBA3 AHB-Lite总线协议的区别 AMBA总线协议(三)--一文看懂 ...

  3. AMBA总线协议(三)——一文看懂AHB总线所有协议总结(AHB2 AHB-Lite AHB5 )

    AMBA AHB 总线协议介绍请点击以下链接: AMBA总线协议(一)--一文看懂APB总线协议 AMBA总线协议(二)一文看懂AMBA2 AHB2与AMBA3 AHB-Lite总线协议的区别 AMB ...

  4. 怎么看电脑系统是win几_一文看懂arm架构和x86架构有什么区别

    一文看懂arm架构和x86架构有什么区别 本文主要介绍的是arm架构和x86架构的区别,首先介绍了ARM架构图,其次介绍了x86架构图,最后从性能.扩展能力.操作系统的兼容性.软件开发的方便性及可使用 ...

  5. 《SOC芯片研究框架》深度科普,发展趋势、技术特点、产业链一文看懂

    片上系统SoC(System on Chip),即在一块芯片上集成一整个信息处理系统,简单来说 SoC芯片是在中央处理器CPU的基础上扩展音视频功能和专用接口的超大规模集成电路,是智能设备的" ...

  6. [转帖] 一文看懂:边缘计算究竟是什么?为何潜力无限?

    一文看懂:"边缘计算"究竟是什么?为何潜力无限? 转载cnbeta 云计算 雾计算 边缘计算... 知名创投调研机构CB Insights撰文详述了边缘计算的发展和应用前景.文章称 ...

  7. 【燃】是时候展现真正的实力了!一文看懂2022华为开发者大赛技术亮点

    摘要:2022华为开发者大赛备赛攻略,超详细的开发技术要点介绍来了. 本文分享自华为云社区<[燃]是时候展现真正的实力了!一文看懂2022华为开发者大赛技术亮点>,作者:华为云社区精选 . ...

  8. 一文看懂 AI 训练集、验证集、测试集(附:分割方法+交叉验证)

    2019-12-20 20:01:00 数据在人工智能技术里是非常重要的!本篇文章将详细给大家介绍3种数据集:训练集.验证集.测试集. 同时还会介绍如何更合理的讲数据划分为3种数据集.最后给大家介绍一 ...

  9. 一文看懂计算机视觉-CV(基本原理+2大挑战+8大任务+4个应用)

    2020-03-06 20:00:00 计算机视觉(Computer Vision)是人工智能领域的一个重要分支.它的目的是:看懂图片里的内容. 本文将介绍计算机视觉的基本概念.实现原理.8 个任务和 ...

最新文章

  1. 信息理论基础 周炯槃 常迥
  2. aac蓝牙编解码协议_蓝牙音频编码哪个音质好?今天我们来逐一解读
  3. revit导出lumion插件_建筑工程BIM建模入门级教程——REVIT的几种渲染方式
  4. Draw Call未被批处理?在Unity 5.6中如何查找原因
  5. python微控制器编程从零开始-Python微控制器编程从零开始 使用MicroPython
  6. I Hate It(线段树)
  7. PE文件格式和ELF文件格式(上)----PE文件
  8. 《移动App测试的22条军规》—App测试综合案例分析23.13节测试微信App的流量和电量消耗...
  9. xp系统上安装linux系统教程,XP系统如何安装fedora linux双系统?WinXP安装fedora linux双系统的方法...
  10. 通过 User-Agent 请求头判断设备类型
  11. 基于android对接百度地图搜索附近关键字列表展示并调用第三方地图应用打开导航(百度地图、高德地图)
  12. FJUT Home_W的gcd(乱搞)题解
  13. 基于51单片机的简易计算器
  14. 互联网创新创业大赛优秀范例_互联网创业大赛优秀作品_ 创新创业大赛优秀作品...
  15. 自学计算机键盘基础知识,刘坚强办公学《新手学五笔打字》1-2 功能键区,电脑键盘功能基础知识按键详解...
  16. 【3】WEB安全学习----HTTP协议
  17. Flutter中PlatformView组件无法刷新的问题
  18. pyboard呼吸灯代码分享
  19. Raphael 原理及实践
  20. Android关于分辨率的支持(QVGA,HVGA,WVGA,WXGA)

热门文章

  1. 网络综合测试仪 都具备什么功能
  2. 网络测试仪哪个牌子好
  3. php水果百科动态网站毕业设计-附源码060917
  4. 文献解读 | 单细胞转录组助力解析水稻早期花序的发育轨迹机制
  5. 【Unity游戏开发】动画系统(三)按钮动画
  6. matlab pi表示,matlab中pi是什么意思
  7. Hive正则表达式案例
  8. Mac上Unity打ab包报错 Moving file failed. … No Such file or director
  9. MySQL命令行导出数据库(sql脚本)
  10. 鼠标可拖动的浮动层效果