Ubuntu-Rockchip项目:ROC-RK3588S-PC开发板的NVMe支持优化
2025-06-26 00:25:30作者:俞予舒Fleming
背景介绍
ROC-RK3588S-PC是一款基于Rockchip RK3588S处理器的开发板,其M.2接口同时支持SATA和PCIe协议。然而在默认配置下,该开发板仅启用了SATA支持,需要通过修改设备树并重新编译固件才能启用NVMe支持。本文将详细介绍如何在不重新编译固件的情况下,通过设备树覆盖技术实现NVMe支持。
技术原理分析
RK3588S处理器的M.2接口设计采用了灵活的配置方式,可以通过软件选择支持SATA或PCIe协议。这种设计带来了硬件兼容性的优势,但也增加了软件配置的复杂性。在设备树中,相关配置主要体现在以下几个方面:
- 电源管理:NVMe设备需要稳定的3.3V供电
- 时钟配置:PCIe接口需要特定的时钟信号
- 引脚复用:M.2接口的引脚需要正确配置为PCIe模式
现有问题诊断
在当前的Ubuntu-Rockchip固件中,ROC-RK3588S-PC开发板的设备树默认将M.2接口配置为SATA模式。通过分析系统日志,可以观察到以下关键信息:
[ 16.665514] reg-fixed-voltage vcc3v3-pcie20: Looking up vin-supply from device tree
[ 19.227602] rockchip-pm-domain: Looking up pcie-supply property in node failed
这些日志表明PCIe电源管理未能正确初始化,导致NVMe设备无法被识别。
解决方案实现
方法一:使用设备树覆盖技术
- 创建或获取预编译的SATA设备树覆盖文件(rk3588s-roc-pc-sata0.dtbo)
- 修改u-boot配置:
sudo vi /etc/default/u-boot
添加以下内容:
U_BOOT_FDT_OVERLAYS_DIR="/lib/firmware/6.1.0-1021-rockchip/device-tree/rockchip/overlay/"
U_BOOT_FDT_OVERLAYS="rk3588s-roc-pc-sata0.dtbo"
U_BOOT_SYNC_DTBS="true"
U_BOOT_UPDATE="true"
- 更新u-boot配置:
sudo u-boot-update
方法二:直接替换设备树二进制文件
对于需要更彻底解决方案的用户,可以直接替换设备树二进制文件:
- 获取支持NVMe的设备树源文件(rk3588s-roc-pc.dts)
- 编译设备树:
dtc -I dts -O dtb -o rk3588s-roc-pc.dtb rk3588s-roc-pc.dts
- 替换系统设备树文件:
sudo cp rk3588s-roc-pc.dtb /lib/firmware/6.1.0-1021-rockchip/device-tree/rockchip/rk3588s-roc-pc.dtb
验证与测试
成功应用解决方案后,系统日志应显示PCIe链路已建立:
[ 16.614772] rk-pcie fe190000.pcie: PCIe Link up, LTSSM is 0x130011
[ 16.614820] rk-pcie fe190000.pcie: PCIe Gen.2 x1 link up
通过lsblk命令应能看到NVMe设备:
nvme0n1 259:0 0 1.9T 0 disk
└─nvme0n1p1 259:1 0 1.9T 0 part
性能优化建议
- 对于高性能NVMe SSD,建议检查PCIe链路速度:
dmesg | grep "available PCIe bandwidth"
-
考虑使用PCIe 3.0 x4接口的M.2转接板以获得更高性能
-
对于需要频繁读写的大型应用,建议将根文件系统迁移到NVMe设备
总结
通过设备树覆盖或直接替换设备树二进制文件的方法,用户可以灵活地在ROC-RK3588S-PC开发板上启用NVMe支持,无需重新编译整个固件。这种解决方案不仅简化了配置过程,还保留了系统原有的SATA支持能力,用户可以根据实际需求随时切换存储接口类型。
登录后查看全文
热门项目推荐
相关项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0134
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00
最新内容推荐
【免费下载】 提升下载效率:BaiduExporter-Motrix 扩展程序推荐【亲测免费】 GRABIT:从图像文件中提取数据点的Matlab源码【亲测免费】 电力电表376.1协议Java版【亲测免费】 一键获取网站完整源码:打造您的专属网站副本 探索三维世界:Three.js加载GLTF文件示例项目推荐【亲测免费】 解决 fatal error C1083: 无法打开包括文件 "stdint.h": No such file or directory【免费下载】 华为网络搬迁工具 NMT 资源下载【免费下载】 LabVIEW 2018 资源下载指南 JDK 8 Update 341:稳定高效的Java开发环境【免费下载】 TSMC 0.18um PDK 资源文件下载
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
499
3.66 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
870
482
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
310
134
React Native鸿蒙化仓库
JavaScript
297
347
暂无简介
Dart
745
180
Ascend Extension for PyTorch
Python
302
343
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
11
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
66
20
仓颉编译器源码及 cjdb 调试工具。
C++
150
882