首页 > 编程知识 正文

qt5只编译工具链,安装arm工具链

时间:2023-05-06 06:34:26 阅读:125000 作者:3094

本文请参考以下链接。 https://www .建墅.com/p/Fe 5485 A8 DAE 7,转载并整理以下内容,对自己的学习有帮助:

交叉编译是指编译在一个平台上可以在体系结构不同的另一个平台上运行的程序。 例如,在PC平台(X86 CPU )上编译可以在以ARM为核心的CPU平台上执行的程序时,编译的程序不能在X86 CPU平台上执行,而是放在ARM CPU平台上虽然这两个平台都使用Linux系统。 交叉编译工具链是由编译器、连接器和解释器组成的综合开发环境,交叉编译工具链主要由binutils、gcc和glibc三部分组成。 为了减小libc库的大小,也可以使用其他c库代替glibc,如uClibc、dietlibc和newlib。

分类和说明从许可证分为免费许可证版和收费许可证版。

免费版目前由三个主要的工具制造商提供。 第一个是GNU (提供源代码并自己编译创建),第二个是Codesourcery,第三个是Linora。

付费版包括ARM工厂提供的armcc、IAR提供的编译器等,但它们价格昂贵,不适合学习用户使用,因此不做说明。

arm-none-linux-gnueabi-gcc:这是目前被Mentor收购的Codesourcery公司基于GCC推出的ARM交叉编译工具。 可用于交叉编译arm(32位)系统所有部分的代码,包括裸机程序、u-boot、Linux kernel、文件系统和app APP应用程序。arm-linux-gnueabihf-gcc:是Linaro公司基于GCC推出的ARM交叉编译工具。 可用于交叉编译arm(32位)系统所有部分的代码,包括裸机程序、u-boot、Linux kernel、文件系统和app APP应用程序。 3358www.Sina.com/linaro公司基于GCC推出的ARM交叉编译工具。 可用于交叉编译ARMv8 64位目标中的裸机程序、u-boot、Linux kernel、文件系统和app APP应用程序。aarch64-linux-gnu-gcc:是是目前被Mentor收购的Codesourcery公司基于GCC推出的ARM交叉编译工具。 可用于交叉编译armMCU(32位)芯片,如ARM7、ARM9和Cortex-M/R芯片程序。arm-none-elf-gcc:是GNU推出的ARM交叉编译工具。 可用于交叉编译armMCU(32位)芯片,如ARM7、ARM9和Cortex-M/R芯片程序。 命名约定交叉编译工具链的命名约定为arch[-vendor][-OS][-GNU]eabi]

arch-arm、MIPS等体系结构(由交叉编译工具生成的可执行文件或系统镜像的可执行平台或环境) ) ) ) ) ) ) )。

vendor工具链提供程序

操作系统目标操作系统(主机的主要操作平台,即编译时的系统)

eabi嵌入式应用程序接口)

根据是否支持操作系统,ARM GCC可以分为是否支持操作系统,如下所示

arm-none-eabi :这是因为没有操作系统,所以当然不能支持与Fork(2)这样的操作系统关系密切的函数。 他使用一个名为newlib的嵌入式系统专用c库。

arm-none-Linux-eabi :用于Linux,使用Glibc

http://www.Sina.com/http://www.Sina.com /

(ARM architecture,no vendor,not target an operating system,complies with the ARM EABI )

用于编译ARM体系结构的裸机系统(包括ARM Linux引导和密钥)。 无法编译Linux APP应用程序应用程序) )通常适用于ARM7、Cortex-M和Cortex-R内核的芯片,因此可以像fork(2) 2那样进行操作

arm-none-eabi-gcc:

(ARM architecture,no vendor,createsbinariesthatrunonthelinuxoperatingsystem,and uses the GNU EABI )

它主要用于基于ARM体系结构的Linux系统,可用于编译ARM体系结构的u-boot、Linux内核和Linux APP应用程序等。 arm-none-linux-gnueabi是以GCC为基础,使用Glibc库,由Codesourcery公司优化发售的编译器。 arm-none-linux-gnueabi-xxx交叉编译工具的浮点运算非

常优秀。一般ARM9、ARM11、Cortex-A 内核,带有 Linux 操作系统的会用到。

3、arm-eabi-gcc

Android ARM 编译器。

4、armcc

ARM 公司推出的编译工具,功能和 arm-none-eabi 类似,可以编译裸机程序(u-boot、kernel),但是不能编译 Linux 应用程序。armcc一般和ARM开发工具一起,Keil MDK、ADS、RVDS和DS-5中的编译器都是armcc,所以 armcc 编译器都是收费的(爱国版除外,呵呵~~)。

