Amlogic S9xxx Armbian 项目:SM3399B 设备支持与内核模块优化
背景介绍
在 Amlogic S9xxx Armbian 项目中,开发者们成功为 SM3399B 设备提供了支持。这款基于 Rockchip RK3399 芯片的设备在运行 Armbian 系统时遇到了一些特殊挑战,特别是与无线网络模块相关的性能问题。
设备支持现状
SM3399B 设备采用 RK3399 处理器,通过替换设备树文件(dtb)的方式,已经能够成功运行多个版本的 Armbian 系统。测试表明,Armbian 24.11.0 版本在替换适当的 dtb 文件后可以正常工作。
遇到的核心问题
在系统运行过程中,用户报告了严重的性能问题,表现为系统负载异常升高(达到10左右),导致几乎无法进行任何操作。通过分析系统日志,发现问题与 Broadcom 无线网络驱动(brcmfmac)有关。
问题分析与解决方案
深入分析系统日志后发现,brcmfmac 内核模块在初始化过程中触发了空指针异常,导致系统资源被大量占用。具体表现为:
- 驱动尝试访问空指针地址 0x0000000000000038
- 产生数据中止异常(Data abort)
- 导致内核崩溃(Oops)
针对这一问题,开发者提出了两种解决方案:
临时解决方案
对于已经安装的系统,可以通过以下步骤临时解决问题:
- 移动 brcmfmac 内核模块文件:
mv /usr/lib/modules/6.1.120-Lemon1151/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko /usr/lib/modules/6.1.120-Lemon1151/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko.bak
- 重启系统
这种方法可以立即解决问题,但会永久禁用无线网络功能。
长期解决方案
更彻底的解决方案是在内核构建阶段禁用 brcmfmac 模块:
- 修改内核配置文件
- 将
CONFIG_BRCMFMAC=m改为# CONFIG_BRCMFMAC is not set - 重新编译内核
这种方法可以确保系统从一开始就不会加载有问题的驱动模块。
系统优化建议
除了解决 brcmfmac 问题外,针对 SM3399B 设备的 Armbian 系统还可以进行以下优化:
- CPU 亲和性设置:通过调整中断请求(IRQ)的 CPU 亲和性,可以优化网络性能
- RPS 设置:合理配置接收包转向(RPS)的 CPU 掩码可以提升网络吞吐量
- 日志系统优化:对于使用 btrfs 文件系统的用户,建议关闭日志目录的写时复制属性以提高性能
结论
通过对 SM3399B 设备的支持工作,Amlogic S9xxx Armbian 项目进一步扩展了其硬件兼容性。这次经验也提醒开发者,在支持新硬件时,需要特别注意特定硬件与内核模块的兼容性问题。通过内核配置调整和系统优化,可以显著提升设备的运行稳定性和性能表现。
对于普通用户,如果不需要无线网络功能,简单的模块禁用即可解决问题;而对于需要完整功能的用户,则建议采用内核重新编译的方式获得最佳体验。
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考



