新闻中心

EEPW首页>嵌入式系统>设计应用> arm-linux-gcc/ld/objcopy/objdump参数

arm-linux-gcc/ld/objcopy/objdump参数

作者: 时间:2016-11-21 来源:网络 收藏
arm-linux-gcc-wall -O2 -c -o $@ $<-o 只激活预处理,编译,和汇编,也就是他只把程序做成obj文件-Wall 指定产生全部的警告信息-O2 编译器对程序提供的编译优化选项,在编译的时候使用该选项,可以使生成的执行文件的执行效率提高-c 表示只要求编译器进行编译,而不要进行链接,生成以源文件的文件名命名但把其后缀由 .c 或 .cc 变成 .o 的目标文件-S 只激活预处理和编译,就是指把文件编译成为汇编代码arm-linux-ld直接指定代码段,数据段,BSS段的起始地址-Ttest startaddr-Tdata startaddr-Tbss startaddr

示例:Arm-linux-ld –Ttext 0x0000000 –gled.o –o led_elf

本文引用地址: //m.amcfsurvey.com/article/201611/319394.htm

使用连接脚本设置地址:Arm-linux-ld –Ttimer.lds –o timer_elf $^其中timer.lds 为连接脚本

完整的连接脚本格式:SECTIONS{…Secname start ALING(aling) (NOLOAD):AT(ldaddr){contents} > region:phdr=fill…..}

arm-linux-objcopy被用来复制一个目标文件的内容到另一个文件中,可用于不同源文件的之间的格式转换示例:Arm-linux-objcopy –o binary –S elf_file bin_file

常用的选项:input-file , outflie输入和输出文件,如果没有outfile,则输出文件名为输入文件名

2.-l bfdname或—input-target=bfdname用来指明源文件的格式,bfdname是BFD库中描述的标准格式名,如果没指明,则arm-linux-objcopy自己分析

3.-O bfdname 输出的格式

4.-F bfdname 同时指明源文件,目的文件的格式

5.-R sectionname 从输出文件中删除掉所有名为sectionname的段

6.-S 不从源文件中复制重定位信息和符号信息到目标文件中

7.-g 不从源文件中复制调试符号到目标文件中

arm-linux-objdump查看目标文件(.o文件)和库文件(.a文件)信息arm-linux-objdump -D -m arm led_elf > led.dis-D 显示文件中所有汇编信息-m machine指定反汇编目标文件时使用的架构,当待反汇编文件本身没有描述架构信息的时候(比如S-records),这个选项很有用。可以用-i选项列出这里能够指定的架构.

常用选项:

1.-b bfdname 指定目标码格式2.—disassemble或者-d 反汇编可执行段3.—dissassemble-all或者-D 反汇编所有段4.-EB,-EL指定字节序5.—file-headers或者-f 显示文件的整体头部摘要信息6.—section-headers,--headers或者-h 显示目标文件中各个段的头部摘要信息7.—info 或者-I 显示支持的目标文件格式和CPU架构8.—section=name或者-j name显示指定section 的信息9.—architecture=machine或者-m machine 指定反汇编目标文件时使用的架构

1. 修改源代码的顶层MakefileCC =$(CROSSCOM_PILE)gcc-->CC =$(CROSSCOM_PILE)gcc-g使成生的vmlinux中含有debug信息2. 所有生成.o的rule中再加一条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.txtvmliux中所有段的头信息,其中包口vmlinux的入口地址等7. objdump --debugging vmlinux > debugging.txt很多有用的debug信息,如函数名,结构体定义等我觉的用根据以上信息,ultraedit看很方便。尤其在vmlinux.txt中选中文件名,用ultraedit右键的open能马上打开文件,很方便。

objdump -j .text -Svmlinux > vmlinux.txt-S尽可能反汇编出源代码,尤其当编译的时候指定了-g这种调试参数时,效果比较明显。隐含了-d参数。

-l用文件名和行号标注相应的目标代码,仅仅和-d、-D或者-r一起使用使用-ld和使用-d的区别不是很大,在源码级调试的时候有用,要求编译时使用了-g之类的调试编译选项。

[-l | --line-numbers][-S | --source]混合汇编[-z | --disassemble-zeroes][-j section | --section=section][--prefix-addresses]



关键词:armlinuxgc

评论


技术专区

关闭