加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

如何在Linux内核代码中生成内核oops或panic崩溃?

发布时间:2020-12-14 01:15:39 所属栏目:Linux 来源:网络整理
导读:如何在内核代码中生成内核oops或崩溃?有功能吗? 解决方法 崩溃内核的常用方法是使用BUG()宏.还有WARN()宏,它将堆栈转储到控制台但内核仍在运行. http://kernelnewbies.org/FAQ/BUG 在内核命中BUG()宏(最终导致内部陷阱)或某些类似的错误条件(如空指针解除
如何在内核代码中生成内核oops或崩溃?有功能吗?

解决方法

崩溃内核的常用方法是使用BUG()宏.还有WARN()宏,它将堆栈转储到控制台但内核仍在运行.

http://kernelnewbies.org/FAQ/BUG

在内核命中BUG()宏(最终导致内部陷阱)或某些类似的错误条件(如空指针解除引用)后,会发生什么情况取决于panic_on_oops全局变量的设置.如果它设置为0,内核将尝试继续运行(带来任何可怕的后果).如果它设置为1,内核将进入恐慌状态并停止.

如果你想从用户空间崩溃内核,你就得到了一个方便的< SysRq> &LT c取代; key combo(或者,echo c> / proc / sysrq-trigger).值得查看此操作的处理程序实现(http://code.metager.de/source/xref/linux/stable/drivers/tty/sysrq.c#134):

static void sysrq_handle_crash(int key)
{
    char *killer = NULL;

    panic_on_oops = 1;  /* force panic */
    wmb();
    *killer = 1;
}

处理程序设置全局标志以对陷阱进行内核恐慌,然后尝试取消引用随机空指针.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读