objdump使用方法

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信息,如函数名,结构体定义等 

 

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值