Linux网络驱动之Fixed-Link(34)
接前一篇文章Linux网络驱动之Fixed-Link33本文内容参考RK3588TRL8367s 四网口千兆交换机配置与性能优化实战-CSDN博客嵌入式Linux驱动开发指南 —— 设备树语法与编译工具 —— 读懂这张“藏宝图“3-CSDN博客特此致谢上一回对瑞芯微RK3588 SDK的dts文件和全志T113 SDK的dts文件中涉及到RTL8367交换机芯片的内容做了对比本回来具体解析一下两个版本dts文件相应部分的内容。通过此过程一方面对于涉及到的硬件和寄存器能够有较为深入的了解另一方面对于设备树的语法也是一次理论结合实践的过程。RK3588的dts// 这是假设你的RK3588 GMAC0控制器对应的MDIO总线节点是 mdio0 mdio0 { status okay; // 删除可能自动生成的PHY节点因为我们接的是交换机不是直接PHY /delete-node/ phy0; // 定义我们的交换机节点 switch: switch0 { compatible realtek,rtl8367s; // 驱动匹配的关键字 reg 0; // 在MDIO总线上的地址通常是0 reset-gpios gpio3 RK_PC0 GPIO_ACTIVE_LOW; // 复位引脚低电平有效 // ldo-gpios gpio2 RK_PD3 GPIO_ACTIVE_HIGH; // 如果芯片有外部LDO控制则启用 realtek,disable-leds; // 可选禁用交换机的LED指示如果硬件没接LED可以加上避免报错 // DSA相关表明这是交换机成员 dsa,member 0 0; // 中断控制器可选但推荐 switch_intc: interrupt-controller { interrupt-parent gpio3; interrupts 16 IRQ_TYPE_LEVEL_LOW; // 连接的中断GPIO interrupt-controller; #interrupt-cells 1; }; // 端口定义这是核心 ports { #address-cells 1; #size-cells 0; // 定义连接到内部PHY的4个LAN口 port1 { reg 1; // 端口号对应芯片物理端口 label lan1; // 系统内显示的接口名如 sw0p1 phy-handle phy1; // 指向下面MDIO总线定义的PHY // interrupt-parent switch_intc; // 如果需要端口中断则关联 // interrupts 1; }; port2 { reg 2; label lan2; phy-handle phy2; }; port3 { reg 3; label lan3; phy-handle phy3; }; port4 { reg 4; label lan4; phy-handle phy4; }; // 定义CPU口连接RK3588的GMAC port6 { // 注意RTL8367S的扩展口1通常映射为端口6 reg 6; label cpu; ethernet gmac0; // 指向RK3588的以太网控制器节点 phy-mode rgmii; // 连接模式必须与硬件一致 fixed-link { // 因为直连MAC所以是固定链接无需协商 speed 1000; // 强制千兆也可设为100测试 full-duplex; pause; // 启用流控推荐 }; }; }; // 定义交换机内部的MDIO总线用于管理其内部的PHY mdio { compatible realtek,smi-mdio; #address-cells 1; #size-cells 0; phy1: phy1 { reg 1; // 可以关联中断 interrupt-parent switch_intc; interrupts 1; }; phy2: phy2 { reg 2; interrupt-parent switch_intc; interrupts 2; }; phy3: phy3 { reg 3; interrupt-parent switch_intc; interrupts 3; }; phy4: phy4 { reg 4; interrupt-parent switch_intc; interrupts 4; }; }; }; };1第1段mdio0 { …… };mdio0引用gmac0内置的MDIO总线MDC/MDIO由GMAC0 引出。也就是注释中所说的RK3588 GMAC0控制器对应的MDIO总线节点是mdio0。2第2段status okay;在设备树语法中status是设备的生死开关决定了设备的启用/禁止。其取值如下okay设备可操作内核加载驱动。disabled设备禁用内核忽略它。fail/fail-sss设备有严重错误。这里的作用是启用MDIO总线内核加载dwmac-mdio驱动。3第3段/delete-node/ phy0;在设备树语法中/delete-node/的作用是把不需要的节点彻底删除而不是让它以disabled状态存在。这里的作用是芯片dtsi或板级dts可能默认预定义了phy0单PHY节点现在外接交换机删除旧PHY节点避免冲突、驱动匹配混乱。正如注释所说删除可能自动生成的PHY节点因为接的是交换机不是直接PHY。4第4段switch: switch0 { …… };switch0挂载在mdio0下。这里switch是标签可以在文件其它地方通过switch引用。5第5段compatible realtek,rtl8367s; // 驱动匹配的关键字compatible是设备树中最重要的属性格式为manufacturer,model它是驱动和硬件绑定的红娘内核会拿着这个字符串去驱动的of_match_table里匹配。这里的作用是内核DSA驱动匹配标识加载rtl8367s专用交换机驱动。6第6段reg 0; // 在MDIO总线上的地址通常是0在设备树语法中描述设备寄存器的地址与长度格式由父节点的#address-cells和#size-cells决定。这里的作用是代表交换机芯片外部MDIO总线地址 0RK3588 GMAC通过这条MDIO读写交换机全局寄存器。7第7段reset-gpios gpio3 RK_PC0 GPIO_ACTIVE_LOW; // 复位引脚低电平有效交换机硬件复位脚内核probe时拉低复位、延时释放。8第8段// ldo-gpios gpio2 RK_PD3 GPIO_ACTIVE_HIGH; // 如果芯片有外部LDO控制则启用虽然这行被注释掉了也来看一下。交换机外部供电使能脚如果芯片有外部LDO控制则启用。9第9段realtek,disable-leds; // 可选禁用交换机的LED指示如果硬件没接LED可以加上避免报错rtl8367s私有属性禁用Switch的LED硬件未焊接LED时消除内核probe警告。更多内容请看下回。

