跳转至

UART

一、串口(UART)概述

UART(Universal Asynchronous Receiver/Transmitter,通用异步收发器)是一种常用的串行通信协议,广泛应用于单片机或各种嵌入式设备之间的通信。以下是 UART 的详细介绍:

1.1 UART 的基本概念

UART 是一种串行通信接口,它允许设备通过串行通信方式发送和接收数据。UART 通信是异步的,这意味着通信双方不需要共享一个时钟信号来同步数据传输。UART 通常用于嵌入式系统中,如微控制器与其他设备之间的数据交换。

1.2 UART 的物理连接

UART 通信通常只需要两条线:一条用于数据的发送(TX),一条用于数据的接收(RX)。此外,还需要一条地线(GND)来提供一个共同的参考电平,确保信号的准确性。在实际连接时,一个设备的 TX 线需要连接到另一个设备的 RX 线,反之亦然,这样才能实现双向通信。

1.3 UART 的数据格式

UART 通信的数据格式包括以下几个部分:

  • 起始位:标识数据帧的开始,通常为一个逻辑“0”的位。
  • 数据位:紧随起始位之后,包含实际要传输的数据。数据位的长度可以根据需要设置为 5、6、7、8 或 9 位。
  • 奇偶校验位(可选):用于错误检测,可以是奇校验、偶校验或无校验。
  • 停止位:标识数据帧的结束,可以是 1 位、1.5 位或 2 位。停止位通常为逻辑“1”。

1.4 波特率

波特率是 UART 通信中最重要的参数之一,它定义了数据传输的速率,即每秒钟传输的位数。常见的波特率值有 300、600、1200、2400、4800、9600、19200、38400、57600、115200 等。波特率必须在通信双方之间进行匹配,否则数据将无法正确传输。

1.5 额外的信号管脚

除了基本的 TX 和 RX 管脚,UART 还有其他一些信号管脚,这些管脚用于实现更高级的通信功能,如流控制等:

  • DTR(Data Terminal Ready):数据终端就绪信号,用于指示数据终端设备(DTE)已经准备好进行通信。
  • DSR(Data Set Ready):数据集就绪信号,用于指示数据通信设备(DCE)已经准备好进行通信。
  • DCD(Data Carrier Detect):数据载波检测信号,用于指示检测到载波信号,即通信链路已经建立。
  • RI(Ring Indicator):响铃指示信号,用于指示有来电。
  • nRTS(Request To Send):请求发送信号,用于硬件流控制,当设备准备好发送数据时,此信号为低电平。
  • nCTS(Clear To Send):清除发送信号,用于硬件流控制,当设备准备好接收数据时,此信号为低电平。

这些额外的管脚主要用于实现硬件流控制(如 RTS/CTS)和调制解调器控制(如 DTR/DSR/DCD/RI)。在实际应用中,这些管脚的使用取决于具体的通信需求和硬件配置。

二、演示功能概述

本文将演示如何在 Air780EP 核心板上实现 UART(通用异步收发传输器)的通信。演示功能主要包括以下几个方面:

1. 初始化 UART:将介绍如何配置 UART 的波特率、数据位、停止位和校验位等参数,并初始化 UART。

2. 接收数据:将展示如何通过注册接收事件的回调函数来接收来自 UART 的数据,并处理接收到的数据。

3. 发送数据:将介绍如何使用 UART 的 API 接口来发送数据,包括发送普通字符串、十六进制数据和 JSON 格式的数据。

4. 单串口通信:将展示如何在 Air780EP 核心板上实现单串口通信,包括配置和发送接收数据的步骤。

5. 多串口通信:将展示如何在 Air780EP 核心板上实现多串口通信,包括配置和发送接收数据的步骤。

6. RS485 通信:将展示如何在 Air780EP 核心板上实现 RS485 通信,包括配置和发送接收数据的步骤。

7. USB 虚拟串口:将介绍如何在 Air780EP 核心板上使用 USB 虚拟串口进行通信,包括配置和发送接收数据的步骤。

8. UART 电平:将介绍 UART 电平的标准和如何在 Air780EP 核心板上修改 UART 电平。

通过这些演示,大家可以了解如何在 Air780EP 核心板上实现 UART 通信,包括初始化、接收和发送数据、以及实现单串口、多串口、RS485 和 USB 虚拟串口通信等。

三、演示硬件环境

3.1 开发板

本文主要以 Air780EP 核心板为例进行演示,不过由于本文例程中有关于 UART2 复用的演示,但是 Air780EP 核心板并没有引出可以复用的 GPIO 管脚,因此需要使用 Air780EP 低功耗验证板进行演示,下方也会简单介绍 Air780EP 低功耗验证板。如果您不需要进行 UART2 复用操作,建议还是使用 Air780EP 核心板进行学习。

