我有一个带有处理器 AT91SAM9G45 的嵌入式 ARM 系统。我尝试为这个系统用 initramfs 构建 linux 内核。内核版本为4.14.79。
在设备上加载内核和 initramfs 镜像后,我有以下内容:
内核一定会找到 initramfs 镜像,将其解压缩并设置到内存中。
内核定义找到 initramfs 镜像中的所有文件,我在添加到 linux 内核源代码中的调试消息中看到了它。
解压 initramfs 镜像内核后尝试启动/init 进程。/init 进程启动并立即返回 0(0 表示没有错误),然后立即抛出内核 panic 消息:
Freeing unused kernel memory: 384K
This architecture does not have kernel memory protection.
run_init_process BEFORE /init
run_init_process AFTER /init, result = 0
Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000004
“run_init_process_BEFORE/init”和“run_init_process/init, result = 0”是我添加到 linux 源代码中的调试消息。
Initramfs 镜像是使用 busybox 构建的。
没有区别,我尝试启动的初始脚本或可执行文件。结果是一样的。如果/init 脚本尝试回显某些消息并休眠几秒钟,内核不会显示消息也不等待,并立即抛出 panic 消息。
所以我静态编译了这个简单的程序并尝试启动它:
#include <stdio.h>
int main(int argc, char *argv)
{
printf("Hello world!\n");
sleep(999999999);
}
相同的结果,没有“Hello world!”没有 sleep :
Freeing unused kernel memory: 384K
This architecture does not have kernel memory protection.
run_init_process BEFORE /hello
run_init_process AFTER /hello, result = 0
Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000004
如果我用 x86_64 gcc 编译器编译这个程序,结果是 -8:
Same result, with no "Hello world!" and sleeping:
Freeing unused kernel memory: 384K
This architecture does not have kernel memory protection.
run_init_process BEFORE /hello
run_init_process AFTER /hello, result = -8
Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000004
也就是说linux内核定义了文件在当前平台下是否可执行。
如果我在没有静态链接的情况下编译 hello.c 程序,结果是 -2(之后是内核崩溃消息)。如果我将 .so 文件放入/lib 文件夹中的 initramfs 镜像,结果为 0,然后出现内核崩溃消息。如果我放入用 x86_64 编译器编译的 .so 文件,结果是 -13,然后是内核崩溃消息。
那么这个消息的原因是什么?我找不到它。
最佳答案
退出代码是您将从 wait() 中获得的内容。挖掘 WEXITSTATUS 和 WTERMSIG 定义,这意味着程序从信号 4 以状态 0 退出。 4 是 SIGILL - 非法指令。
所以 init 程序有问题 - 它已损坏,或者处理器类型错误,或类似的问题。
它试图执行导致处理器调用“非法指令”异常的代码。内核尽职尽责地看到了这一点,并用 SIGILL 杀死了有问题的程序。然后它注意到这是 init
并且因为现在没有任何东西可以运行而 panic 。
关于linux-kernel - 在/init 之后退出代码 = 0x00000004 的内核 panic ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54303119/