本文信息

CSDN GitHub
Linux Kernel PANIC(一)–概述(Hard Panic/Aieee和Soft Panic/Oops) LDD-LinuxDeviceDrivers/study/debug/modules/panic/01-kernel_panic

同类博文信息

CSDN GitHub
Linux Kernel PANIC(一)–概述(Hard Panic/Aieee和Soft Panic/Oops) LDD-LinuxDeviceDrivers/study/debug/modules/panic/01-kernel_panic
Linux Kernel PANIC(二)–Hard Panic/Aieee实例分析 LDD-LinuxDeviceDrivers/study/debug/modules/panic/02-hard_panic
Linux Kernel PANIC(三)–Soft Panic/Oops调试及实例分析 LDD-LinuxDeviceDrivers/study/debug/modules/panic/03-soft_panic


本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可, 转载请注明出处

1 Kernel PANIC/OOPS


wiki:A kernel panic is an action taken by an operating system upon detecting an internal fatal error from which it cannot safely recover. The term is largely specific to Unix and Unix-like systems; for Microsoft Windowsoperating systems the equivalent term is “Bug check” (or, colloquially, “Blue Screen of Death“).
The kernel routines that handle panics (in AT&T-derived and BSD Unix source code, a routine known as panic()) are generally designed to output an error message to the console, dump an image of kernel memory to disk for post-mortemdebugging and then either wait for the system to be manually rebooted, or initiate an automatic reboot. The information provided is of highly technical nature and aims to assist a system administrator or software developer in diagnosing the problem.
Attempts by the operating system to read an invalid or non-permitted memory address are a common source of kernel panics. A panic may also occur as a result of a hardware failure or a bug in the operating system. In many cases, the operating system could continue operation after memory violations have occurred. However, the system is in an unstable state and rather than risking security breaches and data corruption, the operating system stops to prevent further damage and facilitate diagnosis of the error.
The kernel panic was introduced in an early version of Unix and demonstrated a major difference between the design philosophies of Unix and its predecessor Multics. Multics developer Tom van Vleck recalls a discussion of this change with Unix developer Dennis Ritchie:
I remarked to Dennis that easily half the code I was writing in Multics was error recovery code. He said, “We left all that stuff out. If there’s an error, we have this routine called panic, and when it is called, the machine crashes, and you holler down the hall, ‘Hey, reboot it.’”[1]
The original panic() function was essentially unchanged from Fifth Edition UNIX to the VAX-based UNIX 32V and output only an error message with no other information, then dropped the system into an endless idle loop. As the Unixcodebase was enhanced, the panic() function was also enhanced to dump various forms of debugging information to the console.

1.1 什么是 Kernel PANIC


panic 是英文中是惊慌的意思, Linux Kernel panic 正如其名, Linux Kernel 不知道如何走了, 它会尽可能把它此时能获取的全部信息都打印出来, 为开发人员调试提供帮助.

有两种主要类型 Kernel panic

  • Hard Panic(也就是Aieee信息输出)

  • Soft Panic(也就是Oops信息输出)

1.2 什么会导致Linux Kernel Panic


只有加载到内核空间的驱动模块才能直接导致 kernel panic, 你可以在系统正常的情况下, 使用 lsmod 查看当前系统加载了哪些模块. 除此之外, 内建在内核里的组件(比如 memory map等)也能导致panic.

常见Linux Kernel Panic报错内容

Kernel panic-not syncing fatal exception in interrupt
kernel panic – not syncing: Attempted to kill the idle task!
kernel panic – not syncing: killing interrupt handler!
Kernel Panic – not syncing:Attempted to kill init !

一般出现下面的情况,就认为是发生了 kernel panic :

  • 机器彻底被锁定,不能使用

  • 数字键(Num Lock),大写锁定键(Caps Lock),滚动锁定键(Scroll Lock)不停闪烁。

  • 如果在终端下,应该可以看到内核dump出来的信息(包括一段”Aieee”信息或者”Oops”信息)

  • 和Windows蓝屏相似

因为 hard panicsoft panic 本质上不同,因此我们分别讨论.

2 hard panic


对于 hard panic 而言, 最大的可能性是驱动模块的中断处理(interrupt handler)导致的, 一般是因为驱动模块在中断处理程序中访问一个空指针(null pointer).

一旦发生这种情况,驱动模块就无法处理新的中断请求,最终导致系统崩溃.

2.1 原因


对于 hard panic 而言,最大的可能性是驱动模块的中断处理(interrupt handler)导致的,一般是因为驱动模块在中断处理程序中访问一个空指针(null pointre).

一旦发生这种情况, 驱动模块就无法处理新的中断请求, 最终导致系统崩溃.

