各个交叉工具链区别及命名

通常我们在下载工具链的时候,如果不清楚各个工具链代表的意思,那么可能会一脸懵逼。本人在工作中也会遇到,于是就查找资料,总结部分。各位请对号入座!

ARM CPU汇总 & 编译链选择 - solonj - 博客园

ARM32、小端、裸机工程: arm-none-eabi
ARM32、小端、Linux工程: arm-none-linux-gnueabihf
ARM64、小端、裸机工程: aarch64-none-elf
ARM64、小端、Linux工程: aarch64-none-linux-gnu
ARM64、大端、Linux工程: aarch64_be-none-linux-gnu

 

原文网址:http://www.veryarm.com/296.html

命名规则

交叉编译工具链的命名规则为:arch [-vendor] [-os] [-(gnu)eabi]

  • arch - 体系架构,如ARM,MIPS
  • vendor - 工具链提供商
  • os - 目标操作系统
  • eabi - 嵌入式应用二进制接口(Embedded Application Binary Interface)

根据对操作系统的支持与否,ARM GCC可分为支持和不支持操作系统,如

  • arm-none-eabi:这个是没有操作系统的,自然不可能支持那些跟操作系统关系密切的函数,比如fork(2)。他使用的是newlib这个专用于嵌入式系统的C库。
  • arm-none-linux-eabi:用于Linux的,使用Glibc

 实例

1、arm-none-eabi-gcc

(ARM architecture,no vendor,not target an operating system,complies with the ARM EABI)
用于编译 ARM 架构的裸机系统(包括 ARM Linux 的 boot、kernel,不适用编译 Linux 应用 Application),一般适合 ARM7、Cortex-M 和 Cortex-R 内核的芯片使用,所以不支持那些跟操作系统关系密切的函数,比如fork(2),他使用的是 newlib 这个专用于嵌入式系统的C库。

2、arm-none-linux-gnueabi-gcc

(ARM architecture, no vendor, creates binaries that run on the Linux operating system, and uses the GNU EABI)

主要用于基于ARM架构的Linux系统,可用于编译 ARM 架构的 u-boot、Linux内核、linux应用等。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 = %f\n”, c);
    printf(“hello world !\n”);
    return 0;
}

1、使用 arm-linux-gnueabihf-gcc 编译,使用“-v”选项以获取更详细的信息:
# arm-linux-gnueabihf-gcc -v mfloat.c
COLLECT_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.c
COLLECT_GCC_OPTIONS=’-v’ ‘-march=armv7-a’ ‘-mfloat-abi=softfp’ ‘-mfpu=vfpv3-d16′ ‘-mthumb’
-mfloat-abi=softfp

