ARM Linux崩溃分析(三) - 内核崩溃的实例分析

本文详细介绍了在ARM Linux系统中遇到内核崩溃的情况,特别是空指针异常的问题。通过分析出错信息确定错误源于非法地址访问,即空指针。接着,文章探讨了如何利用Oops信息进行栈回溯,查找函数调用关系,以理解错误源头。在没有CONFIG_FRAME_POINTER配置的情况下,需要手动解析栈信息。文中还阐述了栈在函数调用中的作用,以及如何通过栈回溯找到函数调用链。最后,提供了一种在内核未配置CONFIG_FRAME_POINTER时,通过反汇编地址来定位问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

测试代码如下:

#include <linux/compat.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/device.h>
#include <linux/pci.h>
#include <linux/fs.h>
#include <linux/poll.h>
#include <linux/interrupt.h>
#include <linux/cdev.h>
#include <linux/slab.h>
#include <linux/phantom.h>

static void test_crash(void)
{
   
	char *pstr = NULL;
	printk("drivr crash \n");
	*pstr = 12;
	printk("%s \n",pstr);
	return;
}

static int __init test_init(void)
{
   
	printk("drivr test \n");
	
	test_crash();
	return  0;
}


static void __exit test_exit(void)
{
   
	
	printk("drivr exit   \n");
	return ;
}


module_init(test_init);
module_exit(test_exit);

MODULE_AUTHOR("Alex<free5home5@163.com>");
MODULE_LICENSE("GPL");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值