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

标签 linux-kernel arm embedded-linux panic

我有一个带有处理器 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/

相关文章:

linux - 当 CONFIG_IKCONFIG 设置为模块(=m)时,如何从内核镜像文件中提取配置?

C函数关闭linux系统

linux - 无法从串行端口 ttymxc 读取数据

linux - 使用 GDB 生成核心转储文件时如何限制其大小

linux - 模糊测试 Linux 内核 : A student in peril.

在 linux 内核中使用 sprintf 将字符串转换为 int

c - Neon 相当于 SSE 内在函数

linux - 内核必须在上下文切换之间保存什么内存 "state"?

c - device_create 使用现有设备名称

c - U-Boot 2020.04 : Probing SPI flash fails - Invalid bus 0 (err=-19)