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

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

3天内不再提示

ArmSoM Rockchip系列产品 通用教程 之 UART 使用

jf_30051736 来源:jf_30051736 作者:jf_30051736 2024-03-08 14:39 次阅读

1. UART 简介

Rockchip UART (Universal Asynchronous Receiver/Transmitter) 基于16550A串口标准,完整模块支持以下功能:

  • 支持5、6、7、8 bits数据位。
  • 支持1、1.5、2 bits停止位。
  • 支持奇校验和偶校验,不支持mark校验和space校验。
  • 支持接收FIFO和发送FIFO,一般为32字节或者64字节。
  • 支持最高4M波特率,实际支持波特率需要芯片时钟分频策略配合。
  • 支持中断传输模式和DMA传输模式。
  • 支持硬件自动流控,RTS+CTS。

2. 普通串口

  • ArmSoM-Sige7中,普通UART集成在40PIN中,可供用户复用为UART功能。
  • 在40PIN中可供复用的UART有:uart2-m2,uart3-m1,uart4-m2,uart7-m1,uart7-m2,uart8-m0

2.1 如何使用40PIN中的UART ?

用户只需参考 overlay 设置,在overlay属性中添加上UART的overlay文件:

例如:

  • 使用UART3:
overlays=rk3588-uart3-m1

  • 使用uart4
overlays=rk3588-uart4-m2

  • 使用uart7
overlays=rk3588-uart7-m1

  • 使用uart8
overlays=rk3588-uart8-m0

2.2 内核menuconfig配置

Device Drivers() ---> Character devices() ---> Serial drivers

2.3 dts配置

2.3.1 芯片级公共配置

kernel/arch/arm64/boot/dts/rockchip/rk3588s.dtsi

uart2: serial@feb50000 {
        compatible = "rockchip,rk3588-uart", "snps,dw-apb-uart";
        reg = <  0x0 0xfeb50000 0x0 0x100  >;
        interrupts = <  GIC_SPI 333 IRQ_TYPE_LEVEL_HIGH  >;
        clocks = <  &cru SCLK_UART2  >, <  &cru PCLK_UART2  >;
        clock-names = "baudclk", "apb_pclk";
        reg-shift = <  2  >;
        reg-io-width = <  4  >;
        dmas = <  &dmac0 10  >, <  &dmac0 11  >;
        pinctrl-names = "default";
        pinctrl-0 = <  &uart2m1_xfer  >;
        status = "disabled";
    };

2.3.2 板级配置

kernel/arch/arm64/boot/dts/rockchip/rk3588-armsom-sige7.dts

UART的板级dts配置只有以下参数允许修改:

dma-names:

  • "tx" 打开tx dma
  • "rx" 打开rx dma
  • "!tx" 关闭tx dma
  • "!rx" 关闭rx dma

pinctrl-0:

  • &uart1m0_xfer 配置tx和rx引脚为iomux group 0
  • &uart1m1_xfer 配置tx和rx引脚为iomux group 1
  • &uart1m0_ctsn和&uart1m0_rtsn 配置硬件自动流控cts和rts引脚为iomux group 0
  • &uart1m1_ctsn和&uart1m1_rtsn 配置硬件自动流控cts和rts引脚为iomux group 1

status:

  • "okay" 打开
    • "disabled" 关闭
&uart2 {
    status = "okay";
    pinctrl-names = "default";
    pinctrl-0 = <  &uart2m2_xfer  >;
}

2.4 UART设备节点

配置好串口后,硬件接口对应软件上的节点分别为:

UART3:   /dev/ttyS3
UART4:   /dev/ttyS4
...

2.5 使用串口唤醒系统

串口唤醒系统功能是在系统待机时串口保持打开,并且把串口中断设置为唤醒源。使用时需要在dts中增 加以下参数:

&uart1 {    wakeup-source;};

3. 控制台串口

  • 在ArmSoM-Sige7中,UART2是作为控制台串口使用,可供用户查看开机启动的信息以及日常调试使用。

3.1 驱动

kernel/drivers/soc/rockchip/fiq_debugger/rk_fiq_debugger.c

3.2 dts配置

由于fiq_debugger和普通串口互斥,在使能fiq_debugger节点后必须禁用对应的普通串口uart节点

fiq_debugger: fiq-debugger {
        compatible = "rockchip,fiq-debugger";
        rockchip,serial-id = <  2  >;
        rockchip,wake-irq = <  0  >;
        /* If enable uart uses irq instead of fiq */
        rockchip,irq-mode-enable = <  1  >;
        rockchip,baudrate = <  1500000  >;  /* Only 115200 and 1500000 */
        interrupts = <  GIC_SPI 423 IRQ_TYPE_LEVEL_LOW  >;
        pinctrl-names = "default";
        pinctrl-0 = <  &uart2m0_xfer  >;
        status = "okay";
    };
    
