0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是交叉编译?为何要有交叉编译

Q4MP_gh_c472c21 来源:未知 作者:李倩 2018-04-26 10:46 次阅读

一、交叉编译简介

1、什么是交叉编译

1.1 本地编译

解释什么是交叉编译之前,先要明白一个概念:本地编译

我们之前常见的软件开发,都是属于本地编译:在当前的PC下,x86的CPU下,直接编译出来程序,可以运行的程序(或者库文件),其可以直接在当前的环境,即x86的CPU下,当前电脑中,运行。

此时的编译,可以叫做,本地编译,即在当前目标平台下,编译出来的程序,也只是放到当前平台下,就可以运行的。

2.2 交叉编译

交叉编译,是一个和,本地编译,相对应的概念。

而所谓的,交叉编译,就是:在一种平台上编译,编译出来的程序,是放到别的平台上运行即编译的环境,和运行的环境不一样,属于交叉的,此所谓cross。

交叉编译,这个概念,主要和嵌入式开发有关。

例 1.1. 在x86平台上编译,在ARM平台上运行

一种最常见的例子就是:

在进行嵌入式开发时手上有个嵌入式开发板,CPU是arm的然后在x86的平台下开发,比如Ubuntu的Linux,或者是Win7然后就需要:

在x86的平台上,(用交叉编译器)去编译你写好的程序代码

编译生成的(可执行的)程序,是放到目标开发板,arm的CPU上运行的

此所谓:在x86平台上编译,在ARM平台上运行

交叉编译,英文常写作cross compile,也有其他写法:crosscompile, cross compiling等

2、为何要有交叉编译

之所以要有交叉编译,主要原因是:嵌入式系统中的资源太少

具体的解释就是:交叉编译出来的程序,所要运行的目标环境中,各种资源,都相对有限,所以很难进行直接的本地编译

最常见的情况是:在进行嵌入式开发时,目标平台,即嵌入式开发板,比如是最大主频200MHz的ARM的CPU,加上32M的RAM,加上1G的Nand Flash等等。在如此相对比较紧张的硬件资源的前提下,在已经运行了嵌入式Linux的前提下,是没法很方便的直接在嵌入式Linux下,去本地编译,去在ARM的CPU下,编译出来,供ARM的CPU可以运行的程序的。因为编译,开发,都需要相对比较多的CPU,内存,硬盘等资源,而嵌入式开发上的那点资源,只够嵌入式(Linux)系统运行的,没太多剩余的资源,供你本地编译。

BusyBox中包含make等和编译开发相关的工具

对应的,等你后期熟悉了嵌入式开发,熟悉了Busybox后,比如在Buildroot中去配置Busybox,或者单独交叉编译BusyBox时:

【记录】Ubuntu下为QEMU的arm平台交叉编译BusyBox

就会看到,后来的BusyBox,功能增加后,也已经包含了一些,和编译开发相关的工具,比如make等等

而这些工具,本来的话,只是,放在PC端使用,即在x86平台下做开发的时候,在交叉编译的时候,才用到的工具,现在,也在(BusyBox的)嵌入式环境中,支持了。

此时,如果,你在BusyBox中把相关的开发工具都选上的话,

再加上,你的目标开发板的硬件配置足够强大的话,比如CPU都是以GHz为单位,等等

加上相关的开发的库和工具都很全的话

实际上,至少理论上,也是可以在你的嵌入式Linux中,进行,有限的,甚至是很大程度上的,本地开发即,直接在ARM的开发板上,嵌入式Linux中,直接进行嵌入式开发,进行针对ARM的本地编译

比如,编译出一个helloworld,估计还是可以的

这样,就不存在,或者说,避免了,此处所说的,交叉编译,而变成了本地编译

就相当于,之前在x86的PC端的,编译程序放在x86的CPU上运行的本地编译,

在ARM的CPU,嵌入式Linux中,也实现了

但是很明显,对于更加复杂的程序或者库,在ARM开发板上直接编译的可行性和效率,相对就很低

而且如果是本身折腾Uboot等东西,本身目标运行环境,就没有完整的(嵌入式Linux)系统的话,那么就更加没法在目标平台实现本地编译了。

