[轉] GDB disassemble


前面幾篇談GDB調試程序的帖子,都對反匯編語焉不詳。這里詳細討論一下disassemble/disass命令

反匯編一個函數
disass func_name

反匯編一段內存地址, 第1個參數是起始地址,第2個是終止地址
disassemble 0×0 0×10

先看看文檔 Debugging with GDB
http://sourceware.org/gdb/download/onlinedocs/gdb.html
源碼和機器碼
可以使用 info line 命令來映射一個源碼行到程序地址,然后使用命令disassemble顯示一個地址范圍的機器指令。
比如,我要查看main函數從哪里開始

(gdb) info line main
Line 34 of “rank.c” starts at address 0x804847f
and ends at 0×8048493 .
(gdb) info line *0x804847f
Line 34 of “rank.c” starts at address 0x804847f
and ends at 0×8048493 .
並且,info line會修改 x/i 命令的默認的起始地址

disassemble 不帶參數,默認的反匯編范圍是 所選擇幀的pc附近的函數
單個參數, 就是pc, 當然也可以是函數名,因為函數名 也是一個 地址; 這樣范圍就是該pc附近的函數
兩個參數,就是內存地址范圍

set disassembly-flavor intel 將匯編指令格式 設置為intel格式,默認是att
(gdb) show disassembly-flavor
The disassembly flavor is “att”.

下斷點:

b *0x00007fffab642

查看 反匯編指令的另一個方法就是使用x
x/3i $pc

x/100u $pc
顯示pc開始的3條指令

單步執行:

si

單行執行:

ni

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM