当前位置: 首页 > news >正文

RK3588 RTL8211F PHY的LED灯调试

文章目录

    • 一、硬件连接概述
      • 1.1 典型连接方式
      • 1.2 硬件原理图
    • 二、RTL8211F LED控制原理
      • 2.1 LED控制寄存器
      • 2.2 LCR寄存器位定义
      • 2.3 常见LED配置值及其效果
    • 三、Linux内核中的RTL8211F LED控制实现
      • 3.1 驱动层LED控制代码
    • 四、通过ADB命令控制RTL8211F LED
      • 4.1 切换到扩展页并配置LED
      • 4.2 验证配置
    • 五、故障排除
      • 5.1 LED不亮的可能原因
      • 5.2 调试方法
    • 六、参考资料

一、硬件连接概述

RK3588是一款高性能ARM处理器,支持多种以太网接口配置。RTL8211F是一款常用的千兆以太网PHY芯片,支持多种LED指示模式。在典型的RK3588平台上,RTL8211F通过RGMII接口与处理器相连,其LED信号通常连接到RK3588的GPIO引脚,用于指示网络状态。

1.1 典型连接方式

  • RK3588的RGMII接口连接到RTL8211F的数据接口
  • RTL8211F的LED1和LED2信号分别连接到网口座子

1.2 硬件原理图

在这里插入图片描述

二、RTL8211F LED控制原理

2.1 LED控制寄存器

RTL8211F通过特定寄存器控制LED的行为,主要涉及LCR(LED Control Register)。该寄存器位于扩展页0xd04中,通过MDIO接口访问。

2.2 LCR寄存器位定义

LCR寄存器的相关位定义如下(仅列出关键位):
在这里插入图片描述
在这里插入图片描述

Bit位置名称读写类型默认值功能描述对LED的影响
16.15RSVDRO0保留位,禁止修改-
16.14LED2_ACTRW1控制LED2的数据活动指示功能1=数据收发时闪烁
0=仅显示链路状态(常亮/灭)
16.13LED2_LINK_1000RW1控制LED2在1000Mbps链路速率下的点亮功能1=1000Mbps链路时点亮
0=忽略1000Mbps链路状态
16.12RSVDRO0保留位,禁止修改-
16.11LED2_LINK_100RW0控制LED2在100Mbps链路速率下的点亮功能1=100Mbps链路时点亮
0=忽略100Mbps链路状态
16.10LED2_LINK_10RW0控制LED2在10Mbps链路速率下的点亮功能1=10Mbps链路时点亮
0=忽略10Mbps链路状态
16.9LED1_ACTRW1控制LED1的数据活动指示功能1=数据收发时闪烁
0=仅显示链路状态(常亮/灭)
16.8LED1_LINK_1000RW0控制LED1在1000Mbps链路速率下的点亮功能1=1000Mbps链路时点亮
0=忽略1000Mbps链路状态
16.7RSVDRO0保留位,禁止修改-
16.6LED1_LINK_100RW1控制LED1在100Mbps链路速率下的点亮功能1=100Mbps链路时点亮
0=忽略100Mbps链路状态
16.5LED1_LINK_10RW0控制LED1在10Mbps链路速率下的点亮功能1=10Mbps链路时点亮
0=忽略10Mbps链路状态
16.4LED0_ACTRW1控制LED0的数据活动指示功能1=数据收发时闪烁
0=仅显示链路状态(常亮/灭)
16.3LED0_LINK_1000RW0控制LED0在1000Mbps链路速率下的点亮功能1=1000Mbps链路时点亮
0=忽略1000Mbps链路状态
16.2RSVDRO0保留位,禁止修改-
16.1LED0_LINK_100RW0控制LED0在100Mbps链路速率下的点亮功能1=100Mbps链路时点亮
0=忽略100Mbps链路状态
16.0LED0_LINK_10RW1控制LED0在10Mbps链路速率下的点亮功能1=10Mbps链路时点亮
0=忽略10Mbps链路状态

2.3 常见LED配置值及其效果

以下是几种常见的配置值及其对应的LED行为:

配置值二进制表示LED2行为LED1行为
0x6d000110 1101 0000 000010/100/1000Mbps链路状态+活动指示(闪烁)1000Mbps链路状态常亮,非则灭灯
0x20400010 0000 0100 0000100Mbps链路状态常亮,非则灭灯100Mbps链路状态常亮,非则灭灯

在这里插入图片描述

三、Linux内核中的RTL8211F LED控制实现

在RK3588平台的Linux内核中,可以通过以下方式实现对RTL8211F LED的控制。

3.1 驱动层LED控制代码