则还是只能进行,此处所说的,交叉编译

二、交叉工具链简介

1、什么是工具链

所谓的工具链,两部分的含义:

a -- 工具

工具,即tool

工具,是用来干活的;此处要干的活,目标是为了:生成(可以运行的)程序或库文件

而为了达成此目标,内部的执行过程和逻辑主要包含了:

1)、编译

编译的输入(对象)是:程序代码

编译输出(目标)是:目标文件

编译所需要的工具是:编译器

编译器,常见的编译器,即为gcc

2)、链接

链接的输入(对象)是:(程序运行时所依赖的,或者某个库所依赖的另外一个)库(文件)

链接的输出(目标)是:程序的可执行文件,或者是可以被别人调用的完整的库文件

链接所需要的工具是:链接器

链接器,即ld

即,此处,为了将程序代码,编译成可执行文件,涉及到编译,链接(等其他步骤),要依赖到很多相关的工具,最核心的是编译器gcc,链接器ld。而此处,所谓的工具,主要指的就是:和程序编译链接等相关的gcc,ld等工具

binutils包含了ld等工具

实际上,上面所说的ld,只是处理操作目标文件,二进制文件的最主要的一个工具

而和操作目标等文件相关的,还有其他很多工具的:as,objcopy,strip,ar等等工具的

所以,对此,GNU官网,弄出一个binutils,即binary utils,二进制工具(包),集成了这些,和操作二进制相关的工具集合,叫做binutils

所以,之后你所见到的,常见的工具,就是那个著名的GNU Binutils了。

b -- 链

链,即链条,chain

之所以能称为链,你是说明不止一个东西,然后,按照对应的逻辑,串在一起,链在一起。而对应的,涉及到的:

不止一个东西:指的是就是前面所说的那个工具,即:和程序编译链接等相关的gcc,binutils等工具

按照对应的逻辑:指的就是,按照程序本身编译链接的先后顺序,即:先编译,后链接,再进行后期其他的处理等等,比如用objcopy去操作相应的目标文件等等。

如此的,将:

和程序编译链接等相关的gcc,binutils等工具按照先编译后链接等相关的编译程序的内在逻辑串起来,就成了我们所说的:工具链

2、什么是交叉工具链

普通所说的,工具链指的是当前自己的本地平台的工具链。

用于交叉编译的工具链,就叫做交叉工具链。即那些工具,即编译的gcc,链接的ld,以及相关的工具,用于交叉编译的,工具链,叫做交叉工具链。

交叉工具链,很明显,是用来,交叉编译,跨平台的程序所用的。交叉工具链,和(本地)工具链类似,也是包含了很多的,对应的工具,交叉编译版本的gcc,ld,as等等。但是,由于其中最最主要的是用于编译的gcc,所以,我们也常把:交叉工具链,简称为交叉编译器

即严格意义上来说,交叉编译器,只是指的是交叉编译版本的gcc。但是实际上为了叫法上的方便,我们常说的交叉编译器,都是指的是交叉工具链。常说的交叉编译版本的gcc,比如arm-linux-gcc,实际上指代了,包含一系列交叉编译版本的交叉工具链(arm-linux-gcc,arm-linux-ld,arm-linux-as等等)而此文中,后面,所说的,如无特殊指明,均用交叉编译器指代交叉工具链。

总结

交叉编译就是在一种平台上编译出能运行在体系结构不同的另一种平台上的程序,比如在PC平台(X86 CPU)上编译出能运行在以ARM为内核的CPU平台上的程序,编译得到的程序在X86 CPU平台上是不能运行的,必须放到ARM CPU平台上才能运行,虽然两个平台用的都是Linux系统。 交叉编译工具链是一个由编译器、连接器和解释器组成的综合开发环境,交叉编译工具链主要由binutils、gcc和glibc三个部分组成。有时出于减小 libc 库大小的考虑,也可以用别的 c 库来代替 glibc,例如 uClibc、dietlibc 和 newlib。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    11322

    浏览量

    209869
  • 开发板
    +关注

    关注

    25

    文章

    5083

    浏览量

    97730
  • 交叉编译
    +关注

    关注

    0

    文章

    32

    浏览量

    12658
  • 编辑器
    +关注

    关注

    1

    文章

    806

    浏览量

    31212

