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 StartedRust0144- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniCPM-V-4.6这是 MiniCPM-V 系列有史以来效率与性能平衡最佳的模型。它以仅 1.3B 的参数规模,实现了性能与效率的双重突破,在全球同尺寸模型中登顶,全面超越了阿里 Qwen3.5-0.8B 与谷歌 Gemma4-E2B-it。Jinja00
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0110
项目优选
收起
暂无描述
Dockerfile
730
4.71 K
Ascend Extension for PyTorch
Python
604
776
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
388
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
995
999
昇腾LLM分布式训练框架
Python
163
196
暂无简介
Dart
984
249
Claude 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 Started
Rust
1.09 K
144
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
234
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.67 K
978
deepin linux kernel
C
29
16