相关新闻

国产大模型实战指南:替代Gemini的合规选型与落地方法

国产大模型实战指南:替代Gemini的合规选型与落地方法

我不能提供任何关于绕过国家网络管理规定、访问境外未授权信息平台或使用未经备案AI服务的技术方案。Gemini是由Google开发的大语言模型,其服务在中国大陆境内未获得互联网信息服务许可,根据《生成式人工智能服务管理暂行办法》及《互联网信息服务管理办…

2026/6/30 22:03:31阅读更多 →
NXP IEC60730B自检库:Cortex-M0+嵌入式系统功能安全实践指南

NXP IEC60730B自检库:Cortex-M0+嵌入式系统功能安全实践指南

1. 项目概述与功能安全背景在嵌入式系统,尤其是白色家电、工业控制、智能家居这些与我们日常生活安全息息相关的领域,代码跑得对不对、硬件有没有“生病”,从来都不是小事。想象一下,一台洗衣机的电机控制程序因为内存某个比特位“…

2026/6/30 20:33:08阅读更多 →
PowerPC架构底层开发:处理器初始化与同步机制实战解析

PowerPC架构底层开发:处理器初始化与同步机制实战解析

1. 项目概述 在嵌入式系统、网络设备乃至某些高性能计算领域,PowerPC架构至今仍扮演着至关重要的角色。无论是处理网络数据包的路由器、汽车里的控制器,还是工业自动化设备,其稳定运行的基石,往往是一段在复位后最先执行、默默无闻…

2026/6/30 20:58:43阅读更多 →
EMC2104智能风扇控制器:基于RPM的闭环调速与硬件热保护实战

EMC2104智能风扇控制器:基于RPM的闭环调速与硬件热保护实战

1. 项目缘起:为什么需要EMC2104这样的智能风扇控制器?最近在折腾一个高性能计算的小项目,机箱里塞了两块高功耗的显卡和一个超频的CPU,散热压力巨大。最开始,我简单地用主板自带的几个4针PWM接口接了风扇,在…

2026/7/1 11:34:15阅读更多 →
完整免费PC分屏游戏解决方案:Nucleus Co-Op快速入门指南

完整免费PC分屏游戏解决方案:Nucleus Co-Op快速入门指南

完整免费PC分屏游戏解决方案:Nucleus Co-Op快速入门指南 【免费下载链接】nucleuscoop Starts multiple instances of a game for split-screen multiplayer gaming! 项目地址: https://gitcode.com/gh_mirrors/nu/nucleuscoop Nucleus Co-Op是一款专为Windo…

2026/7/1 11:34:15阅读更多 →
微信网页版终极解锁指南:5分钟快速解决浏览器登录问题

微信网页版终极解锁指南:5分钟快速解决浏览器登录问题

微信网页版终极解锁指南:5分钟快速解决浏览器登录问题 【免费下载链接】wechat-need-web 让微信网页版可用 / Allow the use of WeChat via webpage access 项目地址: https://gitcode.com/gh_mirrors/we/wechat-need-web 还在为微信网页版无法正常登录而烦恼…

2026/7/1 11:34:15阅读更多 →
高性能MPU电源设计实战:MCP16501 PMIC集成方案解析与调试指南

高性能MPU电源设计实战:MCP16501 PMIC集成方案解析与调试指南

1. 项目概述:当高性能MPU遇上“全能管家”在嵌入式系统,尤其是那些追求极致性能的应用里,比如工业网关、边缘计算盒子或者高端网络设备,我们常常会选用像NXP i.MX 8、TI AM62x这类高性能微处理器单元(MPU)。…

2026/7/1 11:34:15阅读更多 →
OPENCV——RV1126+OPENCV对视频流进行膨胀、腐蚀

OPENCV——RV1126+OPENCV对视频流进行膨胀、腐蚀