5、arm-none-uclinuxeabi-gcc 和 arm-none-symbianelf-gcc

arm-none-uclinuxeabi 用于uCLinux,使用Glibc。

arm-none-symbianelf 用于symbian,没用过,不知道C库是什么 。

Codesourcery
Codesourcery推出的产品叫Sourcery G++ Lite Edition,其中基于command-line的编译器是免费的,在官网上可以下载,而其中包含的IDE和debug 工具是收费的,当然也有30天试用版本的。

目前CodeSourcery已经由明导国际(Mentor Graphics)收购,所以原本的网站风格已经全部变为 Mentor 样式,但是 Sourcery G++ Lite Edition 同样可以注册后免费下载。

Codesourcery一直是在做ARM目标 GCC 的开发和优化,它的ARM GCC在目前在市场上非常优秀,很多 patch 可能还没被gcc接受,所以还是应该直接用它的(而且他提供Windows下[mingw交叉编译的]和Linux下的二进制版本,比较方便;如果不是很有时间和兴趣,不建议下载 src 源码包自己编译,很麻烦,Codesourcery给的shell脚本很多时候根本没办法直接用,得自行提取关键的部分手工执行,又费精力又费时间,如果想知道细节,其实不用自己编译一遍,看看他是用什么步骤构建的即可,如果你对交叉编译器感兴趣的话。

ABI 和 EABI
ABI:二进制应用程序接口(Application Binary Interface (ABI) for the ARM Architecture)。在计算机中,应用二进制接口描述了应用程序(或者其他类型)和操作系统之间或其他应用程序的低级接口。

EABI:嵌入式ABI。嵌入式应用二进制接口指定了文件格式、数据类型、寄存器使用、堆积组织优化和在一个嵌入式软件中的参数的标准约定。开发者使用自己的汇编语言也可以使用 EABI 作为与兼容的编译器生成的汇编语言的接口。

两者主要区别是,ABI是计算机上的,EABI是嵌入式平台上(如ARM,MIPS等)。

arm-linux-gnueabi-gcc 和 arm-linux-gnueabihf-gcc
两个交叉编译器分别适用于 armel 和 armhf 两个不同的架构,armel 和 armhf 这两种架构在对待浮点运算采取了不同的策略(有 fpu 的 arm 才能支持这两种浮点运算策略)。

其实这两个交叉编译器只不过是 gcc 的选项 -mfloat-abi 的默认值不同。gcc 的选项 -mfloat-abi 有三种值 soft、softfp、hard(其中后两者都要求 arm 里有 fpu 浮点运算单元,soft 与后两者是兼容的,但 softfp 和 hard 两种模式互不兼容):
soft: 不用fpu进行浮点计算,即使有fpu浮点运算单元也不用,而是使用软件模式。
softfp: armel架构(对应的编译器为 arm-linux-gnueabi-gcc )采用的默认值,用fpu计算,但是传参数用普通寄存器传,这样中断的时候,只需要保存普通寄存器,中断负荷小,但是参数需要转换成浮点的再计算。
hard: armhf架构(对应的编译器 arm-linux-gnueabihf-gcc )采用的默认值,用fpu计算,传参数也用fpu中的浮点寄存器传,省去了转换,性能最好,但是中断负荷高。

把以下测试使用的C文件内容保存成 mfloat.c:

 

#include <stdio.h>int main(void){ double a,b,c; a = 23.543; b = 323.234; c = b/a; printf(“the 13/2 = %fn”, c); printf(“hello world !n”); return 0;}

1、使用 arm-linux-gnueabihf-gcc 编译,使用“-v”选项以获取更详细的信息:

 

arm-linux-gnueabihf-gcc -v mfloat.cCOLLECT_GCC_OPTIONS=’-v’ ‘-march=armv7-a’ ‘-mfloat-abi=hard’ ‘-mfpu=vfpv3-d16′ ‘-mthumb’ -mfloat-abi=hard

可看出使用hard硬件浮点模式。

2、使用 arm-linux-gnueabi-gcc 编译:

 

arm-linux-gnueabi-gcc -v mfloat.cCOLLECT_GCC_OPTIONS=’-v’ ‘-march=armv7-a’ ‘-mfloat-abi=softfp’ ‘-mfpu=vfpv3-d16′ ‘-mthumb’ -mfloat-abi=softfp

可看出使用softfp模式。

 

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。