Linux系统git漏提空目录导致根文件系统rootfs启动时挂载失败

本文主要是介绍Linux系统git漏提空目录导致根文件系统rootfs启动时挂载失败,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

从git服务器下载SDK代码,自编译出大包文件,在进行烧写后发现启动时挂载rootfs根文件系统失败,打印如下:

[    4.500157] UBIFS (ubi0:0): background thread "ubifs_bgt0_0" started, PID 161
[    4.556092] UBIFS (ubi0:0): recovery needed
[    4.599850] UBIFS (ubi0:0): recovery completed
[    4.603390] UBIFS (ubi0:0): UBIFS: mounted UBI device 0, volume 0, name "rootfs"
[    4.610680] UBIFS (ubi0:0): LEB size: 253952 bytes (248 KiB), min./max. I/O unit sizes: 4096 bytes/4096 bytes
[    4.620569] UBIFS (ubi0:0): FS size: 76439552 bytes (72 MiB, 301 LEBs), journal size 9404416 bytes (8 MiB, 38 LEBs)
[    4.630979] UBIFS (ubi0:0): reserved for root: 0 bytes (0 KiB)
[    4.636771] UBIFS (ubi0:0): media format: w4/r0 (latest is w4/r0), UUID FF904CF4-E7E5-4D45-8522-B0458FBC0218, small LPT model
[    4.650529] VFS: Mounted root (ubifs filesystem) on device 0:12.
[    4.655939] Freeing unused kernel memory: 312K (c0ad8000 - c0b26000)
[    4.661881] @RamosKernel command line: noinitrd  rw console=ttyHSL0,115200,n8 androidboot.hardware=qcom ehci-hcd.park=3 msm_rtb.filter=0x37 lpm_levels.sleep_disabled=1  earlycon=msm_hsl_uart,0x78b3000  androidboot.serialno=a37185f5 androidboot.authorized_kernel=true androidboot.baseband=msm rootfstype=ubifs rootflags=bulk_read root=ubi0:rootfs ubi.mtd=19 ubi.mtd=13
[    4.694665] quectel_mount failed 挂载失败
[    4.697420] @Ramos set restore modem flag here 444444 
[    4.702685] @Ramos :mtdsize:500000, mtd->writesize =4096, mtd->erasesize:262144  blockcount
[    4.711091] @Ramos qfirst_goodblock_addr=-1610612461 
[    4.716387] @Ramos set partition(modem) restore, offset=440000,print magic1=0,magic2=78e5d4c2
[    4.725205] @Ramos g_fota_upgradedFlag_goodblock=-1 fota_upgradedFlag=3670016
[    4.731834] @Ramos set partition magic	right !!!!!
[    4.739764] @Ramos set partition(modem) flag=1,successd restore times=246 !!!
[    4.745892] Going down for restart now 【这里重启了】
[    4.750241] Calling SCM to disable SPMI PMI

使用发布版本启动挂载正常打印如下:

[    4.500157] UBIFS (ubi0:0): background thread "ubifs_bgt0_0" started, PID 161
[    4.556092] UBIFS (ubi0:0): recovery needed
[    4.599850] UBIFS (ubi0:0): recovery completed
[    4.603390] UBIFS (ubi0:0): UBIFS: mounted UBI device 0, volume 0, name "rootfs"
[    4.610680] UBIFS (ubi0:0): LEB size: 253952 bytes (248 KiB), min./max. I/O unit sizes: 4096 bytes/4096 bytes
[    4.620569] UBIFS (ubi0:0): FS size: 76439552 bytes (72 MiB, 301 LEBs), journal size 9404416 bytes (8 MiB, 38 LEBs)
[    4.630979] UBIFS (ubi0:0): reserved for root: 0 bytes (0 KiB)
[    4.636771] UBIFS (ubi0:0): media format: w4/r0 (latest is w4/r0), UUID FF904CF4-E7E5-4D45-8522-B0458FBC0218, small LPT model
[    4.650529] VFS: Mounted root (ubifs filesystem) on device 0:12.
[    4.714335] Freeing unused kernel memory: 312K (c0ad8000 - c0b26000)
[    4.720271] @RamosKernel command line: noinitrd  rw console=ttyHSL0,115200,n8 androidboot.hardware=qcom ehci-hcd.park=3 msm_rtb.filter=0x37 lpm_levels.sleep_disabled=1  earlycon=msm_hsl_uart,0x78b3000  androidboot.serialno=588c78b androidboot.authorized_kernel=true androidboot.baseband=msm rootfstype=ubifs rootflags=bulk_read root=ubi0:rootfs ubi.mtd=19 ubi.mtd=13
[    4.855481] UBIFS (ubi1:0): UBIFS: mounted UBI device 1, volume 0, name "modem", R/O mode
[    4.862686] UBIFS (ubi1:0): LEB size: 253952 bytes (248 KiB), min./max. I/O unit sizes: 4096 bytes/4096 bytes
[    4.872559] UBIFS (ubi1:0): FS size: 47235072 bytes (45 MiB, 186 LEBs), journal size 9404416 bytes (8 MiB, 38 LEBs)
[    4.882971] UBIFS (ubi1:0): reserved for root: 0 bytes (0 KiB)
[    4.888754] UBIFS (ubi1:0): media format: w4/r0 (latest is w4/r0), UUID 43E7EFF3-32C9-48F0-8476-F22950783580, small LPT model
[    4.906146] quectel_mount_success 

