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

相关文章

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配