1. Air780EP 核心板

参考:硬件环境清单第二章节内容,准备以及组装好硬件环境。

2. Air780EP 低功耗验证板

使用 Air780EP 低功耗验证板,如下图为例:

淘宝购买链接:Air780EP 低功耗验证板淘宝购买链接

此核心板的详细使用说明参考:Air780EP 产品手册 中的 << 开发板 EVB-Air780EP-IO 使用说明 V X.X.X.pdf>>,写这篇文章时最新版本的使用说明为:开发板 EVB-Air780EP-IO 使用说明 V1.2.0.pdf ,使用过程中遇到任何问题,可以直接参考这份使用说明 pdf 文档。

四、软件环境

“凡事预则立,不预则废。”在详细阐述本功能示例之前,我们需先精心筹备好以下软件环境。

1. Luatools工具

2. 内核固件文件(底层core固件文件):LuatOS-SoC_V2002_Air780EP;参考项目使用的内核固件

3. luatos需要的脚本和资源文件

脚本和资源文件点我,查看demo链接

lib脚本文件:使用Luatools烧录时,勾选 添加默认lib 选项,使用默认lib脚本文件;

准备好软件环境之后,接下来查看如何烧录项目文件到Air780EP核心板,将本篇文章中演示使用的项目文件烧录到Air780EP核心板中。

五、软硬件资料

5.1 uart 库介绍

5.1.1 主要功能介绍

uart 库即串口操作库,该库为内部库,因此在程序中使用时无需 require 调用。该库主要用于支持 UART(通用异步收发传输)功能,适用于一些嵌入式设备或平台。它使用 C 语言,并结合 Lua 脚本提供了一些 API 供用户方便地控制和操作串口。该库包含如下主要功能:

  • 初始化、配置和管理多个串口设备,包括支持软件 UART。
  • 发送和接收数据,支持串口的基本通信功能。
  • 提供事件回调机制,用户可以注册接收和发送的数据处理函数。
  • 允许用户检查串口的存在以及读取剩余数据缓存的大小。
  • 支持 485 模式的特定操作及其管理。

5.1.2 API 接口介绍

本教程所用 API 接口参考:uart - 串口操作库 - 合宙文档中心

5.2 串口接线介绍

Air780EP 模组支持 3 个串口,分别为主串口 MAIN_UART,扩展串口 AUX_UART,调试串口 DBG_UART。在使用串口时,默认将主串口 MAIN_UART 作为串口 1(UART1),扩展串口 AUX_UART 作为串口 2(UART2)。在本文中,将会使用到 UART1 和 UART2。 特别说明,调试串口 DBG_UART 是用来输出模块的运行日志,不能连接任何外设。

5.2.1 串口管脚位置介绍

下方为 Air780EP 核心板和低功耗验证板的串口管脚位置 关于 GPIO 复用的说明可参考:GPIO 使用注意事项 - luatos@Air780EP - 合宙文档中心

Air780EP 核心板串口管脚位置说明:

Air780EP 低功耗验证板管脚位置说明:

5.2.2 串口接线说明

接下来进行接线操作,注意模块与 MCU 之间要交叉接线,即 TX 接 RX,RX 接 TX,GND 接 GND 。由于本文只需用到 MAIN_UART 和 AUX_UART 两个通用串口,因此下表中只列出了这两个通用串口的模块引脚编号及模块与 MCU 之间的接线说明。

六、代码示例介绍

6.1 初始化

6.1.1 单串口

大家任选其中一个就行,本文使用 MAIN_UART( UART1 )串口进行演示。

  • 使用 MAIN_UART( UART1 )串口:
local uartid = 1 -- 使用uart1,可根据实际设备选取不同的uartid

--初始化 参数都可以根据实施情况修改
uart.setup(
    uartid,--串口id
    115200,--波特率
    8,--数据位
    1--停止位
)
  • 使用 AUX_UART( UART2 )串口:
local uartid = 2 -- 使用uart2

--初始化 参数都可以根据实施情况修改
uart.setup(
    uartid,--串口id
    115200,--波特率
    8,--数据位
    1--停止位
)

6.1.2 多串口

本文以 MAIN_UART( UART1 ) 和 AUX_UART( UART2 ) 两个串口进行演示

-- 根据实际设备选取不同的uartid
local uartid1 = 1 -- 第一个串口id
local uartid2 = 2 -- 第二个串口id

