gpt4 book ai didi

linux-kernel - 在/init 之后退出代码 = 0x00000004 的内核 panic

转载 作者:行者123 更新时间:2023-12-05 01:16:08 26 4
gpt4 key购买 nike

我有一个带有处理器 AT91SAM9G45 的嵌入式 ARM 系统。我尝试为这个系统用 initramfs 构建 linux 内核。内核版本为4.14.79。

在设备上加载内核和 initramfs 镜像后,我有以下内容:

  1. 内核一定会找到 initramfs 镜像,将其解压缩并设置到内存中。

  2. 内核定义找到 initramfs 镜像中的所有文件,我在添加到 linux 内核源代码中的调试消息中看到了它。

  3. 解压 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com