&uart2 {
    status = "disabled";
};

以下对几个参数进行说明:

  • rockchip,serial-id:使用的UART编号。修改serial-id到不同UART,fiq_debugger设备也会注册成ttyFIQ0设备。
  • rockchip,irq-mode-enable:配置为1使用irq中断,配置为0使用fiq中断。
  • interrupts:配置的辅助中断,保持默认即可。

4. 测试

UART调试提供一个官方测试程序:ts_uart.uart(存放在网盘:1. 开发工具->测试工具)、两个测试用文件send_0x55和send_00_ff,该程序可以联系ArmSoM客服获取。 通过adb工具将测试程序放在开发板上一个可执行的路径下,以下放在data路径:

adb rootadb remountadb push ts_uart.uart /dataadb push send_0x55 /dataadb push send_00_ff /data

在开发板上修改测试程序权限:

sudo chmod +x /data/ts_uart.uart

使用以下命令可以获取程序帮助:

console:/ # ./data/ts_uart.uart
Use the following format to run the HS-UART TEST PROGRAM
ts_uart v1.1
For sending data:
./ts_uart <  tx_rx(s/r)  > <  file_name  >  <  flow_control(0/1)  > <  max_delay(0-
100)  > <  random_size(0/1)  >
tx_rx : send data from file (s) or receive data (r) to put in file
file_name : file name to send data from or place data in
baudrate : baud rate used for TX/RX
flow_control : enables (1) or disables (0) Hardware flow control using RTS/CTS
lines
max_delay : defines delay in seconds between each data burst when sending.
Choose 0 for continuous stream.
random_size : enables (1) or disables (0) random size data bursts when sending.
Choose 0 for max size.
max_delay and random_size are useful for sleep/wakeup over UART testing. ONLY
meaningful when sending data
Examples:
Sending data (no delays)
ts_uart s init.rc 1500000 0 0 0 /dev/ttyS0
loop back mode:
ts_uart m init.rc 1500000 0 0 0 /dev/ttyS0
receive, data must be 0x55
ts_uart r init.rc 1500000 0 0 0 /dev/ttyS0

4.1 测试发送

测试发送的命令如下,send_0x55和send_00_ff为发送的文件:

./data/ts_uart.uart s ./data/send_0x55 1500000 0 0 0 /dev/ttyS3./data/ts_uart.uart s ./data/send_00_ff 1500000 0 0 0 /dev/ttyS3

发送成功可以通过USB转UART小板连接PC端,使用PC端串口调在这里插入代码片试工具验证。

4.2 测试接收

测试接收的命令如下,receive_0x55为接收的文件:

./data/ts_uart.uart r ./data/receive_0x55 1500000 0 0 0 /dev/ttyS1

可以使用PC端串口调试工具发送数据,测试程序将自动检测,检测到U(0x55)接收正确,检测到其它 字符将打印16进制ASCII码值,可以对照查询接收是否正确。

4.3 测试内部自发自收

测试内部自发自收的命令如下:

./data/ts_uart.uart m ./data/send_00_ff 1500000 0 0 0 /dev/ttyS3

按下Ctrl+C停止测试,可以观察到结束log如下。比较发送和接收的数据是否一致:

Sending data from file to port...send:1172, receive:1172 total:1172 # 收发数据一致,测试成功send:3441, receive:3537 total:3441 # 收发数据不一致,测试失败

如果测试失败,说明当前串口存在问题或者有其他程序也在使用同一个串口。可以使用以下命令查看哪 些程序打开了这个串口:

lsof | grep ttyS3


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

    关注

    14

    文章

    1483

    浏览量

    74513
  • uart
    +关注

    关注

    22

    文章

    1159

    浏览量

    99961
  • Rockchip
    +关注

    关注

    0

    文章

    66

    浏览量

    18317
