专栏首页琦小虾的Binary交叉编译学习笔记(一)——交叉编译和交叉工具链

交叉编译学习笔记(一)——交叉编译和交叉工具链

交叉编译学习笔记(一)——交叉编译和交叉工具链

最近看论文看的烦,又重新拾起之前没有完全完成的交叉编译,准备在网上找资料,好好研究一下。

参考链接: http://blog.csdn.net/zqixiao_09/article/details/51822943 http://blog.csdn.net/shenjianxz/article/details/52130111 http://www.crifan.com/files/doc/docbook/binutils_intro/release/html/binutils_intro.html

一. 交叉编译

了解交叉编译之前,首先要介绍本地编译,才能进一步对比本地编译与交叉编译的区别。

1. 本地编译

我们之前常见的软件开发,都是属于本地编译:在当前的PC下,x86的CPU下,直接编译出来程序,可以运行的程序(或者库文件),其可以直接在当前的环境,即x86的CPU下,当前电脑中,运行。 此时的编译叫做本地编译,即编译出来的程序是由当前目标平台编译出的,且只是放到当前平台下运行。

2. 交叉编译

交叉编译是和本地编译相对应的概念。交叉编译是指在当前平台下编译出在其他平台下运行的程序,即编译出来的程序运行环境与编译它的环境不一样,所以称为交叉编译(Cross Compile)。

3. 交叉编译的意义

交叉编译的概念一般用于嵌入式系统开发。 使用交叉编译的主要原因,是嵌入式系统中配置较低,资源过少,远不及PC的编译效率。 以笔者为例,笔者的毕业设计是把在ARM上运行一个搭建一个小型监控系统,所以就需要在ARM上配置OpenCV。一方面,笔者的ARM是Cortex-A9的四核1.0GHz的芯片(且已经算比较高的配置),但编译速度依旧远远不如笔者的PC机(i7处理器,8核3.6GHz)。如果在ARM上编译OpenCV,编译过程中生成的中间文件可能大于ARM存储容量不说,且编译速度也远不如本地编译。另一方面,PC机的CPU架构是x86型的,ARM的CPU架构是ARM型的,所以这时候就需要用交叉编译器(此处即为ARM的编译器)编译程序代码,然后移植到ARM平台运行。所以这就是交叉编译的意义所在。

二. 交叉工具链

工具链可以被拆分为两部分:工具、链。下面分别对其进行解释:

1. 工具

工具就是用来工作的。此处工作的目的是为了生成库文件或(可运行)程序。 此处为了将程序代码编译成可执行文件,中间涉及到了编译、链接等其他步骤,过程中依赖很多相关工具,其中最核心的便是编译器(如gcc)、链接器(ld)。此处所谓的工具,就是gcc,ld等与程序编译、链接等操作相关的工具。 达成此目标的工作流程中主要包含了编译链接两个步骤。

(1) 编译

  • 输入对象:程序源码
  • 输出目标:目标文件
  • 工具:编译器
    • 常见编译器:PC上的gcc,ARM上的arm-linux-gcc

(2) 链接

  • 输入对象:库文件(程序运行时依赖的库文件,或者是某个库所依赖的另外一个库文件)
  • 输出目标:
    • 程序的可执行文件
    • 可被其他可执行文件/库文件调用的库文件
  • 工具:链接器(ld)

这里有一个不得不提的二进制工具集——GNU Binutils。 GNU Binutils,即GNU Binary Utilities的简写,是一组二进制工具的集合。主要包含的工具有:

  • ld:链接器,将多个目标文件链接成一个可执行文件/目标库文件
  • as:汇编器,将汇编源代码编译为机器代码
  • ranlib:对静态库的符号索引表进行更新
  • addr2line:将地址转换为行号(一般用于反汇编)
  • ar:用来操作.a档案文件,如创建、修改、提取内容等
  • nm:列出目标文件中的符号
  • objcopy:拷贝并转换文件,可用于不同格式的二进制文件转换
  • objdump:显示目标文件中的信息
  • readelf:显示ELF格式的目标文件信息
  • size:显示目标文件或档案文件的节(section)大小
  • strings:显示文件中可打印字符串信息

其中最重要的工具是ld, as。

