我有几个Android NDK应用程序,但人们抱怨我的应用程序在他们的手机上无法正常工作。我想知道的是,哪些编译设置将支持市场上大多数,如果不是所有ARM设备?我的问题似乎是armeabi-v7a设备对VFP、NEON等的支持程度不同。我正在寻找一种解决方案,可以构建运行于最多平台上的应用程序,即使这样会牺牲优化成本。我使用了默认的NDK构建脚本来指定armeabi和armeabi-v7a,如下所示:
-march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3
。但这在某些设备上无效,例如Acer A500(CPU Nvidia Tegra2(双核Cortex A9))。从这里http://wiki.debian.org/ArmHardFloatPort/VfpComparison学到,该CPU没有实现NEON。具体而言,崩溃是这样的:F/libc (15549): Fatal signal 4 (SIGILL) at 0x5bfd9260 (code=1)
...(snip)...
I/DEBUG ( 81): #00 pc 0005b260 /data/data/com.burnsmod.oscpad/lib/libapplication.so (tanf)
看 libapplication.so,我发现 tanf 生成为:
0005b25c <tanf>:
5b25c: ee070a90 fmsr s15, r0
5b260: eef70ae7 fcvtds d16, s15
5b264: e92d4010 push {r4, lr}
5b268: ec510b30 vmov r0, r1, d16
5b26c: ebff4b6c bl 2e024 <_ZN15ButtonUIHandler10FreeImagesEv-0x6ac>
5b270: ec410b30 vmov d16, r0, r1
5b274: eef77be0 fcvtsd s15, d16
5b278: ee170a90 fmrs r0, s15
5b27c: e8bd8010 pop {r4, pc}
那么,答案是什么?vfpv2?vfp?vfpv3?vfpv3-d16?
现在,如果我使用readelf,我会发现我的应用程序库的依赖关系如下:
MacBook:armeabi-v7a tom$ arm-linux-androideabi-readelf -A libapplication.so
Attribute Section: aeabi
File Attributes
Tag_CPU_name: "7-A"
Tag_CPU_arch: v7
Tag_CPU_arch_profile: Application
Tag_ARM_ISA_use: Yes
Tag_THUMB_ISA_use: Thumb-2
Tag_VFP_arch: VFPv3
Tag_ABI_PCS_wchar_t: 4
Tag_ABI_FP_denormal: Needed
Tag_ABI_FP_exceptions: Needed
Tag_ABI_FP_number_model: IEEE 754
Tag_ABI_align8_needed: Yes
Tag_ABI_align8_preserved: Yes, except leaf SP
Tag_ABI_enum_size: int
Tag_ABI_HardFP_use: SP and DP
VFP2:使用“-mfpu=vfpv2”或“-mfpu=vfp2”编译是不支持在NDK 7中的,两者都会返回错误消息。