分析

1、首先怀疑是编译环境问题,通过对比提交原始代码的服务器,没有发现差异;

2、怀疑是提交原始代码的服务器漏提交文件,通过对比发现漏提交了很多空目录,对比结果如下;

bin  build.prop  dev  etc  lib  linuxrc  sbin  share  system  target  usr  var  WEBSERVER  www
bin  boot  build.prop  cache  data  dev  etc  firmware  home  lib  linuxrc  media  mnt  proc  run  sbin  share  sys  system  target  tmp  usr  var  WEBSERVER  www

3、通过上面对比得知缺少目录,那到底是缺少哪个目录呢?来查看一下内核挂载失败的打印:quectel_mount failed,通过搜索内核代码如下:

   pr_notice("@RamosKernel command line: %s\n", temp_cmdLine);//if(strstr(temp_cmdLine, "ubi.mtd=19")) //this condition will replace last,if ( system_mode_flag == QUECTEL_SYSTEM_NORMAL_MODE ){extern void *subsystem_get_with_fwname(const char *name, const char *fw_name);if( sys_mount("ubi1:modem", "/firmware", rootfstype, MS_RDONLY, rootflags)&&  sys_mount("/dev/ubi1_0", "/firmware", rootfstype, MS_RDONLY, rootflags)){printk("quectel_mount failed \n");printk("@Ramos set restore modem flag here 444444 \r\n");Quectel_Set_Partition_RestoreFlag("modem",4); // modem ޷أлԭ}else{printk("quectel_mount_success \n");subsystem_get_with_fwname("modem", "modem");}}

可以看到是挂载modem分区到/firmware目录下失败,不是前面分析出的挂载rootfs跟文件系统失败;modem分区文件NON-HLOS.ubi我们没有修改,不会有问题的;查看得知是firmware目录不存在导致,使用系统调用mount挂载时目录必须存在是基本的常识,在用户层会提示“No such file or directory”,但是sys_mount为何没有提示呢?

sys_mount在ext4文件系统学习的时候应该是看过代码实现了的,再回去复习一下,看内核代码检查后确实没有提示;

挂载失败后,设置分区参数重启使用recovery进行恢复,这里不是分区文件问题,而是没有这个目录,所以导致的结果就是循环的挂载失败并一直重启。

原因

git会自动忽略空目录,导致在使用git status命令不能发现漏提交的空目录,这样在提交SDK源码文件时漏提交空目录,这样的话其他人通过git下载文件后缺少跟文件系统必须的目录,导致启动挂载失败;

解决

在空目录下增加.gitkeep文件,这样就可以让git追踪空目录,这也是最通用的方式(注:.gitigonre中不要忽略.gitkeep文件否则会失效);

搜索空目录结果如下:

[yubo.wang@localhost ql-ol-rootfs]$ find ./ -type d -empty
./mnt
./proc
./run
./sys
./tmp
。。。

在每个空目录下增加.gitkeep文件:

find ./ -type d -empty | xargs -I {} touch {}/.gitkeep

增加.gitkeep文件后就能使用git status查看差异了: 

最后把空目录提交上去然后下载编译烧写验证OK。

总结

提交git代码文件时,需要注意空目录的处理,防止出现上面的类似问题。遇到此类问题也可逐一排查环境和代码来定位。

 

这篇关于Linux系统git漏提空目录导致根文件系统rootfs启动时挂载失败的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor