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支持能力,用户可以根据实际需求随时切换存储接口类型。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677