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

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

3天内不再提示

UART串口通信协议详解

我快闭嘴 来源:全栈芯片工程师 作者:Chiptist 2022-09-07 09:47 次阅读

通用异步收发传输器(Universal Asynchronous Receiver/Transmitter),通常称作UATR,是一种串行、异步、全双工的收发器。全双工的UART支持同时双向通信,是嵌入式系统必不可少的debug接口

什么是全双工?什么是半双工?

全双工:同一时刻,两个设备都在收发数据,比如SPI。注意QSPI是半双工,因为4根线只能同时收或者发。

半双工:两设备间可以收发数据,但只能收完再发或发完再收。

单工:任何时刻只能进行一个方向的通讯,且固定一方为发送设备,一方为接收设备。

串口通信协议

dfcde42c-2de8-11ed-ba43-dac502259ad0.png

空闲位:不通信时,TX & RX是逻辑“1”状态,表示当前线路无数据传输。

起始位:发送“0”,表示传输开始。

数据位:起始位之后,数据位的个数可以是5、6、7、8等,一般是8bit,采用ASCII码。从最低位开始传送,根据波特率在数据bit稳定的中间位置采样。

奇偶校验位:数据位加上这一位后,使得“1”的位数为偶数,则为偶校验,使得“1”的位数为奇数则为奇校验,以次来校验数据传送的正确性。

比如一个 8 位长的有效数据为:10100101,此时总共有 4 个“ 1”,

为达到奇校验效果,校验位应为“ 1”,即有效数据和校验位中“ 1”的个数为奇数。

为达到偶校验效果,校验位应为“ 0”,即有效数据和校验位中“ 1”的个数为偶数。

注意,UART校验方法有:奇校验(odd)、偶校验(even)、0校验(space)、0校验(mark)、无校验(noparity),为了提高实际带宽,一般可省去校验位,即选择无校验,思考下为什么?

0 校验是不管有效数据是什么,校验位固定为“ 0”。1 校验是校验位固定为“ 1”。

无校验就是数据包中不包含校验位。

停止位:一个字符数据传输的结束标志,可以是1位、1.5位、2位的高电平。停止位不仅表示传输的结束,并且可提供校正时钟同步。停止位的位数越多,时钟容忍程度越大,但有效带宽就越小。

波特率

数据传输速率使用波特率来表示。单位bps(bits per second),常见的波特率9600bps、19200bps、115200bps等,如果串口波特率设置为9600bps,那么传输1bit数据需要的时间是1/9600≈104.2us。

带上校验位,传送一个字符数据实际是11个比特(1bit开始位、8bit数据位、1bit校验位、1bit停止位),有效的传输速率实际为9600*8/11= 6982bps。

不带校验位,传送一个字符数据实际是10个比特(1bit开始位、8bit数据位、1bit停止位),有效的传输速率实际为9600*8/10=7680bps。

这就是为何不传校验位,可以提高一点带宽,也就是所谓的开销。

以小编设计的RISC-V SoC为例,仿真UART:

e0205e78-2de8-11ed-ba43-dac502259ad0.png

写个简单的测试程序:

e04bb5e6-2de8-11ed-ba43-dac502259ad0.png

配置波特率115200bps:

e0726074-2de8-11ed-ba43-dac502259ad0.png

观察到1bit的传输时间为8.8us,1s/115200bps=8.68us, 基本符合预期。

e09dc796-2de8-11ed-ba43-dac502259ad0.png

仿真打印效果:

e0b71958-2de8-11ed-ba43-dac502259ad0.png

审核编辑:汤梓红

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

    关注

    10

    文章

    2968

    浏览量

    104776
  • 通信协议
    +关注

    关注

    28

    文章

    737

    浏览量

    39745
  • uart
    +关注

    关注

    22

    文章

    1159

    浏览量

    99961

原文标题:UART通信协议及SoC仿真

