linux 核心崩潰處理
阿新 • • 發佈:2019-01-10
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的函式
以此類推,可以得到呼叫流程