2.2 信息收集


根据 panic 的状态不同, 内核将记录所有在系统锁定之前的信息. 因为 kenrel panic 是一种很严重的错误, 不能确定系统能记录多少信息, 下面是一些需要收集的关键信息, 他们非常重要,因此尽可能收集全,当然如果系统启动的时候就kernel panic,那就无法只知道能收集到多少有用的信息了。

  1. /var/log/messages, 幸运的时候, 整个 kernel panic 栈跟踪信息都能记录在这里. 要确认是否有一个足够的栈跟踪信息,你只要查找包含”EIP”的一行, 它显示了是什么函数和模块调用时导致panic.

  2. 应用程序/库 日志: 可能可以从这些日志信息里能看到发生 panic 之前发生了什么。

  3. 其他发生 panic 之前的信息, 或者知道如何重现panic那一刻的状态

  4. 终端屏幕 dump信息, 一般 OS被锁定后, 复制, 粘贴肯定是没戏了, 因此这类信息, 你可以需要借助数码相机或者原始的纸笔工具了.

如果 kernel dump 信息既没有在 /var/log/message 里, 也没有在屏幕上, 那么尝试下面的方法来获取(当然是在还没有死机的情况下).

  1. 如果在图形界面,切换到终端界面,dump信息是不会出现在图形界面的,甚至都不会在图形模式下的虚拟终端里.

  2. 确保屏幕不黑屏,可以使用下面的几个方法:

    setterm -blank 0
    setterm -powerdown 0
    setvesablank off
  3. 从终端,拷贝屏幕信息

2.3 排查方法


栈跟踪信息(stack trace)是排查 kernel panic 最重要的信息, 该信息如果在/var/log/messages日志里当然最好,因为可以看到全部的信息,如果仅仅只是在屏幕上,那么最上面的信息可能因为滚屏消失了,只剩下栈跟踪信息的一部分。如果你有一个完整栈跟踪信息的话,那么就可能根据这些充分的信息来定位panic的根本原因。要确认是否有一个足够的栈跟踪信息,你只要查找包含”EIP”的一行,它显示了是什么函数和模块调用时导致panic

使用内核调试工具(kenrel debugger ,aka KDB)
如果跟踪信息只有一部分且不足以用来定位问题的根本原因时, kernel debugger(KDB)就需要请出来了。

KDB编译到内核里,panic发生时,他将内核引导到一个shell环境而不是锁定。这样,我们就可以收集一些与panic相关的信息了,这对我们定位问题的根本原因有很大的帮助。

3 soft panic


  1. 症状没有 hard panic严重

  2. 通常导致段错误(segmentation fault)

  3. 以看到一个 oops 信息, /var/log/messages里可以搜索到’Oops’.

  4. 机器稍微还能用(但是收集信息后,应该会重启系统).

3.1 原因


凡是非中断处理引发的模块崩溃都将导致 soft panic

在这种情况下, 驱动本身会崩溃, 但是还不至于让系统出现致命性失败, 因为它没有锁定中断处理例程. 导致 hard panic的原因同样对soft panic也有用(比如在运行时访问一个空指针).

3.2 信息收集


soft panic发生时, 内核将产生一个包含内核符号(kernel symbols)信息的 dump数据, 这个将记录在/var/log/messages里.

3.3 排查方法


为了开始排查故障, 可以使用 ksymoops 工具来把内核符号信息转成有意义的数据.

为了生成ksymoops文件,需要

  • /var/log/messages 里找到的堆栈跟踪文本信息保存为一个新文件。确保删除了时间戳(timestamp),否则 ksymoops 会失败.

  • 运行 ksymoops 程序(如果没有,请安装)
    详细的ksymoops执行用法,可以参考ksymoops(8)手册。

Oops 可以看成是内核级的 Segmentation Fault.

  • 应用程序如果进行了非法内存访问或执行了非法指令, 会得到 Segfault 信号, 一般的行为是 coredump, 应用程序也可以自己截获Segfault 信号,自行处理

  • 如果内核自己犯了这样的错误, 则会打出 Oops 信息.

处理器使用的所有地址几乎都是通过一个复杂的页表结构对物理地址映射而得到的虚拟地址(除了内存管理子系统自己所使用的物理地址)。当一个非法的指针被废弃时,内存分页机制将不能为指针映射一个物理地址,处理器就会向操作系统发出一个页故障信号。如果地址不合法,那么内核将不能在该地址“布页”;这时如果处理器处于超级用户模式,内核就会生成一条oops消息。

4 参考资料


根据内核Oops 定位代码工具使用— addr2line 、gdb、objdump

