问:挂载自己制作的文件系统卡在这里:
  
  NET: Registered protocol family 1
  
  NET: Registered protocol family 17
  
  VFS: Mounted root (cramfs filesystem) readonly.
  
  Freeing init memory: 116K
  
  Failed to execute /linuxrc. Attempting defaults...
  
  Kernel panic - not syncing: No init found. Try passing init= optionto kernel.
  
  bootargs为:
  
  noitinrd root=/dev/mtdblock2 rootfstype=cramfs console=ttySAC0,115200 init=/linurc mem=64M
  
  linuxrc的内容如下:
  
  #!/bin/sh
  
  echo mount /etc as ramfs
  
  /bin/mount-n -t ramfs ramfs /etc
  
  /bin/cp -a /mnt/etc/* /etc
  
  echo re-create the /etc/mtab entries
  
  #re-create the /etc/mtab entries
  
  /bin/mount -f -t cramfs -o remount, ro /dev/mtdblock/3 /
  
  /bin/mount -f -t ramfs ramfs /etc
  
  exec /sbin/init
 
  
  rcS如下:
  
  #!/bin/sh
  
  /bin/mount -a
  

  内核版本2.6.19.2。怎么解决?
  
  答:
  
  这类问题很常见,先总体介绍一下解决思路。
  
  能出现让人激动的的控制台,那么系统移植已经接近完成。 但是不少人在最后一步出现问题。
  
  要点如下:
  
  1. 在正确的位置烧写正确格式的文件系统映象
  
  2. 内核支持这种文件系统格式
  
  3. 文件系统的内容要完整
  
  上面说得简单,一个个介绍。
  
  1. 在正确的位置烧写正确的文件系统映象:
  
  (a). 正确的位置
  
  嵌入式开发中常通过bootloader烧写文件系统映象,假设写在flash的地址A处。
  
  内核启动时,显然要从地址A处读取文件系统,内核怎么知道的呢?通过命令行参数,比如“root=/dev/mtdblock2 ”。/dev/mtdblock2 又是怎么和地址A对应上的呢?内核将flash划分为几个分区,这是在代码中固定的。/dev/mtdblock2是第3个分区,它的开始地址必须是A。
  
  内核启动时,可以看到这些分区的开始地址、结束地址,比如内核启动时会有类似下面的信息:
  
  Creating 3 MTD partitions on NAND 64MiB 3,3V 8-bit:
  
  0x00000000-0x00030000 : bootloader
  
  0x00050000-0x00250000: kernel
  
  0x00250000-0x03ffc000: root
  
  对于上面的内核信息,/dev/mtdblock2对应root分区,开始地址为0x00250000,使用bootloader写文件系统映象时,烧写的地址必须是0x00250000。
  
  所以,要保证3点:① bootloader烧到地址A,② 地址A是内核某个分区的开始地址,③ 命令行参数“root=/dev/mtdblockXXX ”是这个分区。
  
  (b). 正确格式的文件系统映象
  
  不同的bootloader支持烧写的文件系统映象格式不同、使用的烧写命令也可能不同,请注意这点。另外,马大哈们制作文件系统映象时,使用的工具也不要弄错了。最后,请保证这个文件系统映象是“真的烧写了”,因为如果flash只是擦除而没有烧写,它也是“正确的、可以挂接的文件系统”──有人碰到这个问题,我和他答非所问地折腾了很久。
  
  2. 内核支持这种文件系统格式
  
  配置内核时选上支持的文件系统格式
  
  1、2这两个问题如果不能保证,内核启动时会出现类似如下错误:
  
  VFS: Cannot open root device mtdblock2 or unknown-block(2,0)
  
  Please append a correct root= boot option
  
  如果1、2能保证,就可以挂接上文件系统,出现类似下面的字样时,革命已经成功了80%:
  
  VFS: Mounted root (cramfs filesystem) readonly.
  
  Freeing init memory: 116K
  
  3. 文件系统的内容要完整
  
  挂接文件系统后,内核就会读取、执行文件系统中的某个文件,通过它来启动应用程序。这个文件要么通过命令行参数“init=xxxx”指定,要么取默认的文件(下面说明)。
  
  一般制作文件系统映象时,都是在一个目录(假设目录名为rootfs)下放好各种东西:bin/,sbin/,lib/,etc/fstab等文件,然后将这个目录制作为文件系统映象。
  
  可以想象,如果这个目录中的东西不对、不全,即使制作出了文件系统映象,也只是能识别出来,挂接上去。但是启动不了──所谓启动,不就是执行文件系统中的程序嘛?
  
  这时会有类似以下的错误:
  
  Failed to execute /linuxrc. Attempting defaults…
  
  Kernel panic - not syncing: No init found. Try passing init= optionto kernel
  
  它说得很明显, Failed to execute /linuxrc ──执行/linuxrc失败:
  
  它为什么要执行/linuxrc,还不是因为你在命令行中加入了“init=/linuxrc”这个参数。
  
  它为什么会失败?原因有二:
  
  一、制作文件系统映象时,rootfs目录下有linuxrc文件吗?
  
  二、rootfs目录的linuxrc文件是正确的吗?
  
  请好好确定这两点,大多数是没有linuxrc文件──linuxrc是busybox自动生成,只要配置好就可以。如果有linuxrc,还出现问题,原因就是它无法执行了(解决方法在下面)。
  
  不用linuxrc行不行?当然行!看看内核文件init/main.c,有如 run_init_process(/sbin/init);
  
  run_init_process(/etc/init);
  
  run_init_process(/bin/init);
  
  run_init_process(/bin/sh);
  
  panic(No init found. Try passing init= option to kernel);
  
  就是说,它会依次尝试执行/sbin/init、www.wmyl15.com/ /etc/init、/bin/init、/bin/sh这些文件,都失败后才打印出错信息No init found. Try passing init= option to kernel…
  
  所以,出现这个错误信息,表明没有或是无法执行这些文件:需通过命令行参数“init=xxxx”来指定的xxx文件、/sbin/init、/etc/init、www.wmyl11.com/ /bin/init、/bin/sh。
  
  解决方法:
  
  一、请检查你的rootfs目录,看看这些文件是否存在
  
  二、使用file命令看看它们是什么文件类型,是否可执行。
  
  使用busybox时,linuxrc是/bin/busybox文件的软链接,那就看看busybox的文件类型,可以使用
  
  $ file linuxrc
  
  linuxrc: symbolic link to `bin/busybox’
  
  $ file bin/busybox
  
  1
  
  1
  
  bin/busybox: ELF 32-bit LSB executable, ARM, version 1, for GNU/Linux 2.4.3,dynamically linked (uses shared libs), stripped
  
  注意了:如果bin/busybox 是一个动态链接的文件,还要把它用到的库复制到rootfs中。这些库在交叉编译工具的相应目录下。
  
  最后一点,文件系统中的各种配置文件、dev目录也要正确
  
  回到这个帖子,它的内核打印信息为:
  
  VFS: Mounted root (cramfs filesystem) readonly.
  
  Freeing init memory: 116K
  
  Failed to execute /linuxrc. Attempting defaults...
  
  Kernel panic - not syncing: No init found. Try passing init= optionto kernel
  
  说明文件系统挂接成功(VFS: Mounted root (cramfs filesystem)readonly.);
  
  还说明/linuxrc不存在或者不可执行(Failed www.senta77.com toexecute /linuxrc. Attempting defaults…);
  
  但是楼主的意思是linuxrc已经有了,内容为:
  
  #!/bin/sh
  
  echo mount /etc as ramfs
  
  /bin/mount -n -t ramfs ramfs /etc
  
  /bin/cp -a /mnt/etc/* /etc
  
  echo re-create the /etc/mtab www.caihonyule.com/ entries
  
  #re-create the /etc/mtab entries
  
  /bin/mount -f -t cramfs -o remount,ro /dev/mtdblock/3 /
  
  /bin/mount -f -t ramfs ramfs /etc
  
  exec /sbin/init
  
  它是一个脚本,它的执行依赖于/bin/sh,问题转为:/bin/sh是否存在?是否可以执行?
  
  可以用file命令看看它的类型、是否需要动态库。

挂载文件系统出现"kernel panic..." 史上最全解决方案的更多相关文章

  1. Linux面试题(史上最全、持续更新、吐血推荐)

    文章很长,建议收藏起来,慢慢读! 疯狂创客圈为小伙伴奉上以下珍贵的学习资源: 疯狂创客圈 经典图书 : <Netty Zookeeper Redis 高并发实战> 面试必备 + 大厂必备 ...

  2. Linux记录-史上最全的MySQL高性能优化实战总结(转载)

       史上最全的MySQL高性能优化实战总结! 1.1 前言 MySQL对于很多Linux从业者而言,是一个非常棘手的问题,多数情况都是因为对数据库出现问题的情况和处理思路不清晰.在进行MySQL的优 ...

  3. 开源框架】Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发

    [原][开源框架]Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发,欢迎各位... 时间 2015-01-05 10:08:18 我是程序猿,我为自己代言 原文  http: ...

  4. 史上最全的maven pom.xml文件教程详解

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  5. 优秀后端架构师必会知识:史上最全MySQL大表优化方案总结

    本文原作者“ manong”,原创发表于segmentfault,原文链接:segmentfault.com/a/1190000006158186 1.引言   MySQL作为开源技术的代表作之一,是 ...

  6. 移动端IM开发者必读(二):史上最全移动弱网络优化方法总结

    1.前言 本文接上篇<移动端IM开发者必读(一):通俗易懂,理解移动网络的“弱”和“慢”>,关于移动网络的主要特性,在上篇中已进行过详细地阐述,本文将针对上篇中提到的特性,结合我们的实践经 ...

  7. 史上最全的maven的pom.xml文件详解(转载)

    此文出处:史上最全的maven的pom.xml文件详解——阿豪聊干货 <project xmlns="http://maven.apache.org/POM/4.0.0" x ...

  8. 你想找的Python资料这里全都有!没有你找不到!史上最全资料合集

    你想找的Python资料这里全都有!没有你找不到!史上最全资料合集 2017年11月15日 13:48:53 技术小百科 阅读数:1931   GitHub 上有一个 Awesome - XXX 系列 ...

  9. 史上最全存储引擎、索引使用及SQL优化的实践

    史上最全存储引擎.索引使用及SQL优化的实践 1 MySQL的体系结构概述 2. 存储引擎 2.1 存储引擎概述 2.2 各种存储引擎特性 2.2.1 InnoDB 2.2.2 MyISAM 3. 优 ...

随机推荐

  1. 在centos 7上安装BIMServer

    下载bimserverwar-1.5.85.war https://github.com/opensourceBIM/BIMserver/releases mkdir -p /opt/bim cd / ...

  2. MiniProfiler工具介绍(监控EF生成的SQL语句)--EF,迷你监控器,哈哈哈

    十年河东,十年河西,莫欺少年穷... 今天是抄袭的别人的博客,不过我感觉蛮好,挺有用,特别是老板让你优化EF项目SQL耗时的情况下,你可以采用这种方式来优化你的LINQ. 时间很宝贵,废话还是不多说, ...

  3. 通用漏洞评估方法CVSS3.0简表

    CVSS3.0计算分值共有三种维度: 1. 基础度量. 分为 可利用性 及 影响度 两个子项,是漏洞评估的静态分值. 2. 时间度量. 基础维度之上结合受时间影响的三个动态分值,进而评估该漏洞的动态分 ...

  4. Mvc_model实体数据验证

    MVC提供了很方便的数据验证,只需要在model里加入相关的正则等,那么就会在前台里生成相关的验证脚本.需要引用两个js文件: jquery.validate.min.js jquery.valida ...

  5. 利用Tarjan算法解决(LCA)二叉搜索树的最近公共祖先问题——数据结构

    相关知识:(来自百度百科)  LCA(Least Common Ancestors) 即最近公共祖先,是指在有根树中,找出某两个结点u和v最近的公共祖先. 例如: 1和7的最近公共祖先为5: 1和5的 ...

  6. android studio报Resolved versions for app (26.1.0) and test app (27.1.1)differ. 错误的解决办法

    https://blog.csdn.net/qq_36636969/article/details/80278150

  7. 作业20171102 alpha-review 成绩

    申诉 对成绩有疑问或不同意见的同学,请在群里[@杨贵福]. 申诉时间截止2017年12月12日 17:00. 成绩 review NABCD-评论 SPEC-评论 例行报告 附加分数 合计 本周归一化 ...

  8. [BUAA-SE-2018]结对作业测试报告

    目录 1. 测试方式 2. 评分规则 2.1 测试点组成 2.2 性能测试的分级 2.3 重新提交的扣分策略 3. 评测结果 3.1 罗老师班 3.2 任老师班 3.3 表中数据的说明 4. 测试点下 ...

  9. Linux内核分析— —扒开系统调用的三层皮(上)

    实验部分 根据系统调用表,选取一个系统调用.我选得是mkdir这个系统调用,其系统调用号为39,即0x27 由于mkdir函数的原型为int mkdir (const char *filename, ...

  10. docker网络调试过程

    #1: 添加永久网桥 vi /etc/sysconfig/network-scripts/ifcfg-br0 DEVICE=br0 TYPE=Bridge BOOTROTO=static IPADDR ...