RK3568 学习笔记 : Linux emmc 内核启动 rootfs 根文件系统无法正常挂载问题的分析

devtools/2024/10/5 18:24:21/

问题描述

  • 平台 : NanoPi-R5C 开发板 RK3568 平台。

  • 手动编译的 Linux 内核,结果发现大概率 emmc 无法正常初始化,导致 rootfs 根文件系统无法正常挂载

  • Linux 内核版本: 6.1

  • Linux 内核代码位置: https://github.com/friendlyarm/kernel-rockchip.git,分支 nanopi6-v6.1.y

  • u-boot Linux 内核引导启动参数

bootargs=console=ttyS2,1500000 earlycon=uart8250,mmio32,0xfe660000 root=/dev/mmcblk2p3 rootfstype=ext4 rw rootwaitbootcmd=ext4load mmc 0:2 0x280000 Image; ext4load mmc 0:2 0x8300000 rk3568-nanopi5-rev02.dtb; booti 0x280000 - 0x8300000

在这里插入图片描述

问题排查

  • 通过查看 LOG 信息,发现 emmc 相关的初始化信息不多,或者在 挂载文件系统(ext4)时,emmc 没有初始化。

  • 通过修改内核代码:电源管理部分,让电源管理 PMIC 初始化提前,问题依旧。

  • 切换了内核的版本,有的版本有改善,但依旧有概率性无法挂载 rootfs 根文件系统,导致系统启动死机

  • RK 平台的Linux 内核可能更改了一些,尝试把 regulator 与 io power domains 提前初始化,但是执行依旧比较的靠后,尤其是 drivers/soc/rockchip/io-domain.c 中的 rockchip_iodomain_driver_init,提前初始化,但是 相应的 执行函数 rockchip_iodomain_probe 依旧执行的非常靠后,理论上电源部分需要提前初始化好,尤其是 emmc,里面有个 VCC_1V8 电源,来自电源管理芯片 PMIC。

解决问题

  • 从代码层面上,加了一些 LOG 打印,确认是电源初始化有点靠后,导致 emmc 没有正常初始化,文件系统 mount 挂载失败,查看文件系统挂载相关的代码,init/do_mounts.c,是否可以在文件系统挂载的地方加个延时。

  • 通过查看 init/do_mounts.c 文件系统挂载相关的代码,意外发现有个 u-boot 传参可以用于 延时挂载

  • 函数 prepare_namespace,里面有个 root_delay 变量,用于延时,单位是秒(ssleep)

/** Prepare the namespace - decide what/where to mount, load ramdisks, etc.*/
void __init prepare_namespace(void)
{if (root_delay) {printk(KERN_INFO "Waiting %d sec before mounting root device...\n",root_delay);ssleep(root_delay);}
  • 经过查找 root_delay 变量,确认是来自 u-boot 的传参,因此,修改 u-boot 传参 bootargs,增加 rootdelay=1 即可,比如延时 1秒

在这里插入图片描述

  • 设置 bootargs console=ttyS2,1500000 earlycon=uart8250,mmio32,0xfe660000 root=/dev/mmcblk2p3 rootfstype=ext4 rootdelay=1 rw rootwait

  • 经过测试,发现emmc 正常初始化了,并且正常挂载 rootfs 根文件系统,并且可以进入 console 控制台。

  • emmc 根文件系统 rootfs 挂载问题得到初步的解决

在这里插入图片描述

小结

  • 后面研究一下 电源管理 pmic 与 regulator,确认为何电源管理初始化不能提前的问题(驱动注册提前初始化,但是执行函数 probe 靠后),更改启动的次序,发现没有效果

  • 这个 rootdelay 参数可能是Linux 新内核支持的,后面尝试对比新老版本Linux 内核,优化解决这个emmc 初始化较慢导致根文件系统 rootfs 无法挂载问题


http://www.ppmy.cn/devtools/38230.html

相关文章

Unity调用智谱API(简单操作 文本实时翻译)

代码展示: using Newtonsoft.Json; using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.Networking; using UnityEngine.UI;public class ZhiPuAi : MonoBehaviour {// API的端点URLpublic string…

[法规规划|数据概念]金融行业数据资产和安全管理系列文件解析

“ 金融行业在自身数据治理和资产化建设方面一直走在前列。” 一直以来,金融行业由于其自身需要,都是国内开展信息化建设最早,信息化程度最高的行业。 同时,金融行业的数据治理、数据资产化以及过程中的管理要求和安全要求与其他…

设置默认表空间和重命名

目录 设置默认表空间 创建的临时表空间 tspace4 修改为默认临时表空间 创建的永久性表空间 tspace3 修改为默认永久表空间 重命名表空间 将表空间 tspace3 修改为 tspace3_1 Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/13520…

【leetcode】栈题目总结

普通栈 先进后出的特点 ​​​​​​20. 有效的括号 class Solution { public:unordered_map<char, char> mp {{), (},{], [},{}, {}};bool isValid(string s) {stack<char> st;for (char c : s) {if (c ( || c [ || c {) {st.push(c);} else {if (!st.empty…

[NOIP1999 普及组] Cantor 表

题目描述 现代数学的著名证明之一是 Georg Cantor 证明了有理数是可枚举的。他是用下面这一张表来证明这一命题的&#xff1a; 我们以 Z 字形给上表的每一项编号。第一项是 1 / 1 1/1 1/1&#xff0c;然后是 1 / 2 1/2 1/2&#xff0c; 2 / 1 2/1 2/1&#xff0c; 3 / 1 3/1…

【C++】命名空间和IO流

一切都从这个代码开始&#xff01;&#xff01;&#xff01; #include<iostream>using namespace std;int main() {cout << "Hello world!" << endl;return 0; } 命名空间 当我们写了这么一段代码的时候... Ctrl F5运行&#xff0c;发现报错了..…

深度学习中模块化设计的理念优势

模块化设计在深度学习领域中是一个重要的概念&#xff0c;比如在构建和改进类似于编码器-解码器这样的复杂模型时&#xff0c;transformer就是编码器-解码器架构的一个实例。模块化设计可以帮助我们快速集成最新的研究成果&#xff0c;支持模型的快速迭代&#xff0c;这些都与深…

Python深度学习基于Tensorflow(6)神经网络基础

文章目录 使用Tensorflow解决XOR问题激活函数正向传播和反向传播解决过拟合权重正则化Dropout正则化批量正则化 BatchNormal权重初始化残差连接 选择优化算法传统梯度更新算法动量算法NAG算法AdaGrad算法RMSProp算法Adam算法如何选择优化算法 使用tf.keras构建神经网络使用Sequ…