收藏 人收藏

    评论

    相关推荐

    宽电压时钟振荡器系列产品选型指南

    宽电压时钟振荡器系列产品选型指南
    的头像 发表于 04-22 14:53 172次阅读
    宽电压时钟振荡器<b class='flag-5'>系列产品</b>选型指南

    工业数显压力测量系列产品介绍

    电子发烧友网站提供《工业数显压力测量系列产品介绍》资料免费下载
    发表于 03-11 14:04 0次下载

    ArmSoM Rockchip系列产品 通用教程 之 Display 使用

    产 品上需要⽀持 8K 显⽰输出,VP1 上要注意不要连接其他显⽰接口。 1.2 RK3588支持的显示接口​ 2个DP 2个HDMI/eDP 共用接口 2个MIPI DSI BT656/BT1120 2. ArmSoM-W3显示接口​ ArmSoM-W3有着丰富的显示接
    的头像 发表于 03-06 15:50 284次阅读
    <b class='flag-5'>ArmSoM</b> <b class='flag-5'>Rockchip</b><b class='flag-5'>系列产品</b> <b class='flag-5'>通用</b>教程 之 Display 使用

    ArmSoM Rockchip系列产品 通用教程 之 RTC 使用

    1. RTC 简介​ RTC:(Real_Time Clock):实时时钟 HYM8563是一种低功耗实时时钟(RTC)芯片,用于提供精确的时间和日期信息。它提供一个可编程的时钟输出,一个中断输出和一个掉电检测器,所有的地址和数据都通过I2C总线接口串行传递。最大总线速度为 400Kbits/s,每次读写数据后,内嵌的字地址寄存器会自动递增 以下是HYM8563芯片的主要特点和功能: 时钟和日历功能:HYM8563具有时钟和日历功能,可提供准确的时间和日期信息。它支持年、月、日、星期、小时、
    的头像 发表于 03-05 16:57 106次阅读
    <b class='flag-5'>ArmSoM</b> <b class='flag-5'>Rockchip</b><b class='flag-5'>系列产品</b> <b class='flag-5'>通用</b>教程 之 RTC 使用

    ArmSoM Rockchip系列产品 通用教程 之 CAN 使用

    都采用CAN总线来实现汽车内部控制系统之间的数据通信。 RK3568/RK3588的CAN驱动文件:drivers/net/can/rockchip/rockchip
    的头像 发表于 02-29 16:52 212次阅读
    <b class='flag-5'>ArmSoM</b> <b class='flag-5'>Rockchip</b><b class='flag-5'>系列产品</b> <b class='flag-5'>通用</b>教程 之 CAN 使用

    ArmSoM-W3应用开发之安装docker

    1.简介RK3588从入门到精通系列专题开发板:ArmSoM-W3Kernel:5.10.160OS:Debian11本⽂介绍ArmSoM-W3在Debian11下如何安装
    的头像 发表于 11-20 10:05 203次阅读
    <b class='flag-5'>ArmSoM</b>-W3应用开发之安装docker

    ArmSom--摄像头开发指南(二)

    一.简介RK3588从入门到精通开发板:ArmSoM-W3Kernel:5.10.160OS:Debian11上篇文档介绍了rockchip平台怎么配置MIPI-CSI的通路,本⽂主要介绍
    的头像 发表于 11-06 10:30 1061次阅读
    <b class='flag-5'>ArmSom</b>--摄像头开发指南(二)

    ArmSom--摄像头开发指南(一)

    一.简介RK3588从入门到精通开发板:ArmSoM-W3Kernel:5.10.160OS:Debian11本⽂主要介绍在Rockchip平台下Camera相关代码配置,MIPI-CSI调试的通路
    的头像 发表于 11-03 14:56 909次阅读
    <b class='flag-5'>ArmSom</b>--摄像头开发指南(一)

    MCU微课堂 | CKS32F4xx系列产品GPIO口配置

    MCU微课堂 | CKS32F4xx系列产品GPIO口配置
    的头像 发表于 10-24 15:14 481次阅读
    MCU微课堂 | CKS32F4xx<b class='flag-5'>系列产品</b>GPIO口配置

    四川零点全系列产品介绍

    四川零点全系列产品介绍
    发表于 10-24 14:36 0次下载

    ArmSoM-W3RK3588 MPP环境配置

    1. 简介瑞芯微提供的媒体处理软件平台(Media Process Platform,简称 MPP)是适用于瑞芯微芯片系列通用媒体处理软件平台。该平台对应用软件屏蔽了芯片相关的复杂底层处理,其目的
    发表于 10-19 10:39

    armsom:为何选择rk3588开发与Jetson Nano引脚兼容的嵌入式产品

    引言: 当armsom决定采用RK3588芯片开发一款与Jetson Nano引脚兼容的产品时,这意味着一次重要的技术决策,为开发者和制造商提供了更大的灵活性。这篇文章将解释我们选择RK3588
    发表于 10-18 17:35

    RK3588平台产测ArmSoM产品高温环境测试

    1. 简介 ArmSoM团队在产品量产之前都会对产品做几次专业化的功能测试以及性能压力测试,以此来保证产品的质量以及稳定性 优秀的产品都要进
    发表于 10-12 09:57

    RK3588平台产测ArmSoM-W3 DDR压力测试

    root@linaro-alip:/rockchip-test# ./rockchip_test.sh DDR压力测试开始: ArmSoM 产品介绍: http
    发表于 10-09 19:29

    【LGA封装RK3588核心板】基于RK3588,小而强大的ArmSom-W3 CORE BOARD

    Armsom-RK3588 LGA Core board 是一款基于Rockchip RK3588芯片平台,采用LGA(506pin)封装设计的一款极小尺寸的RK3588核心板。
    的头像 发表于 07-03 16:08 1300次阅读
    【LGA封装RK3588核心板】基于RK3588,小而强大的<b class='flag-5'>ArmSom</b>-W3 CORE BOARD