Armv8上不弃不离的NEON/FPU

微信公众号mindshare思享

此文来源于本人在arm开发者网站发布的英文文章

Hints for running software on V8-A processors without FPU

现用中文讲一遍。

熟悉arm

processor的朋友应该知道arm的Cortex-A是带有FPU和NEON的,FPU用来做浮点数运算的,而NEON是SIMD指令做并行运算的。在现有Cortex-A的设计里,NEON和FPU是不可分的,也就是不能单独只有NEON或是FPU。在比较高性能的Cortex-A

CPU(比如Cortex-A15/A57/A72/A73/A75)中,NEON和FPU是不能在RTL配置里去掉的,在高能效的Cortex-A的CPU(比如Cortex-A7/A53/A55)中NEON和FPU是可以在RTL配置里面配置有或是没有。

NEON和FPU毕竟是占面积的,也许你会认为你的应用可能用不到NEON或是FPU,所以你可以配置RTL没有NEON/FPU,以减少面积die size或功耗。

这在Armv7里可能不是问题,但是在armv8 64位里需要非常小心,也许因为这个配置导致你的芯片称为无用的废片,有些客户因此遭受损失,虽然我们已经尽可能地告知客户们。

问题描述

在 armv8 aarch64中,arm规定了过程调用规范Procedure Call Standard for the ARM 64-bit Architecture’--AAPCS64,这个规范时规定在函数调用过程中怎么传输入和输出参数,哪些寄存器需要调用者保护,哪些寄存器需要被调用者保护。之所以要定义这个规范就是要使不同的compiler (arm compiler, gcc, llvm)生成的库能兼容地被使用,能被链接器链接起来生成一个可执行文件或是库。这保证了arm生态的软件兼容,非常重要。

和我们这次要讨论的话题相关的是怎么来传浮点数的函数输入输出参数。

在Armv7的AAPCS32规范里,我们实际上定义了两种传浮点数的方式:

softfp

hardfp

这两个的区别在于,softfp 是用整形的通用寄存器(r0-r3)来传浮点数参数的,比如

float fadd(float a, float b)

a和b实际上是通过r0,r1传入到被调函数的,结果也是通过r0传出的。

但如果使用hardfp,那么用浮点数寄存器来传参数,以上同样的例子,a和b是通过s0, s1寄存器来传的,结果是通过s0传出的。

在GCC compiler里提供了一下选项来选择你编译的代码是使用哪个方式

-mfloat-abi=softfp/hard

因为使用不同的参数传递方式,所以你不能将一个使用softfp另外一个使用hardfp的库或目标文件链接起来。

正式因为如此,在armv7的时候有些编译好的库(比如glibc使用softfp)没法在使用另一种(使用hardfp)的应用编译中。


有的工具链直接只支持一种方式比如arm-linux-gnueabi,和arm-linux-gnueabihf

但是维护这种不同的ABI带来了兼容性维护的问题,比如同样一套库可能要提供两个版本。因此很多OS厂商开始只支持一种方式,比如ubuntu从12.04开始只支持hardfp.

正是因为以上原因,armv8 aarch64的AAPCS只支持hardfp,这就需要用到NEON/FPU寄存器。如果你的CPU配置了没有NEON/FPU,可能软件上会带来比较大的问题,导致一些通用的OS分发版本(ubuntu,Redhat)没法正常跑。

对软件和compiler的影响

Compiler和一般的OS分发版本都会假设armv8

aarch64的CPU是带NEON/FPU的,除非你能非常肯定地知道你的软件和库不会使用任何的浮点数运算,这样的话我们之后会提供一些编译选项,以便compiler不生成使用浮点数的指令。这样的话你或许可以在RTL里去掉NEON/FPU.

对Linux kernel的影响

为了可以是之前的32位且使用softfp应用可以跑在arm64kernel上,Linux kernel提供下面的patch,

https://patchwork.kernel.org/patch/9405787/

这个patch允许arm64 Linux kernel本身可以在没有NEON/FPU的CPU上跑。

但是我们不建议去除NEON/FPU,因为你可能需要跑通用的Linux kernel.即使Linux kernel本身可以在没有NEON/FPU的CPU上运行,但是还需要考虑user space的应用和库是使用AAPCS64ABI编译的,他们还是需要NEON/FPU.

Compiler的支持

GCC提供了-mgeneral-regs-onlyoption选项,这个选项禁止生成的代码使用浮点数寄存器,但他不限制汇编使用浮点数寄存器。

Arm compiler 6也提供了-mcpu=name+nofp+nosimd这个选项达到以上目标,但是一旦使用这个选项,你的代码就不能有浮点数的类型和运算。

如果你肯定你的程序和库都只需要整形运算,你可以试以上选项,这样的话就不需要NEON/FPU的硬件支持。

http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0773g/chr1383143713787.html

Linux分发版本情况



附录

AAPCS32 allows both soft and hard float ABI by defining ‘The base standard’ and ‘The standard variants’.



5 THE BASE PROCEDURE CALL STANDARD 

The

base standard defines a machine-level, core-registers-only calling

standard common to the ARM and Thumb instruction sets. It should be used

for systems where there is no floating-point hardware, or where a high

degree of inter-working with Thumb code is required.

6.1 VFP and Advanced SIMD Register Arguments 

This

variant alters the manner in which floating-point values are passed

between a subroutine and its caller and allows significantly better

performance when a VFP co-processor or the Advanced SIMD Extension is

present.


6.1.1 Mapping between registers and memory format 

Values passed across a procedure call interface in VFP registers are laid out as follows: 

• A

half precision floating point type is passed as if it were loaded from

its memory format into the least significant 16 bits of a single

precision register. 

• A

single precision floating point type is passed as if it were loaded

from its memory format into a single precision register with VLDR. 

• A

double precision floating point type is passed as if it were loaded

from its memory format into a double precision register with VLDR.

See more information in AAPCS32 spec,

http://infocenter.arm.com/help/topic/com.arm.doc.ihi0042f/IHI0042F_aapcs.pdf

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容