1. 程式人生 > >linux 核心崩潰處理

linux 核心崩潰處理

pc : [<bf0000b8]

1.定位程式碼崩潰在核心中還是xxx.ko

cat  /proc/kallsyms >1.txt

c0034818 T __kmalloc

...

c00082a8 t quiet_kernel /*最開始的是虛擬地址*/

...

bf000000  t $a [cdd]

..

由此可看程式碼崩潰在xxx.ko

2.定位崩潰在xxx.ko中的哪個函式

arm-linux-objdump -D cdd.ko >2.txt

00000000 <cdd_llseek>

0:e1a0c00d mov ip,sp //編譯地址,編譯後的指令,組合語言

編譯地址+0xbf000000 = 存放地址

0000009c <cdd_open>

9c:e1a0c00dmov ip,sp

a0:e92dd8f0push {r4,r5,r6,r7,fp,ip,lr,pc}

...

b8:e5c43000strbr3,[r4] ------此處出現問題

由此知道崩潰在cdd_open函式

3. 反彙編核心程式碼瞭解cdd_open被呼叫流程

arm-linux-objdump -D vmlinux >3.txt

cdd_open壓棧,push {r4,r5,r6,r7,fp,ip,lr,pc}

這8個數據就是你要壓的資料,lr暫存器的值是函式呼叫完要返回的地址

根據lr,檢視上一次呼叫cdd_open的函式

以此類推,可以得到呼叫流程