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

本文主要是介绍RK3568 学习笔记 : Linux emmc 内核启动 rootfs 根文件系统无法正常挂载问题的分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述

  • 平台 : 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 无法挂载问题

这篇关于RK3568 学习笔记 : Linux emmc 内核启动 rootfs 根文件系统无法正常挂载问题的分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/972866

相关文章

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制