新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 嵌入式Linux二進(jìn)制調(diào)試工具

嵌入式Linux二進(jìn)制調(diào)試工具

作者: 時(shí)間:2016-10-08 來源:網(wǎng)絡(luò) 收藏

Linux 系統(tǒng)中有大量的工具可用于 ELF 文件的二進(jìn)制調(diào)試,常用的工具在 GNU binutils 包中可以找到,注意你可能需要這些工具的 x86 版本和 arm 版本,以便在調(diào)試環(huán)境中能夠調(diào)試 x86 ELF 文件和 arm ELF 文件——與交叉編譯器 arm-linux-gcc 類似,我們需要所謂的“交叉調(diào)試工具”,你可以通過互聯(lián)網(wǎng)下載別人已經(jīng)編譯好的 crosstool ,或者自己重新編譯( configure 時(shí)指 ——target=arm-linux )。

本文引用地址:http://butianyuan.cn/article/201610/305945.htm

GNU binutils 包在 GNU 的官方網(wǎng)站提供下載: http://www.gnu.org/software/binutils/ ,特別的,更多跟 arm 相關(guān)的信息和工具可以看看 gnu arm 網(wǎng)站: http://www.gnuarm.org/ .我們將常用的 ELF 調(diào)試工具歸納介紹如下。由于這些工具的 x86 版本和 arm 版本使用起來基本沒有區(qū)別,這里也不作區(qū)分。讀者在使用的時(shí)候請(qǐng)根據(jù)使用對(duì)象的類型(用 FILE 命令查看)自行區(qū)分。? AR用來建立、修改、提取靜態(tài)庫文件。靜態(tài)庫文件包含多個(gè)可重定位目標(biāo)文件,其結(jié)構(gòu)保證了可以恢復(fù)原始目標(biāo)文件內(nèi)容。比如:$ gcc –c file1.c file2.c $ ar rcs libxx.a file1.o file2.o這里我們先用 gcc 編譯得到 file1.o file2.o 兩個(gè)目標(biāo)文件,然后用 ar 命令生成靜態(tài)庫 libxx.a .當(dāng)你希望查看靜態(tài)庫中包含了哪些目標(biāo)文件時(shí),可以用選項(xiàng) -x 解開靜態(tài)庫文件:$ ar x libxx.a

? NM列出目標(biāo)文件的符號(hào)表中定義的符號(hào)。常見的鏈接或者運(yùn)行時(shí)發(fā)生的 unresolved symbol 類型的錯(cuò)誤可以用 NM 來輔助調(diào)試。比如用 NM 結(jié)合 GREP 來查看變量或函數(shù)是否被定義或引用:$ nm [xx.o, or yy.a, or zz.so] | grep [your symbol]對(duì)于 C++ 程序,可以使用選項(xiàng) -C 來進(jìn)行所謂的 demangle —— C++ 編譯器一般會(huì)將變量名或函數(shù)名進(jìn)行修飾 (mangle) ,加上類信息、參數(shù)信息等,變成比較難以辨認(rèn)的符號(hào),而 -C 選項(xiàng)的 demangle 則可將其恢復(fù)為比較正常的符號(hào)。比如下面很簡單的 C++ 程序:#include

int main()

{ std::coutHello World!

U std::basic_ostream

U std::ios_base::Init::Init[in-charge]()

U std::ios_base::Init::~Init [in-charge]()

U std::cout U std::basic_ostream

00000000 b std::__ioinit U std::basic_ostream

U __cxa_atexit U __dso_handle U __gxx_personality_v0 0000007c t __tcf_0 00000000 T main -C 選項(xiàng)在其他一些二進(jìn)制調(diào)試工具中也有提供,使用 C++ 開發(fā)的讀者可以多加注意,畢竟 demangle 之后的符號(hào)可讀性要強(qiáng)很多。

? OBJDUMP objdump 是所有二進(jìn)制工具之母,能夠顯示一個(gè)目標(biāo)文件中所有的信息,通常我們用它來反匯編 .text 節(jié)中的二進(jìn)制指令。

比如對(duì)上面的 hello.o 反匯編的結(jié)果如下:# objdump -d hello.o

hello.o: file format elf32-i386

Disassembly of section .text:

00000000

:0: 55 push %ebp 1: 89 e5 mov %esp,%ebp 3: 83 ec 08 sub $0x8,%esp 6: 83 e4 f0 and $0xfffffff0,%esp 9: b8 00 00 00 00 mov $0x0,%eax e: 29 c4 sub %eax,%esp 10: 83 ec 08 sub $0x8,%esp 13: 68 00 00 00 00 push $0x0 18: 83 ec 0c sub $0xc,%esp 1b: 68 00 00 00 00 push $0x0 20: 68 00 00 00 00 push $0x0 25: e8 fc ff ff ff call 26



關(guān)鍵詞:

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