原文标题:交叉编译知识解析之交叉编译和交叉工具链

文章出处:【微信号:gh_c472c2199c88,微信公众号:嵌入式微处理器】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    什么是交叉编译?为什么要交叉编译

    什么是交叉编译交叉编译是在一个平台上生成另一个平台上的可执行代码(例如我们在windows上用keil编译代码生成hex文件,供51单片机使
    发表于 01-13 06:04

    为什么要有交叉编译器?

    1.为什么要有交叉编译器?\qquad一般电脑是X86架构,而单片机一般不是,比如单片机是ARM架构,那么gcc编译生成的程序只能在X86的架构上运行,而不能在ARM架构上运行,所以需
    发表于 01-25 06:36

    交叉编译linux内核(raspberry_3.6.y)

    一步一步教你交叉编译linux内核,RPI的内核编译教程,小众的东西了
    发表于 11-03 17:58 0次下载

    交叉平台开源编译系统_cmake入门

    交叉平台开源编译系统_cmake入门
    发表于 01-22 13:59 9次下载

    嵌入式交叉编译环境的搭建解析

    5.1.1 嵌入式交叉编译环境的搭建 交叉编译的概念在第4章中已经详细讲述过,搭建交叉编译环境是
    发表于 10-18 16:44 1次下载

    arm-linux的交叉编译环境解析

    交叉编译环境介绍 交叉编译是嵌入式开发过程中的一项重要技术,它的主要特征是某机器中执行的程序代码不是在本机编译生成,而是由另一台机器
    发表于 10-31 11:26 7次下载

    Xilinx交叉编译链的安装步骤和验证

    xilinx-arm-linux交叉编译链最后一个版本就是2011版本,之后的xilinx不再单独提供交叉编译链了,如果需要最新的,请安装SDK开发软件,之后再安装目录中查找,或者so
    发表于 07-10 10:49 3180次阅读

    ST微电子STM8的C交叉编译用户指南

    《STM8交叉编译器用户指南》是程序员为STM8微控制器环境编写C程序的参考指南。它概述了交叉编译器的工作原理,并解释了如何编译、组装、链接
    发表于 06-04 08:00 12次下载
    ST微电子STM8的C<b class='flag-5'>交叉</b><b class='flag-5'>编译</b>用户指南

    Prelink的交叉编译和使用详解

    Prelink的交叉编译和使用详解
    的头像 发表于 06-20 12:03 3557次阅读
    Prelink的<b class='flag-5'>交叉</b><b class='flag-5'>编译</b>和使用详解

    linux的系统移植——交叉编译

    1.为什么要有交叉编译器?\qquad一般电脑是X86架构,而单片机一般不是,比如单片机是ARM架构,那么gcc编译生成的程序只能在X86的架构上运行,而不能在ARM架构上运行,所以需
    发表于 11-30 15:21 11次下载
    linux的系统移植——<b class='flag-5'>交叉</b><b class='flag-5'>编译</b>器

    交叉编译器安装教程

    交叉编译器中“交叉”的意思就是在一个架构上编译另外一个架构的代码,相当于两种架构“交叉”起来了。Ubuntu 自带的 gcc
    的头像 发表于 09-29 09:12 3543次阅读

    QT如何配置交叉编译工具?

    交叉编译工具安装 (glibc版本需要和开发板上的版本相兼容)
    的头像 发表于 10-28 09:31 3495次阅读

    Go工程化-交叉编译概述

    交叉编译,也称跨平台编译,就是在一个平台上编译源代码,生成结果为另一个平台上的可执行代码。
    的头像 发表于 05-22 17:15 716次阅读

    Linux交叉编译选项与源码与目标文件分离

    交叉编译选项 编译Linux,通常只需要运行 make menuconfig 配置要编译的模块,然后运行 make 。Linux默认是做本地编译
    的头像 发表于 09-27 11:48 856次阅读

    QT开发学习笔记1(安装交叉编译器)

    QT安装交叉编译
    的头像 发表于 02-18 10:02 1071次阅读
    QT开发学习笔记1(安装<b class='flag-5'>交叉</b><b class='flag-5'>编译</b>器)