-- 初始化第一个串口
uart.setup(
    uartid1,--串口id
    115200,--波特率
    8,--数据位
    1--停止位
)

-- 初始化第一个串口
uart.setup(
    uartid2,--串口id
    115200,--波特率
    8,--数据位
    1--停止位
)

6.1.3 RS485 串口

local uartid = 1        -- 根据实际设备选取不同的uartid
local uart485Pin = 16   -- 用于控制485接收和发送的使能引脚

--初始化 
uart.setup(
    uartid,     -- 串口id
    9600,       -- 波特率
    8,          -- 数据位
    1,          -- 停止位
    uart.NONE,  -- 校验位
    uart.LSB,   -- 大小端,uart.LSB为小端,uart.MSB为大端
    1024,       -- 缓冲区大小 1024
    uart485Pin, -- 485转换的GPIO
    0,          -- 485模式rx方向的gpio的电平,默认0 低电平
    2000,       -- 485模式下tx向rx转换的延迟时间,单位us
    )

6.1.4 USB 虚拟串口

local uartid = uart.VUART_0 -- 使用USB虚拟串口,固定id

--初始化 参数都可以根据实施情况修改
uart.setup(
    uartid,--串口id
    115200,--虚拟串口的波特率选择多少都无所谓
    8,--数据位
    1--停止位
)

6.2 注册接收数据的回调函数

uart.on 函数用于注册一个接收事件的回调函数,当指定的串口 uartid 接收到数据时,该回调函数会被自动触发并执行。回调函数通过 uart.on(uartid1, "receive", function(id, len) ... end) 定义,并处理接收到的数据。数据的读取是通过 uart.read() 函数进行的,uart.read() 函数是非阻塞的,它是直接从现有缓存区中直接读取数据。