关于编译、链接,笔者也写过一篇简析:《程序生成之编译、链接、加载浅析》,关于编译与链接的内容可查阅该博客。

2. 链

链(chain)的意义在于,按照对应的逻辑,将多个工具串联在一起。 工具,即为前面说到的与程序编译、链接相关的gcc等工具;对应的逻辑,指程序本身编译链接的先后顺序。即先编译,后链接,最后进行其他后期处理(如用objcopy操作相应目标文件等)。 如此将程序编译链接相关工具,按照先编译后链接的内在编译逻辑串起来,就成了我们所谓的工具链。

3. 交叉工具链

一般所说的工具链,指的是本地平台自己的工具链。而用于交叉编译的工具链,就是交叉工具链。交叉工具链中,gcc编译器、ld链接器以及其他的相关工具,都是用来跨平台交叉编译的。 交叉工具链与本地工具链类似,也有交叉编译版本的gcc, ld, as等工具,与本地工具链两两对应。交叉工具链中最重要的工具还是编译器gcc,所以我们也经常把交叉工具链简称为交叉编译器,即严格意义上来讲,交叉编译器指的是交叉编译版本的gcc,但为了叫法上的方便,我们平常说的交叉编译,其实指的都是交叉工具链。 例如常用的交叉编译器arm-linux-gcc,其实是一系列交叉编译版本的交叉工具链,其中包含了arm-linux-gcc, arm-linux-ld, arm-linux-as等工具。

总结:

交叉编译,就是在一种平台上编译出能运行在体系结构不同的另一种平台上的程序。例如在x86平台下交叉编译出了ARM平台上的程序,虽然两个平台用的都是Linux系统,但编译得到的程序只能在ARM平台下运行,x86平台下不可运行。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ARM交叉编译OpenCV错误总结

    ARM交叉编译OpenCV错误总结 最近尝试给两个ARM板子与用交叉编译配置OpenCV,为此查了很多资料,学了很多交叉编译的操作。 经过多次的交叉编译全都...

    剑影啸清寒
  • 程序生成之编译、链接、加载浅析

    程序生成之编译、链接、加载浅析 最近笔者看论文烦得慌,便又重新拾起之前没有完全完成的交叉编译,准备在网上找资料,好好研究一下。 讲道理,笔者其实对编译链接的...

    剑影啸清寒
  • Redis技术知识总结之七——Redis多路复用机制

    redis 是一个单线程却性能非常好的内存数据库, 主要用来作为缓存系统。 redis 采用网络IO多路复用技术来保证在多连接的时候, 系统的高吞吐量。 为什...

    剑影啸清寒
  • Windows下编译64位CGAL

    CGAL的官网准备了压缩包和安装程序两种类型的的源代码,推荐使用安装程序包,因为其中自带了编译好的gmp和mpfr库。gmp和mpfr是CGAL的依赖库,如果自...

    charlee44
  • Eclipse——编译已有工程出现“ No rule to make target”的解决方案

    【问题】:使用Eclipse打开已有工程后,编译出现如下错误“ No rule to make target”;

    Winter_world
  • Windows下PCL1.9.1配置(编译源码)

    PCL1.9.1并没有支持vs2015版本的exe版本,然后需要下载PCL的源码重新自己CMake编译出vs2015版本的

    点云PCL博主
  • 视频流媒体平台EasyNVR是否可以编译树莓派版本?

    我们的流媒体平台支持编译成各种版本,能够满足不同用户的使用需要。为了确保编译后的各个版本没有错误,我们研发时也会进行测试,比如之前我们编译过视频管理平台Easy...

    EasyNVR
  • .Net Micro Framework移植环境准备

    移植准备 .Net Micro Framework移植必须安装PK最新版本,可以从官网(http://netmf.codeplex.com/)下载,建议安装到C...

    大石头
  • readlink: command not found 解决方案

    /c/Program Files (x86)/Yarn/bin/yarn: line 3: readlink: command not found 用gitba...

    smy
  • QQ音乐Android编译提速之路

    ? 1. 序言 工程编译,是Android应用开发工作中的重要一环。而随着工程代码量膨胀,编译耗时也越来越长,拖慢了开发效率。 这个问题在中大型团队中并不少见...

    QQ音乐技术团队

扫码关注云+社区

领取腾讯云代金券