内核文档Documentation/admin-guide/init.rst对此问题有做解释。
加载初始化二进制文件失败的一些高级原因(大致按执行顺序列出)如下:
A)无法挂载根FS
B)rootfs上不存在初始化二进制文件
C)控制台设备损坏
D)二进制文件存在但依赖项不可用
E)无法加载二进制文件
以上各问题的详细分析方法说明如下:
A)设置“调试”内核参数(在引导程序配置文件或CONFIG_CMDLINE中)以获取更详细的内核消息。
如在grub的linux命令行后加上loglevel=7.
B)确保您具有正确的根FS类型(传递给内核的root参数指向正确的分区),所需的驱动程序,例如存储硬件(例如SCSI或USB!)和文件系统(ext3,jffs2等)。 )是内置的(或者作为模块,由initrd预先加载)
C)’‘console = setup’’->initial console可能不可用。
例如,由于串行IRQ问题(例如,缺少基于中断的配置),某些串行控制台不可靠。
尝试使用其他“ console =设备”或“ netconsole =”。
D)例如,初始化二进制文件所需的库依赖项,例如“ /lib/ld-linux.so.2”丢失或损坏。使用“ readelf -d < INIT >|grep NEEDED”来找出需要哪些库。
E)确保二进制文件的体系结构与您的硬件匹配。
例如,i386与x86_64不匹配,或者试图在ARM硬件上加载x86。
如果您尝试在此处加载非二进制文件(shell脚本?),则应确保该脚本在其shebang标头行(``#!/ …’’)中指定了一个可以正常运行的解释器(包括其库依赖性)。在处理脚本之前,最好先测试一个简单的非脚本二进制文件,例如“ / bin / sh”,并确认其成功执行。
要了解更多信息,请在init / main.c中添加代码以显示kernel_execve()的返回值。