objdump -a vmlinux //列举.a文件中所有的目标文件。
objdump -g vmlinux //显示调试信息。
objdump -t vmlinux //输出目标文件的符号表()
objdump -T vmlinux //显示动态链接符号表
objdump -h vmlinux //输出目标文件的所有段概括()
objdump -f vmlinux //显示目标文件文件头
objdump -I vmlinux //显示行号信息
objdump -p vmlinux //显示专有头部信息,具体内容取决于文件格式。
objdump -r vmlinux //显示文件的重定位入口
objdump -R vmlinux //显示动态链接重定位信息。
objdump -s vmlinux //将所有段的内容以十六进制的方式打印出来
objdump -S vmlinux //显示源代码和反汇编代码(包含-d 参数)
objdump -d vmlinux //对包含机器指令的段进行反汇编
objdump -D vmlinux //-D 与 -d 类似,但对所有段进行反汇编
objdump -x vmlinux // 显示所有可用的头信息,包括符号表、重定位入口。-x 等价于
// -a -f -h -r -t 同时指定。
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.dump
显示 linux 内核段信息,如段的开始虚拟地址,段的长度
4. objdump -S -l -z vmlinux > vmlinux.dump
反汇编 vmlinux 到vmlinux.txt, vmlinux.dump 含有汇编和 c 源文件的混合代码,看起来很方
便。而且能一步步看linux怎么一步步运行的。
5. objdump -S -l -z -j xxxx(section name) vmlinux > vmlinux.dump
反汇编 linux 内核段 xxxx 到文件 vmlinux.dump 中。
6. objdump -x vmlinux > x.dump
vmliux中所有段的头信息,其中包口vmlinux的入口地址等
7. objdump --debugging vmlinux > debugging.dump
很多有用的debug信息,如函数名,结构体定义等