Posted on 2011-04-02 20:37
S.l.e!ep.¢% 閱讀(1184)
評(píng)論(0) 編輯 收藏 引用 所屬分類:
Unix
* 反匯編一個(gè)函數(shù)
disass func_name
*反匯編一段內(nèi)存地址, 第1個(gè)參數(shù)是起始地址,第2個(gè)是終止地址
disassemble 0×0 0×10
*?info line 命令來(lái)映射一個(gè)源碼行到程序地址,
然后使用命令disassemble顯示一個(gè)地址范圍的機(jī)器指令。
例1. 查看main函數(shù)從哪里開始
(gdb) info line main
Line 34 of “rank.c” starts at address 0×804847f
???and ends at 0×8048493 .
例2.?
(gdb) info line *0×804847f
Line 34 of “rank.c” starts at address 0×804847f
???and ends at 0×8048493 .
info line會(huì)修改 x/i 命令的默認(rèn)的起始地址
* disassemble?
不帶參數(shù),默認(rèn)的反匯編范圍是 所選擇幀的pc附近的函數(shù)
單個(gè)參數(shù), 就是pc, 當(dāng)然也可以是函數(shù)名,因?yàn)楹瘮?shù)名 也是一個(gè) 地址; 這樣范圍就是該pc附近的函數(shù)
兩個(gè)參數(shù),就是內(nèi)存地址范圍
* set disassembly-flavor intel??
將匯編指令格式 設(shè)置為intel格式,默認(rèn)是att
(gdb) show disassembly-flavor
The disassembly flavor is “att”.
* 使用x查看反匯編指令
x/3i $pc
顯示pc開始的3條指令