如何使用 objdump
查看源代碼
1. 在編譯時必須使用-g選項,-g意爲debug,一般可以修改源代碼的 Makefile來實現 如:
CC =$(CROSSCOM_PILE)gcc 爲
CC =$(CROSSCOM_PILE)gcc -g
使成生的vmlinux中含有debug信息
2. 所有生成 .o 的 rule 中再加一條 /*其他參數除了-c外抄生成.o文件用的參數*/
CC -E -dD -C $< > /preprocessing/$(shell pwd)/$<
生成預處理文件從這個文件裏面能很容易找到 c 源文件的宏定義
3. objdump -h vmlinux > vmlinux.txt
顯示 linux 內核段信息,如段的開始虛擬地址,段的長度
4. objdump -S -l -z vmlinux > vmlinux.txt
反彙編 vmlinux 到vmlinux.txt, vmlinux.txt 含有彙編和 c 源文件的混合代碼,看起來很方
便。而且能一步步看linux怎麼一步步運行的。
5. objdump -S -l -z -j xxxx(section name) vmlinux > vmlinux.txt
反彙編 linux 內核段 xxxx 到文件 vmlinux.txt 中。
6. objdump -x vmlinux > x.txt
vmliux中所有段的頭信息,其中包口vmlinux的入口地址等
7. objdump --debugging vmlinux > debugging.txt
很多有用的debug信息,如函數名,結構體定義等
我覺的用根據以上信息,ultraedit看很方便。尤其在vmlinux.txt中選中文件名,
用ultraedit右鍵的open能馬上打開文件,很方便。
CC =$(CROSSCOM_PILE)gcc 爲
CC =$(CROSSCOM_PILE)gcc -g
使成生的vmlinux中含有debug信息
2. 所有生成 .o 的 rule 中再加一條 /*其他參數除了-c外抄生成.o文件用的參數*/
CC -E -dD -C $< > /preprocessing/$(shell pwd)/$<
生成預處理文件從這個文件裏面能很容易找到 c 源文件的宏定義
3. objdump -h vmlinux > vmlinux.txt
顯示 linux 內核段信息,如段的開始虛擬地址,段的長度
4. objdump -S -l -z vmlinux > vmlinux.txt
反彙編 vmlinux 到vmlinux.txt, vmlinux.txt 含有彙編和 c 源文件的混合代碼,看起來很方
便。而且能一步步看linux怎麼一步步運行的。
5. objdump -S -l -z -j xxxx(section name) vmlinux > vmlinux.txt
反彙編 linux 內核段 xxxx 到文件 vmlinux.txt 中。
6. objdump -x vmlinux > x.txt
vmliux中所有段的頭信息,其中包口vmlinux的入口地址等
7. objdump --debugging vmlinux > debugging.txt
很多有用的debug信息,如函數名,結構體定義等
我覺的用根據以上信息,ultraedit看很方便。尤其在vmlinux.txt中選中文件名,
用ultraedit右鍵的open能馬上打開文件,很方便。