一文理解UART通信
还记得当年的打印机,鼠标和调制解调器吗?他们都有巨大笨重的连接器和粗电缆,并且必须拧到你的电脑上。这些设备正是使用UART协议与计算机进行通信。虽然USB几乎完全取代了旧的电缆和连接器,但UART绝对没有过时。您会发现目前许多项目中使用UART的GPS模块、蓝牙模块和RFID读卡器模块等连接到Raspberry Pi,Arduino或其他微控制器上。
通用异步收发传输器(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%之内
一文理解UART通信相关推荐
- 一文理解ZigBee通信全过程(基于ZStack-CC2530-2.5.1a协议栈)
自己在word中整理的笔记,基本上详细的分析了Zigbee的原理,比较透彻,分享给大家交流参考! 目录 0概述... 2 1协议栈整体运行流程... 3 1.1. 操作系统初始化流程... 5 1.2 ...
- FPGA基础知识极简教程(6)UART通信与移位寄存器的应用
博文目录 写在前面 正文 关于UART的介绍 UART通信过程 UART.RS232以及TTL之间的关系 UART的使用场合 有关UART的总结 调试UART的技巧 UART的Verilog实现 波特 ...
- 一文理解Netty模型架构
转载自 一文理解Netty模型架构 本文基于Netty4.1展开介绍相关理论模型,使用场景,基本组件.整体架构,知其然且知其所以然,希望给读者提供学习实践参考. 1 Netty简介 Netty是 一 ...
- 一文理解C语言中的volatile修饰符
一文理解C语言中的volatile修饰符 2019/12/2 FesianXu 前言 volatile修饰符是在嵌入式开发和多线程并发编程中常见的修饰符,理解其对于实践过程非常有帮助,此文参考了[1] ...
- MATLAB APP 设计实践(一)UART通信(上篇)
引言 UART通信属于异步串行通信,通信速率比较低,在一些速度要求不高的场合常用来作为多设备之间的控制与被控制方式.例如以UART串口通信作为上位机侧与运行设备之间的通信形式,实现上位机对设备的操控以 ...
- 一文理解CatBoost!
1. CatBoost简介 CatBoost是俄罗斯的搜索巨头Yandex在2017年开源的机器学习库,是Boosting族算法的一种.CatBoost和XGBoost.LightGBM并称为GBDT ...
- 基于Lua脚本语言的嵌入式UART通信的实现
随着变电站智能化程度的逐步提高,对温度.湿度等现场状态参量的采集需求也越来越多.就目前而言,在现场应用中,此类设备多采用RS232或RS485等UART串行通信方式和IED(Intelligent E ...
- MSP430F5529 DriverLib 库函数学习笔记(四)UART通信
目录 硬知识 USCI通信模块 USCI的UART模式 1. USCI初始化和复位 2. 异步通信字符格式 3. 异步多机通信模式 4. 自动波特率检测 5. IrDA编码和解码 6. 自动错误检测 ...
- UART 通信 协议 (二)
文章目录 目录 前言 一.接收时序图 二.模块设计 1.总体方案 2.接受数据信号同步化 3.边沿检测设计 4.生成采样时钟 5.采样数据求和判决 三.编程实现 四.仿真验证 五.板级调试验证 参考说 ...
最新文章
- 如何理解numpy.nan_to_num
- 【斗医】【13】Web应用开发20天
- 网络流媒体协议之——RTSP协议
- 如何在IntelliJ IDEA中快速配置Tomcat
- java多线程安全解决方案_java常用知识:多线程安全问题的解决方法-Lock锁
- 针对Spring的Spring Retry 我发现了这样一个大家都不知道的技巧!
- 前端学习(2029)vue之电商管理系统电商系统之timeline组件
- 深入理解Oracle的并行操作【好文认真读】
- 使用 stm32实现锂电充电_千次循环使用,ZMI可充电锂电池套装,够用一辈子吗?...
- SQL Server应用程序中的高级SQL注入[转]
- 修改云服务器上文件夹只读属性,求助:为什么我电脑里的文件夹会自动变为只读属性?...
- [转载] Python内置函数-min函数和max函数-详解
- linepipe——又一个自然语言开源程序
- 远程屏幕共享软件哪个比较好用
- Struts2 教程
- CPU、GPU、TPU、NPU等到底是什么?
- 最大公约数是啥意思_什么是最大公约数
- 畅想物联网未来 | 百度云天工智能物联网沙龙圆满落幕
- 独立样本与配对样本t检验
- UEFI启动视频详解:启动分析+N项操作实例
热门文章
- 服务器操作系统tco的英文全称,云服务器ECS的英文全称
- 如何在华为云软件开发云上运行Python
- 方向gravity_两种对齐方式,layout_gravity和gravity大不同
- 计算机 缓冲区,计算机里的缓冲区
- 全球及中国柔性AMOLED面板行业消费量调研及投资前景预测报告2022-2028年
- AMD新推两款3GHz双核Opteron处理器 耗电更大
- 完善消费信贷风控措施势在必行
- Social LSTM:Human Trajectory Prediction in Crowded Spaces 翻译
- 移动安全办公可行性方案
- 嘿嘿,我的读者拿到阿里offer,复盘他的时间轴