一文读懂串口(波形分析、起始位、数据位、停止位、空闲位)

2023-11-03 12:40

本文主要是介绍一文读懂串口(波形分析、起始位、数据位、停止位、空闲位),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

串口

    • 一、串口(串行接口)
    • 二、异步串口(以下统称串口)
    • 三、重要参数
      • 1、波特率
      • 2、报文格式
        • 2.1、起始位
        • 2.2、数据位
        • 2.3、奇偶校验位
        • 2.4、停止位
        • 2.5、空闲位
    • 四、波形
      • 1、具体连接
      • 2、波形分析
        • 2.1 发送1报文
        • 2.2 发送65报文
    • 五、总结

本文使用 STM32F407ZGT6单片机基于标准库进行测试

一、串口(串行接口)

概念: 串行接口 (英文:Serial Interface) 是指数据一位一位地顺序传送,一条信息的各位数据被逐位按顺序传送的通讯方式称为串行通讯。
特点: 串行通讯的特点是:数据位的传送,按位顺序进行,最少只需一根传输线即可完成;成本低但传送速度慢。串行通讯的距离可以从几米到几千米。
优点: 通信线路简单,只要一对传输线就可以实现双向通信,可以直接利用电话线作为传输线,从而大大降低了成本,特别适用于远距离通信,但传送速度较慢。

分类: 串口分为同步串行接口和异步串行接口

  • 同步串行接口(英文:SynchronousSerialInterface,SSI),即通信双方共用一个时钟,是一种常用的工业用通信接口。
  • 异步串行接口(英文:Universal Asynchronous Receiver/Transmitter, UART),通信双方通过使用相同的波特率来实现同步,采用固定的通信格式,数据以相同的帧格式进行传送,这里我们主要讨论异步串行接口。

二、异步串口(以下统称串口)

串口有TTL和RS232两种电平,它们的具体区别是:

电平TTLRS232
输出低电平Lo <= 0.8V+3V <= Lo <= +15V
输出高电平Ho >= 2.4V-15V <= Ho <= -3V
输入低电平Li <= 1.2V+3V <= Li <= +15V
输入高电平Hi >= 2.0V-15V <= Hi <= -3V

三、重要参数

1、波特率

串口通信最重要的是波特率,它实现了通信双方的时序同步。
波特(Baud)即调制速率,指的是有效数据讯号调制载波的速率,即单位时间内载波调制状态变化的次数。
波特率表示每秒钟传送的码元符号的个数,它是对符号传输速率的一种度量,它用单位时间内载波调制状态改变的次数来表示,1波特即指每秒传输1个符号。常用的波特率为:115200 、9600。

2、报文格式

串口的报文数据由:
起始位(1bit)+ 数据位(5~8bit)+ 奇偶校验位(1bit)+ 停止位(1~1.5bit)

2.1、起始位

在发送有效数据前,无需配置,会自动产生1bit 逻辑“0”的低电平的起始位,表示串口数据传输开始,之后开始发送有效数据。

2.2、数据位

数据位,决定了通信过程中传输的有效数据位数,数据位通常有5、6、7 、8 bit,需要根据需要进行相应的配置,这里我选择8位字长。还需要注意的是有效数据在报文中的存放顺序是以LSB还是以MSB进行存放,这里我的是LSB,在这里插入图片描述

2.3、奇偶校验位

奇偶校验位,因为在通信过程中易受到外部干扰而导致数据出现偏差,所以在有效数据之后增加了校验位来解决这个问题,校验方式需要配置,校验方式有奇校验、偶校验、0校验和1校验

  • 奇校验要求有效数据和校验位中“1”的个数为奇数;
  • 偶校验则要求有效数据和校验位中“1”的个数为偶数;
  • 0校验位则是校验位始终为0,在收到报文后,检测校验位是否为0;
  • 1校验则是校验位始终为1,在收到报文后,检测校验位是否为1;

0校验和1校验过于简陋,不建议使用,这里我选择不使用奇偶校验。在这里插入图片描述

2.4、停止位

停止位,停止位是一帧数据结束的标志,可以是1bit、1.5bit或者2bit逻辑“1” 高电平需要根据自己需求配置,每一个设备都有自己的时钟,在传输过程中可能出现了小小的不同步,停止位不仅仅表示传输的结束,并且提供了校正时钟同步的机会。这里我选择1bit停止位。在这里插入图片描述

2.5、空闲位

空闲位不算是串口报文内的数据, 它是发送完一组报文后,总线会自动将电平拉高,产生1bit 逻辑“1”空闲位

四、波形

1、具体连接

调节示波器触发方式为上升沿触发后,将程序烧入开发板,连接板子Tx端(PA)与GND 进行测试。
在这里插入图片描述
在这里插入图片描述

2、波形分析

以下串口配置我选择了

  • 8bit 的数据位
  • 无奇偶校验位
  • 1bit 的停止位
2.1 发送1报文

在这里插入图片描述

  • 首先是1bit 的起始位,则报文为: 0;
  • 发送1, 8bit有效数据即为: 0000 0001 又因为是小端字节序( 英文:little endian)所以在报文中的实际存储为:1000 0000,则此时报文为: 0 1000 0000 ;
  • 没有使用奇偶校验,不使用奇偶校验位,此时报文没有变化为:0 1000 0000;
  • 使用1bit的停止位,则完整数据报文为: 0 1000 0000 1 ;
  • 发送完成后,自动产生1bit的空闲位,具体见下图:

在这里插入图片描述

2.2 发送65报文

在这里插入图片描述

  • 首先是1bit 的起始位,则报文为: 0;
  • 发送65,8bit数据即为:0100 0001, 又因为是小端字节序,所以实际储存为:1000 0010, 则此时报文为: 0 1000 0010;
  • 没有使用奇偶校验,则不使用奇偶校验位,原报文不做变化,此时报文为:0 1000 0010;
  • 使用1bit的停止位,则完整的数据报文为:0 1000 0010 1
  • 发送完成后,自动产生1bit的空闲位,详情见下图:

在这里插入图片描述

五、总结

通过抓取串口波形,对串口的报文格式有了进一步了解,串口报文格式为:

起始位(1bit)+ 数据位(5~8bit)+ 奇偶校验位(1bit)+ 停止位(1~1.5bit)

在发送完成一组报文后,会自动产生1 bit 的空闲位,以便进行下一组数据的传输。

这篇关于一文读懂串口(波形分析、起始位、数据位、停止位、空闲位)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/338246

相关文章

一文带你迅速搞懂路由器/交换机/光猫三者概念区别

《一文带你迅速搞懂路由器/交换机/光猫三者概念区别》讨论网络设备时,常提及路由器、交换机及光猫等词汇,日常生活、工作中,这些设备至关重要,居家上网、企业内部沟通乃至互联网冲浪皆无法脱离其影响力,本文将... 当谈论网络设备时,我们常常会听到路由器、交换机和光猫这几个名词。它们是构建现代网络基础设施的关键组成

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类