我是靠谱客的博主 动人发带,最近开发中收集的这篇文章主要介绍linux命令详解(arm交叉编译器)1、arm-linux-gcc  编译器2、arm-linux-ld  连接器3、arm-linux-objdump   反汇编器4、arm-linux-objcopy  文件格式转换器,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

PC机用的win10,虚拟机使用的是VMware12,Linux版本是redhat6。

 

1、arm-linux-gcc  编译器

举例:arm-linux-gcc  hello.c –o  hello (产生的是elf文件,查看方法:file  hello   )

              Arm-linux-gcc  -g  -c  hello.c (-g附加调试信息-c只编译不连接)

 

2、arm-linux-ld  连接器

举例:arm-linux-ld  -Thello.lds -o  hello.elf  hello.o (hello.lds是连接脚本)

arm-linux-readelf  -a hello.elf (-a表示全部的信息)

可以看出这个文件适合ARM的小端平台。

 

附录:elf文件、bin文件和hex文件

(1)BIN文件是 raw binary 文件,这种文件只包含机器码。BIN文件就是直接的二进制文件,内部没有地址标记。一般用编程器烧写时从00开始,而如果下载运行,则下载到编译时的地址即可。BIN文件用来烧在Flash上

(2)ELF文件除了机器码外,还包含其它额外的信息,如段的加载地址,运行地址,重定位表,符号表等。 ELF文件可用来调试,只能运行在linux平台,不能直接运行到arm平台。

(3) HEX文件是记录文本行的ASCII文本文件,在Intel HEX文件中,每一行是一个HEX记录,由十六进制数组成的机器码或者数据常量,Intel HEX文件经常被用于将程序或数据传输 
存储到ROM、EPROM,大多数编程器和模拟器使用Intel HEX文件。 

3、arm-linux-objdump   反汇编器

       例子:arm-linux-objdump -D  -S  hello  >dump(hello是elf格式,产生elf文件时如果加入了-g选项,反汇编时看代码会更清晰。>dump表示将反汇编输出到dump文件,可以打开dump文件查看)

4、arm-linux-objcopy  文件格式转换器

         例子:arm-linux-objcopy  -o binary  hello.elf  hello.bin

 

         

最后

以上就是动人发带为你收集整理的linux命令详解(arm交叉编译器)1、arm-linux-gcc  编译器2、arm-linux-ld  连接器3、arm-linux-objdump   反汇编器4、arm-linux-objcopy  文件格式转换器的全部内容,希望文章能够帮你解决linux命令详解(arm交叉编译器)1、arm-linux-gcc  编译器2、arm-linux-ld  连接器3、arm-linux-objdump   反汇编器4、arm-linux-objcopy  文件格式转换器所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部