可看出使用softfp模式

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
大数据时代的消费者洞察 孙予加(柳莺) 阿里巴巴集团,产品经理 负责数据产品"淘宝指数"和"全景洞察" 摘要:随着互联网和移动设备的普及,用户留下 的痕迹越来越完整,越来越丰富,互联网就像是一个 巨大的模子把每一个人完整的印在上面,从吃穿住行 到心情状态,从社交娱乐到日常工作,事无巨细的保 留在网上。如果把一个人遗留在各种网站和 APP 上的 点点滴滴串起来,就能还原这个完整的人。本文探讨 了大数据时代消费者研究和社会研究领域将面临的 变革,并通过数据产品"淘宝指数"和"全景洞察" 向研究者阐述已经发生的未来。 关键词:大数据、社会学研究、消费者研究、 数 据挖掘、算法模型、淘宝指数、全景洞察 1. 消费者研究领域的新纪元 这个时代是研究"人"最好的时代。传统的线下 用户调研模式将面临巨大的冲击,因为传统问卷调研 面临成本高、周期长、样本量小、难以迭代等问题, 在大数据时代自然化解了。利用线上数据进行消费者 研究将取代传统的传统问卷调研,并成为主要趋势。 社会学研究和商业研究将会迎来一个新的时代。 如何从海量的繁杂无序的原始数据中提取出有 价值的信息, 数据挖掘技术是至关重要的角色。 例如, 网购收货地址结合登录 IP 地址的场所识别(学校、 医院、写字楼、小区、政府机构、工厂、商场等) , 再结合上网时间地点(白天还是晚上、工作日还是周 末) ;通过算法模型就可以判断出一个人的工作地点、 住宅小区、身份职业等信息。另外,结合消费特征、 APP 偏好,以及社交网站的言论、关注点和公开的身 份信息,通过算法模型基本可以判断出每个人的性 别、年龄、身高体型、消费能力、学历学校、兴趣爱 好(摄影、户外、园艺、钓鱼、打牌、运动,甚至细 化到旅游的地点和运动的类型, 如跑步、 足球、 篮球、 游泳、舞蹈、瑜伽、骑马等) 、风格品味(偏好的品 牌和格调) 、影视偏好(喜欢的电影、电视剧和音乐 风格,追的明星和导演) 、生活习惯和状态(单身、 热恋还是已婚;是否有孩子、孩子的年龄段;是否有 宠物、宠物的类型和品种;是否有房有车、小区档次 和车的品牌型号;是否和父母同住、一家几口住在一 起) 。这些数据只是冰山一角,百度的搜索行为数据 结合地图定位信息,以及腾讯完整的社会关系网数 据,大数据时代的未来充满想象。 很多人可能开始担心数据安全的问题,据我所知 BAT 对数据安全的措施是极其严格的,阿里云的数据 安全级别超过欧洲最高标准。另外,所有和人有关的 数据是经过严格加密的,只有机器才能识别;而个人 只能看到一串无法识别毫无意义的代码。想要得到个 人的隐私数据是根本不可能的。 2.大数据洞察全景 大数据时代的特点是数据的全面、丰富、深度和 联接。不仅可以看到各个行业各种维度的数据,数据 之间还能打通和联接,能够去发现事物背后的关联。 真正的"大数据时代"是从全景到洞察,再到行动, 是一整套体系的建立。 基于此信念,创造了一款数据产品命名为"全 景洞察" ,用于帮助品牌商进行商业决策的高级研究 工具。其特点在于,数据的深度和宽度,可从各种角 度切入,深入的研究消费者特征和行为,对现象背后 的原因进行深度分析。 作为"全景洞察" 的产品经理, 相信它将会对研究领域产生颠覆性的影响。 "全景洞察"有丰富的数据源、非常细的数据颗 粒度(可无限交叉细分) 、可视化的数据展现和自由 灵活的数据分析方法,可进行深度的分析和数据挖 掘。数据分析的结论可落地到行动上,不仅仅是为了 研究而研究。在"全景洞察"中可自由选择需要的数 据分析方法(如下图) ,以及任意的数据维度进行对 比、交叉和关联分析,上亿条数据瞬间计算完成, 在 0.1 秒内以可视化的方式呈现,呈现后可继续细分进 行深度的分析。 2.1 用"全景洞察"建 Persona 背景:某轻奢侈品女包品牌希望用互联网的数据做品 牌定位,绘制目标人群完整的肖像,制定营销策略。 (该案例为真实案例,已隐去品牌名称。 ) 第一步:绘制购买该品牌包初步的消费者画像(人口 特征) ,确定目标人群。 人口特征维度交叉组合,看哪类人对该品牌包有明显 的倾向,通常有 1-3 类人。 (如果没有明显的人群倾 向,说明该品牌定位不准,需要明确品牌定位) 第二步:细化目标人群,对目标人群进行深度分析, 挖掘消费者需求,绘制完整画像。 可以通过该人群在各个行业下偏好的品类、品牌、价 位段、属性、商品特征来绘制完整的人群画像,从吃 穿住行到社交娱乐,深度了解目标人群才能把握其核 心需求。 第三步:如果该品牌有多个细分人群,针对每个人群 设计定制化的营销方案。 对最合适的人群推最合适的商品/服务,说最打动他 们的话, 用最合适的营销方式, 在恰当的时间和地点。 首先,挖掘该女包品牌消费者特征。将各种人口特征维度交叉组合反复尝试,找到特

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值