-- 收取数据会触发回调, 这里的 "receive" 是固定值不要修改。
uart.on(uartid, "receive", function(id, len)
    local s = ""
    repeat
        s = uart.read(id, 128)
        if #s > 0 then -- #s 是取字符串的长度
            -- 关于收发hex值,请查阅 https://doc.openluat.com/article/583
            log.info("uart", "receive", id, #s, s)
            log.info("uart", "receive(hex)", id, #s, s:toHex())   -- 如果传输二进制/十六进制数据, 部分字符不可见, 不代表没收到,可以用以hex格式打印
        end
    until s == ""
end)

6.3 发送数据

本文中字符串编码格式为 UTF-8 编码格式,SSCOM 串口调试工具无法正确显示字符串中的中文,需要注意。

  • 发送普通字符串
uart.write(uartid, "\r\nRDY\r\n模块型号:" .. hmeta.model())
  • 发送十六进制的数据串
uart.write(uartid, string.char(0x55,0xAA,0x4B,0x03,0x86))
  • 通过 zbuff 的方式发送数据
local buff = zbuff.create(1024)
buff:copy(0, "aa:bb:cc:dd, zbuff!")
uart.tx(uartid, buff)
  • 发送 json 格式的数据
local data =
{
    host = "abcdefg.com",
    port = "1883",
    clientID = "c88885",
    username = "user",
    password = "123456",
    ca_self = {ssl=false},
}

local jsondata = json.encode(data)
uart.write(uartid, jsondata)

七、功能验证

7.1 单串口

7.1.1 接线展示

下方为 MAIN_UART 的接线图

7.1.2 运行结果展示

由于 SSCOM 工具显示 UTF-8 编码格式的中文内容时会乱码,所以采用 HEX 显示方式进行演示。

7.2 多串口

7.2.1 接线展示

7.2.2 运行结果展示

由于 SSCOM 工具显示 UTF-8 编码格式的中文内容时会乱码,所以采用 HEX 显示方式进行演示。

7.3 RS485 通信

7.3.1 RS485 通信介绍

物联网(IoT)在工业场景中的应用越来越广泛,而 RS485 是一种常见的通信协议,广泛应用于工业自动化和物联网系统中。RS485 是一种串行通信标准,主要用于长距离、多节点通信。适用于工业环境中的传感器、执行器、控制器等设备之间的数据传输,且支持多点通信,可以连接多个设备,实现分布式控制。因为具有较好的抗干扰能力,也很适用于噪声环境下的通信。RS485 支持长距离传输,通常可达 1200 米,适用于工业现场中的远程监控和控制。

RS485 是一种半双工通信协议。半双工通信协议允许数据在两个方向上传输,但同一时间只能在一个方向上传输数据。在 RS485 通信中,当发送数据时,只能发送数据而不能接收数据;当接收数据时,只能接收数据而不能发送数据。

比如:在 RS485 通信中,通常使用一个引脚(如 A 或 RX )作为发送引脚,另一个引脚(如 B 或 TX )作为接收引脚。当发送数据时,发送引脚输出高电平或低电平,接收引脚不工作;当接收数据时,接收引脚输出高电平或低电平,发送引脚不工作。有的也有单独一根线专门用于控制收发逻辑,输出高低电平,负责管理 RS485 的通讯,包括发送、接收、处理错误等数据。

优点

  • 抗干扰能力强:RS485 采用差分信号传输,抗干扰能力强,适用于工业环境中的噪声干扰。
  • 传输距离远:RS485 支持长距离传输,适用于工业现场中的远程监控和控制。
  • 多节点通信:RS485 支持多点通信,可以连接多个设备,实现分布式控制。
  • 兼容性好:RS485 是一种标准化的通信协议,具有较好的兼容性,可以与其他设备进行通信。
  • 成本较低:RS485 模块和电缆的成本相对较低,适用于工业现场中的成本控制。

缺点

  • 信号衰减:随着距离的增加,信号衰减会加剧,影响通信质量。
  • 速率限制:RS485 的传输速率相对较低,通常在 9600bps 到 115200bps 之间,适用于低速数据传输。
  • 电气特性要求:RS485 对电气特性有较高的要求,需要使用特定的电缆和连接器。
  • 布线复杂:RS485 需要使用双绞线进行布线,布线复杂度较高。

7.3.2 接线展示

注意,下面的硬件使用的 RS485-TTL 为硬件自动转换,实际使用根据硬件设置去选择 gpio 转换或者硬件自动转换

需要注意,理论上是 TX 与 RX 交叉接线,如果是直接看板子丝印,那就需要 TX 接 TX,RX 接 RX。

A 接 A,B 接 B。

完整接线图:

7.3.3 运行结果展示

7.4 USB 虚拟串口

7.4.1 USB 虚拟串口介绍

USB 虚拟串口是一种将 USB 接口转换为串行通信接口的技术。它允许计算机通过 USB 接口与其他设备进行串行通信,如调制解调器、打印机、扫描仪等。USB 虚拟串口通常由一个 USB 转串行适配器和一个驱动程序组成。

并且虚拟串口通常没有波特率要求,因为它们是软件模拟的串行通信接口,不依赖于物理硬件。然而,在实际应用中,虚拟串口仍然需要遵守一些基本的通信协议,比如数据位、停止位和校验位等。

USB 虚拟串口的主要功能包括:

  • 串行通信:USB 虚拟串口可以模拟串行通信接口,实现数据的串行传输。它支持各种串行通信协议,如 RS-232、RS-485 等。
  • 传输可靠:传统的串口连接线容易受到干扰,而 USB 虚拟串口采用的 USB 技术可以更好地抵抗干扰,提高了通信的可靠性。
  • 串行控制:USB 虚拟串口可以控制串行通信参数,如波特率、数据位、停止位、奇偶校验等。它还支持串行通信的流控制和错误处理。
  • 使用方便:USB 虚拟串口无需再使用传统的串口连接线,只需要一个标准的 USB 数据线即可连接计算机和外部设备,使得设备连接更加方便

USB 虚拟串口广泛应用于各种领域,如工业自动化、物联网、智能家居等。它为各种设备提供了便捷的串行通信解决方案,提高了系统的灵活性和可靠性。

7.4.2 虚拟通讯串口-端口位置说明

首先通过带有 DM、DP 的 USB 数据线两端连接 模块 和 Windows10 或者 Windows11 系统的电脑。

然后将模块开机,就可以从电脑的设备管理器中看到端口处多出来 3 个 USB 端口。

找到"USB\VID_19D1&PID_0001&MI_06\7&17910EBA&0&0006"就是用于软件控制串口传输的 USB 虚拟串口。

7.4.3 运行结果展示

7.5 UART2 复用到另外一组管脚

由于 Air780EP 核心板没有引出 UART2 的复用管脚,需要使用 Air780EP 低功耗验证板演示。

7.5.1 简介

Air780EP 模块除了默认使用的 28/29 管脚可以作为 UART2 的串口通讯以外,UART2 功能也可以复用到另外两组管脚上使用。

7.5.2 复用到 58/57 脚

  • 管脚说明:

软件在代码中,需要在串口初始化之前,执行 mcu.iomux(mcu.UART, 2, 1) ,这个函数接口可以将外设 IO 复用到非默认配置上。第 1 个参数表示外设类型,第 2 个参数为总线序号,第 3 个参数为新的配置,第 3 个参数需要根据具体平台决定。

mcu.iomux(mcu.UART, 2, 1)       -- Air780EP的UART2复用到gpio12(58脚_RX)和gpio13(57脚_TX)
  • 接线展示:

7.5.3 复用到 55/56 脚

  • 管脚说明:

软件在代码中,需要在串口初始化之前,执行 mcu.iomux(mcu.UART, 2, 2) ,这个函数接口可以将外设 IO 复用到非默认配置上。第 1 个参数表示外设类型,第 2 个参数为总线序号,第 3 个参数为新的配置,第 3 个参数需要根据具体平台决定。

mcu.iomux(mcu.UART, 2, 2)       -- Air780EP的UART2复用到gpio6(55脚_RX)和gpio7(56脚_TX)
  • 接线展示:

7.5.4 运行结果展示

7.6 UART 电平

7.6.1 UART 电平介绍

UART 电平是指串行通信中使用的电压电平标准。常见的串口电平标准有 RS-232、TTL 和 RS-485 等。

1. RS-232 电平:RS-232 是一种常用的串口通信标准,它使用负逻辑电平,即逻辑 1 用 -3V 到 -15V 表示,逻辑 0 用 +3V 到 +15V 表示。RS-232 电平适用于短距离、低速率的通信。 2. TTL 电平:TTL(Transistor-Transistor Logic)电平是一种常见的数字电路电平标准,它使用正逻辑电平,即逻辑 1 用 +5V 表示,逻辑 0 用 0V 表示。TTL 电平适用于短距离、高速率的通信。 3. RS-485 电平:RS-485 是一种常用的串口通信标准,它使用差分电平,即逻辑 1 用 +2V 到 +6V 表示,逻辑 0 用 -2V 到 -6V 表示。RS-485 电平适用于长距离、高速率的通信。

在串口通信中,选择合适的电平标准非常重要,它直接影响到通信的可靠性和稳定性。

Air780EP 模块的 UART IO 电压默认为 1.8V,如果不满足使用场景需要更改电压,那么有两种方式。

7.6.2 默认 UART 电压如何修改

7.6.2.1 通过软件调用接口

在 luatOS 开发中,开机时通过使用 pm.ioVol() 接口,可以实现更改串口的电压。下面是使用实例:

注意:软件通过接口设置的电压优先级要比硬件 iosel 引脚的要高。 例如:将 100 脚接 GND,但软件配置了 pm.ioVol(pm.IOVOL_ALL_GPIO, 1800) , 那么在模块开机时 IO 高电平的电压首先会以硬件 3.3V 输出,然后执行到软件脚本上面配置的 pm.ioVol() 接口时,IO 电压最终会变为输出 1.8V 。

-- pm.ioVol接口第二个参数设置电压范围:(1650~2000,2650~3400) 单位毫伏
-- 接口调用位置可以放到task里面,也可以放在task外面
-- 切换成3.3v
pm.ioVol(pm.IOVOL_ALL_GPIO, 3300)    -- 所有GPIO高电平输出3.3V

-- 切换成1.8v
pm.ioVol(pm.IOVOL_ALL_GPIO, 1800)    -- 所有GPIO高电平输出1.8V
7.6.2.2 通过硬件 iosel 引脚控制电压

Air780EP 模块硬件中可通过 100 脚(io_sel),此脚悬空 IO 电平在开机时会变为 1.8V,如果接 GND 那模块在开机时 IO 电平就会变成 3.3V。

八、总结

本文将演示如何在 Air780EP 核心板上实现 UART(通用异步收发传输器)的通信。

九、扩展

十、常见问题

1. 串口电平电压过低或过高可能会导致什么问题?

如果电压过低,可能会导致接收器无法正确识别信号,如果过高,可能会导致信号损坏或损坏接收器。 概述:可能会导致串口无法正常通讯,或通讯数据会突然出现乱码,数据错乱等问题。

2. 有没有推荐的串口设计电路可以作为参考?

有,请跳转至 https://docs.openluat.com/Air780EP/luatos/hardware/design/uart1/ 查看

给读者的话

本篇文章由 马梦阳 开发;

本篇文章描述的内容,如果有错误、细节缺失、细节不清晰或者其他任何问题,总之就是无法解决您遇到的问题;

请登录合宙技术交流论坛,点击 文档找错赢奖金-Air780EP-LuatOS-软件指南-硬件驱动-UART

用截图标注 + 文字描述的方式跟帖回复,记录清楚您发现的问题;

我们会迅速核实并且修改文档;

同时也会为您累计找错积分,您还可能赢取月度找错奖金!