文章出处:【微信号:全栈芯片工程师,微信公众号:全栈芯片工程师】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    UART通信协议

    位、波特率等均可以在COM接口中设置。也可以在代码中对UART寄存器的各位进行设置,UART寄存器的各位所代表的含义如下:下面通过几个小程序,了解UART通信协议进行数据传输的过程:在
    发表于 01-31 10:43

    通用异步收发传输器UART串口通信协议有哪些特性呢

    什么是通用异步收发传输器UART呢?通用异步收发传输器UART串口通信协议有哪些特性呢?
    发表于 11-01 07:03

    怎样使用STM32CubeMX来配置USART串口通信协议

    UART串口通信协议的工作原理是什么?怎样使用STM32CubeMX来配置USART串口通信协议呢?
    发表于 12-06 06:53

    UART串口通信协议的相关资料分享

    #今天也是咸鱼的一天~UART是一个很基础的串口通信协议,有人打趣说只要有单片机的地方,就一定有uart。这话不假,不仅很多模块和单片机的通信
    发表于 01-18 09:42

    UART通信协议的相关资料推荐

    开发板来举例讲解(其他STM32系列芯片大多数都可以按照这些步骤来操作的),如有不足请多多指教。2、UART简介  嵌入式开发中,UART串口通信协议是我们常用的
    发表于 01-25 06:40

    串口通信协议的相关资料分享

    目录一、串口通信协议1、UART简介2、 UART通信协议(1)起始位(2)数据帧(3)奇偶校验位(4)停止位(5)下个起始位(6)波特率二
    发表于 02-22 07:16

    Modbus通信协议详解

    关于Modbus通信协议详解和应用分析
    发表于 10-12 16:54 148次下载
    Modbus<b class='flag-5'>通信协议</b><b class='flag-5'>详解</b>

    串口通信协议详解

    串口是计算机上一种非常通用设备通信协议。大多数计算机包含两个基于RS232的串口串口同时也是仪器仪表设备通用的
    发表于 11-09 14:51 8506次阅读

    基于状态机的串口通信协议的设计与实现

    设计并实现了一种基于状态机的串口通信协议,并将此协议应用到称重仪表的上位机通信中。本文介绍了串口通信协议
    发表于 05-08 15:22 169次下载
    基于状态机的<b class='flag-5'>串口</b><b class='flag-5'>通信协议</b>的设计与实现

    PC与单片机串口通信协议

    PC与单片机串口通信协议
    发表于 12-26 22:12 0次下载

    STM32的三种串口通信协议介绍

    本文首先介绍了STM32串口硬件电路及串口编程,其次介绍了STM32的三种串口通信协议,最后介绍了STM32串口
    发表于 05-25 09:33 3.7w次阅读
    STM32的三种<b class='flag-5'>串口</b><b class='flag-5'>通信协议</b>介绍

    STM8学习之在串口通信中定义通信协议

    STM8学习之在串口通信中定义通信协议
    发表于 03-16 15:39 50次下载
    STM8学习之在<b class='flag-5'>串口</b><b class='flag-5'>通信</b>中定义<b class='flag-5'>通信协议</b>

    基于STM32之UART串口通信协议(一)详解

    开发板来举例讲解(其他STM32系列芯片大多数都可以按照这些步骤来操作的),如有不足请多多指教。2、UART简介  嵌入式开发中,UART串口通信协议是我们常用的
    发表于 11-30 14:36 22次下载
    基于STM32之<b class='flag-5'>UART</b><b class='flag-5'>串口</b><b class='flag-5'>通信协议</b>(一)<b class='flag-5'>详解</b>

    【世说知识】一文搞懂UART通信协议

    UART,即通用异步接收器/发送器,是最常用的设备间通信协议之一,正确配置后,UART可以配合许多不同类型的涉及发送和接收串行数据的串行协议工作。在串行
    的头像 发表于 02-02 10:46 1078次阅读
    【世说知识】一文搞懂<b class='flag-5'>UART</b><b class='flag-5'>通信协议</b>

    UART串口通信协议是什么?

    UART (Universal Asynchronous Receiver/Transmitter) 是一种通信接口协议,用于实现串口通信
    的头像 发表于 03-19 17:26 283次阅读