转载_Linux内核OOPS调试

kernel panic/kernel oops分析

DebuggingKernelOops

kerneloops package in Ubuntu

Understanding a Kernel Oops!

Kernel oops错误

Kernel Oops Howto

Kernel Panics

WiKipedia

Oops中的error code解释

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可

Linux Kernel PANIC(一)--概述(Hard Panic/Aieee和Soft Panic/Oops)相关推荐

  1. linux kernel fuzzing test - 概述

    了解Fuzzing 1.Introduction   Fuzz本意是"羽毛.细小的毛发.使模糊.变得模糊",后来用在软件测试领域,中文一般指"模糊测试",英文有 ...

  2. Linux kernel Panic后自动重启机器的设置

    Linux kernel Panic后自动重启机器的设置 方法1:内核配置命令行加入这句,崩溃后3秒重启: panic=3 make menuconfig 设置kernel系统参数: 方法2: vi ...

  3. Linux kernel panic 问题解决方案

    ===================================================== arm linux系统启动相关文章列表: arm linux系统启动流程 http://bl ...

  4. Linux kernel panic问题解决方法

    kernel panic错误表现 kernel panic 主要有以下几个出错提示: Kernel panic-not syncing fatal exception in interrupt ker ...

  5. Linux Kernel Panic报错解决思路

    Linux虽然没有蓝屏现象,不过Kernel报错有时也会让人头疼.有时重启后正常,linux系统运行一段时间后又down了,总不能出现问题就reboot啊.我从网上搜集一下资料,整理了出来,希望大家能 ...

  6. Linux kernel panic解决方法

    Linux kernel panic解决方法 kernel panic错误表现 kernel panic 主要有以下几个出错提示: Kernel panic-not syncing fatal exc ...

  7. linux 文件系统 panic,Linux kernel panic解决方法

    Linux kernel panic解决方法 kernel panic错误表现 kernel panic 主要有以下几个出错提示: Kernel panic-not syncing fatal exc ...

  8. linux kernel panic not syncing 永久解决的方案

    linux kernel panic not syncing 永久解决的方案 相信第一次使用Linux的朋友可能会遇到这样的问题,因为我就遇到了,直到学<Linux从入门到精通(微课视频版)&g ...

  9. 根据epc和ra定位linux kernel panic或者应用程序的出错位置

    根据epc和ra定位linux kernel panic或者应用程序的出错位置 一.背景 项目中出现了死机的问题,不幸的是没有保存下来coredump文件,只有简要的epc和ra信息.尝试复现问题,一 ...

最新文章

  1. BCH将拥有远超过BTC的“最佳货币”体验
  2. python在当前目录创建txt文件-python-在目录中创建多个文本文件的字数字...
  3. POJ2239简单二分匹配
  4. .NET Core的文件系统[3]:由PhysicalFileProvider构建的物理文件系统
  5. 2.4.3 死锁的处理策略-避免死锁
  6. WPF 获取屏幕分辨率(获取最大宽高)等
  7. Angularjs 设置全局变量的3种方法
  8. pytorch 查看中间变量的梯度
  9. Qt学习笔记(持续更新)
  10. java 反射静态内部类_android-反射的使用(反射静态内部类、非静态内部类、匿名内部类等)...
  11. 一个简单python爬虫的实现——爬取电影信息
  12. MSSQLSERVER数据库- 使用C#来操作事务[转]
  13. 希尔排序增量怎么确定_Python实现希尔排序(已编程实现)
  14. java DTO循环_Java Stream与for循环比较
  15. 四阶段法-交通分布预测方法-算法复现
  16. directadmin php-fpm,Directadmin + Nginx + php fpm + location:找不到文件
  17. 受够了百度网盘?如何注册无限容量的Google Drive网盘
  18. 解决微信小程序内下载视频失败wx.saveVideoToPhotosAlbum :fail invalid video
  19. Linux 4.15亮点特性
  20. 00.关于Android开发的任务分工

热门文章

  1. Process finished with exit code 137 (interrupted by signal 9: SIGKILL)错误
  2. 计算机开机显示屏节能,电脑显示屏显示节能模式怎么处理
  3. cesium实现流入迁徙图(仿echarts)(着色器)(cesium篇.52)
  4. 亚马逊云科技中国北京区域推出Amazon CloudTrail服务
  5. vba工作表重命名_如何在Excel中重命名工作表选项卡
  6. http请求包与请求返回的是什么
  7. C、C++、JAVA
  8. antd右侧菜单栏点击更换icon
  9. 自动生成了个登录界面
  10. 惊呆了!692分的学霸都想当程序员,理由居然是