在内核驱动中,可以通过phy驱动的fixup函数来配置LED。以下是一个典型的实现示例:
驱动路径:drivers/net/ethernet/stmicro/stmmac/stmmac_main.c

 #define PHY_ID_RTL8211F                   0x001cc916#define PAGE_SELECT_ADDR                  0x1f#define RTL_8211F_PHY_ID_MASK   0x001fffff#define RTL_8211F_LCR_ADDR      0x10static int phy_rtl8211f_led_fixup(struct phy_device *phydev)
{/* 切换到扩展页0xd04 */phy_write(phydev, RTL_8211F_PAGE_SELECT, 0xd04);/* 设置LCR寄存器值为0x6171 */phy_write(phydev, RTL_8211F_LCR_ADDR, 0x6d00);/* 切换回默认页 */phy_write(phydev, RTL_8211F_PAGE_SELECT, 0xa42);return 0;
}//在stmmac_dvr_probe函数中调用:/* register the PHY board fixup */
ret = phy_register_fixup_for_uid(PHY_ID_RTL8211F, RTL_8211F_PHY_ID_MASK, phy_rtl8211f_led_fixup);if (ret) {
dev_warn(priv->device, "arunce Cannot register PHY board fixup, terry in :%s.\n", __func__); 
}

四、通过ADB命令控制RTL8211F LED

在RK3588开发板上,可以通过ADB命令直接控制RTL8211F的LED。

4.1 切换到扩展页并配置LED

# 切换到扩展页0xd04
/sys/bus/mdio_bus/devices/stmmac-1:01#  echo 0x1f 0xd04 > phy_registers# 写入LED控制寄存器值(例如0x2d60 )
/sys/bus/mdio_bus/devices/stmmac-1:01# echo 0x10 0x2d60 > phy_registers

4.2 验证配置

# 读取LED控制寄存器值,确认配置成功
cat phy_registers0x16的值:应返回0x2d60 # eth0 切换成百兆
mii-tool -F 100baseTx-FD eth0# eth0 恢复自动协商
mii-tool -r eth0# 查看eth0 的配置
mii-tool eth0

五、故障排除

5.1 LED不亮的可能原因

  1. 硬件连接问题:检查RTL8211F与rj45之间的线路连接是否正确
  2. 寄存器配置错误:确认LCR寄存器的值设置正确
  3. PHY地址问题:检查设备树中PHY地址配置是否与实际一致
  4. 电源问题:确保RTL8211F正常供电
  5. 检查RJ45网口的led 正 负 是否正确。规格书-硬件原理图,有概率会搞反导致灯不亮。

5.2 调试方法

  1. 使用ethtool工具检查以太网状态:
    adb shell ethtool eth0
    
  2. 查看内核日志确认PHY驱动是否正常工作:
    adb shell dmesg | grep eth0
    
  3. 使用示波器或逻辑分析仪检查LED信号引脚的电平变化

六、参考资料

  1. RTL8211F数据手册
  2. RK3588处理器规格说明书
  3. Linux内核文档中的MDIO和PHY驱动部分
  4. 设备树绑定文档中的以太网部分

通过以上配置和方法,可以在RK3588平台上灵活控制RTL8211F的LED指示灯,实现各种网络状态指示需求。

http://www.xdnf.cn/news/884539.html

相关文章:

  • 能做超厚铜pcb工厂有哪些?
  • MLP实战二:MLP 实现图像数字多分类
  • 大中型水闸安全监测管理系统建设方案
  • Authpf(OpenBSD)认证防火墙到ssh连接到SSH端口转发技术栈 与渗透网络安全的关联 (RED Team Technique )
  • 机器学习的数学基础:决策树
  • 今日学习:ES8语法 | Spring整合ES | ES场景八股
  • Python html 库用法详解
  • Selenium 和playwright 使用场景优缺点对比
  • 使用Python提取照片元数据:方法与实战指南
  • 【定昌linux开发板】关闭ssh 端口 22
  • Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
  • 短视频矩阵系统技术saas源头6年开发构架
  • 深入理解JavaScript设计模式之闭包与高阶函数
  • 【JVM】三色标记法原理
  • VisDrone无人机视觉挑战赛观察解析2025.6.5
  • 无人机避障与视觉跟踪技术分析!
  • 装备制造项目管理具备什么特征?如何选择适配的项目管理软件系统进行项目管控?
  • Spring Boot + Elasticsearch + HBase 构建海量数据搜索系统
  • 【数据分析】基于adonis2与pairwise.adonis2的群组差异分析教程
  • vue-router路由问题:可以通过$router.push()跳转,但刷新后又变成空白页面
  • Uniapp 二维码生成与解析完整教程
  • Spring IoC 详解:原理、实现与实战
  • 【Go语言基础【3】】变量、常量、值类型与引用类型
  • Excel处理控件Aspose.Cells教程:使用 C# 从 Excel 进行邮件合并
  • [Git] 文件删除
  • 五、查询处理和查询优化
  • 自动驾驶TPM技术杂谈 ———— 车辆安全设计思考维度
  • 中阳视角下的资产配置趋势分析与算法支持
  • 使用ArcPy进行栅格数据分析(2)
  • MPLAB X IDE ​软件安装与卸载