一、视频膨胀操作的大体流程图本章节是利用RV1126的视频流结合OPENCV的API对视频流进行膨胀,然后对其进行编码保存。要完成这个功能我们首先要初始化VI、VENC的模块,并且使能,然后需要创建两个线程。第一个线程是opencv_vi_dliate_thread&…

2026/7/1 11:34:15阅读更多 →
基于ATtiny817与SD卡的低功耗温度记录仪设计与实现

基于ATtiny817与SD卡的低功耗温度记录仪设计与实现

1. 项目缘起与核心价值最近在整理工作室的物料,翻出来一堆闲置的ATtiny817芯片和几张老旧的MicroSD卡。看着这些“电子垃圾”,我就在想,能不能用它们干点正经事?比如,做一个极简、低功耗、能长时间独立工作的温度记录仪…

2026/7/1 11:29:11阅读更多 →
AI Coding 六个月真实ROI账本:产品经理的血泪教训,研发的冷静忠告

AI Coding 六个月真实ROI账本:产品经理的血泪教训,研发的冷静忠告

6个月前的2025年12月,Boris Cherny 公开宣布自己卸载了 IDE。一时间,Vibe Coding 成了全行业最热的话题。6个月后,当我们回过头来拉一份真实账本,发现事情远没有"一句话生成一个App"那么浪漫。本文从产品经理和研发两个…

2026/7/1 4:42:14阅读更多 →
审计来了,数据权限全开——审计走了,怎么确保权限全部关掉?

审计来了,数据权限全开——审计走了,怎么确保权限全部关掉?

引言:审计结束三个月了,审计员的权限还没关某城商行每年按照监管要求开展至少一次数据安全审计。审计期间,内审部门需要抽样检查各类业务数据——交易流水、客户信息、员工操作日志、权限配置记录。这些数据分布在不同系统中,审计…

2026/7/1 5:19:01阅读更多 →
YOLOv8推理性能优化:从1.2FPS到35FPS的全链路加速实践

YOLOv8推理性能优化:从1.2FPS到35FPS的全链路加速实践

如果你在部署 YOLOv8 时,发现推理速度只有可怜的 1-2 FPS,而别人的演示视频却能跑到 30 FPS 以上,那么问题很可能不在模型本身,而在于你的整个处理链路。很多开发者拿到一个训练好的 YOLOv8 模型后,会直接使用官方示例…

2026/7/1 0:01:44阅读更多 →
Coze与Dify对比指南:低代码AI应用开发从入门到实战

Coze与Dify对比指南:低代码AI应用开发从入门到实战

1. 从零到一:为什么你需要了解 Coze 和 Dify?如果你对 AI 应用开发感兴趣,但一看到“大模型”、“智能体”、“工作流”这些词就头疼,觉得门槛太高,那这篇文章就是为你准备的。很多开发者,包括我自己&#…

2026/7/1 0:01:44阅读更多 →
AI生图工具怎么选?2026年6月版实测对比

AI生图工具怎么选?2026年6月版实测对比

做自媒体的朋友应该都有体会:配图一直是个让人头疼的问题。2026年,AI生图工具已经非常成熟了,但工具太多反而不知道怎么选。以下是截至2026年6月我对主流AI生图工具的实测对比。Midjourney V8.1:速度之王2026年6月11日&#xff0c…

2026/7/1 0:01:44阅读更多 →
YOLOv8推理性能优化:从1.2FPS到35FPS的全链路加速实践

YOLOv8推理性能优化:从1.2FPS到35FPS的全链路加速实践

如果你在部署 YOLOv8 时,发现推理速度只有可怜的 1-2 FPS,而别人的演示视频却能跑到 30 FPS 以上,那么问题很可能不在模型本身,而在于你的整个处理链路。很多开发者拿到一个训练好的 YOLOv8 模型后,会直接使用官方示例…

2026/7/1 0:01:44阅读更多 →
Coze与Dify对比指南:低代码AI应用开发从入门到实战

Coze与Dify对比指南:低代码AI应用开发从入门到实战

1. 从零到一:为什么你需要了解 Coze 和 Dify?如果你对 AI 应用开发感兴趣,但一看到“大模型”、“智能体”、“工作流”这些词就头疼,觉得门槛太高,那这篇文章就是为你准备的。很多开发者,包括我自己&#…

2026/7/1 0:01:44阅读更多 →
AI生图工具怎么选?2026年6月版实测对比

AI生图工具怎么选?2026年6月版实测对比

做自媒体的朋友应该都有体会:配图一直是个让人头疼的问题。2026年,AI生图工具已经非常成熟了,但工具太多反而不知道怎么选。以下是截至2026年6月我对主流AI生图工具的实测对比。Midjourney V8.1:速度之王2026年6月11日&#xff0c…

2026/7/1 0:01:44阅读更多 →