linux驱动调试--段错误之oops信息分析

1. 分析coredump打印信息

2. 确定发生错误的函数

看发生错误的地方的函数和pc

PC is at segment_test_open+0x14/0x1c [segdrv]

看pc值:

pc : [<7f000014>]    lr : [<800d958c>]    psr: 20070013

看Backtrace:

[<7f000014>] (segment_test_open [segdrv]) from [<800d958c>] (chrdev_open+0xa4/0x178)
[<800d958c>] (chrdev_open) from [<800d3e1c>] (do_dentry_open.isra.17+0x110/0x294)

一、直接确定发生错误的函数
看到这句 “PC is at segment_test_open+0x14/0x1c [segdrv]”,出现错误时我们最关注的就是PC值,因为它就是发生错误
的指令的地址,这里我们可以看到错误发生在函数 segment_test_open 的0x14处,0x1c代表这个函数的总长度(汇编代码)

二、根据PC值确定发生错误的函数
有时候不会直接告诉你发生在哪个函数,而是只把PC值告诉你

如果发生的错误函数是属于驱动模块的

# arm-none-linux-gnueabi-objdump -D first_drv.ko > first_drv.dis

如果发生的错误函数是属于内核的
这个时候和发生在模块里类似,不过这里要反汇编整个内核:
# arm-none-linux-gnueabi-objdump -D vmlinux > vmlinux.dis
在gdb下键入命令 : list *atmel_tasklet_func+(LR行的提示)

猜你喜欢

转载自blog.csdn.net/XU18829898203/article/details/84987832
今日推荐