溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何進(jìn)行l(wèi)inux內(nèi)核模塊調(diào)試

發(fā)布時(shí)間:2022-01-07 15:46:07 來源:億速云 閱讀:174 作者:柒染 欄目:系統(tǒng)運(yùn)維

這篇文章將為大家詳細(xì)講解有關(guān)如何進(jìn)行l(wèi)inux內(nèi)核模塊調(diào)試,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

1. 開啟虛擬機(jī),虛擬機(jī)運(yùn)行到 kgdb: Waiting for connection from remote gdb

2. 在Host機(jī)上運(yùn)行: socat tcp-listen:8888 /tmp/vbox2, 其中/tmp/vbox2為管道文件,它是目標(biāo)機(jī)串口的重定向目的文件,socat將這個(gè)管道文件又重定向到tcp socket的8888端口。

3. 開啟一個(gè)新的虛擬終端,cd path/to/kernel/source/tree, 然后執(zhí)行g(shù)db ./vmlinux

輸出

GNU gdb 6.8-debian

Copyright (C) 2008 Free Software Foundation, Inc.

License GPLv3+: GNU GPL version 3 or later

This is free software: you are free to change and redistribute it.

There is NO WARRANTY, to the extent permitted by law.  Type "show copying"

and "show warranty" for details.

This GDB was configured as "i486-linux-gnu"...

(gdb) set-remote

set remote baud rate to 115200c/s

set remote target to local tcp socket

kgdb_breakpoint () at kernel/kgdb.c:1721

1721        wmb(); /* Sync point after breakpoint */

(gdb) c

Continuing.

目標(biāo)機(jī)會(huì)一直啟動(dòng),直到提示輸入用戶名密碼。

4. 進(jìn)入目標(biāo)機(jī),輸入用戶名密碼(推薦使用字符界面下的root用戶),輸入g命令,目標(biāo)機(jī)被斷下,控制移交到Host機(jī)中的gdb中。(目標(biāo)機(jī)root的用戶目錄中的.bashrc中添加一行alias g='echo g>/proc/sysrq-trigger')

5. 在Host機(jī)中的gdb中

(gdb) set-mod-break

set breakpoint in system module init function

Breakpoint 1 at 0xc014bac5: file kernel/module.c, line 2288.

(gdb) c

Continuing.

6. 在目標(biāo)機(jī)中

insmod klogger2.ko

目標(biāo)機(jī)再次斷下,控制權(quán)移交Host機(jī)中的gdb

7. 在Host機(jī)中的gdb中

[New Thread 4693]

[Switching to Thread 4693]

Breakpoint 1, sys_init_module (umod=0x0, len=0, uargs=0x0)

at kernel/module.c:2288

2288        if (mod->init != NULL)

(gdb) print-mod-segment

Name:.note.gnu.build-id Address:0xdf977058

Name:.text Address:0xdf975000

Name:.rodata Address:0xdf977080

Name:.rodata.str1.4 Address:0xdf9774b4

Name:.rodata.str1.1 Address:0xdf977522

Name:.parainstructions Address:0xdf977a00

Name:.data Address:0xdf978440

Name:.gnu.linkonce.this_module Address:0xdf978480

Name:.bss Address:0xdf978a00

Name:.symtab Address:0xdf977a08

Name:.strtab Address:0xdf978078

(gdb) add-symbol-file /home/done/programs/linux-kernel/vlogger/klogger2.ko 0xdf975000 -s .data 0xdf978440 -s .bss 0xdf978a00

add symbol table from file "/home/done/programs/linux-kernel/vlogger/klogger2.ko" at

.text_addr = 0xdf975000

.data_addr = 0xdf978440

.bss_addr = 0xdf978a00

(y or n) y

Reading symbols from /home/done/programs/linux-kernel/vlogger/klogger2.ko...done.

(gdb) b hook_init

Breakpoint 2 at 0xdf976d19: file /home/done/programs/linux-kernel/vlogger/hook.c, line 255.

(gdb)

你可以調(diào)試自己些的LKM模塊了

附gdb的初始化配置文件~/.gdbinit

define set-remote

echo set remote baud rate to 115200c/s\n

set remotebaud 115200

echo set remote target to local tcp socket\n

target remote tcp:localhost:8888

end

define set-mod-break

echo set breakpoint in system module init function\n

break kernel/module.c:2288

end

define print-mod-segment

set $sect_num=mod->sect_attrs->nsections

set $cur=0

while $cur < $sect_num

printf "Name:%-s Address:0x%x\n",mod->sect_attrs->attrs[$cur]->name,mod->sect_attrs->attrs[$cur]->address

set $cur=$cur+1

end

end

后記:gdb的調(diào)試腳本真難寫,簡(jiǎn)單的字符串變量連接和等價(jià)判斷都顯得十分困難,不知道是我水平太差還是gdb的腳本功能太弱,總之比起Windbg來說,內(nèi)核調(diào)試?yán)щy程度上了個(gè)等級(jí)。

關(guān)于如何進(jìn)行l(wèi)inux內(nèi)核模塊調(diào)試就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI