繁体   English   中英

如何在ARMv8-a上启用Aarch32指令集?

[英]How to enable Aarch32 instruction set on ARMv8-a?

Raspberry Pi 3使用带有ARMv8 A53内核的Broadcom SoC 它还使用基于Debian Jessie的32位操作系统。 根据ARM的ARM NEON编程快速参考 ,第3.2节, 指令集

ARMv8-A AArch32指令集由A32(ARM指令集,一个32位固定长度的指令集)和T32(Thumb指令集,一个16位固定长度的指令集; Thumb2指令集,16或32位长度)组成指令系统)。 它是ARMv7-A指令集的超集,因此保留了运行现有软件所需的向后兼容性。 A32和T32有一些附加功能,以保持与A64指令集的对齐,包括NEON除法和加密扩展指令。 还支持NEON双精度浮点(符合IEEE标准)。

我曾在GCC邮件列表上的“ 如何在Aarch64上测试Aarch32执行环境”上问过类似的问题 但是我不太明白答案:

使用arm工具链进行编译后,可以通过-march=armv8-a+crc或选择启用它的-mcpu选项来启用CRC扩展。 要启用Crypto扩展,您必须指定正确的-mfpu选项。

我的问题很简单...如何为Raspberry Pi 3启用CRC和Crypto扩展?


这是一些无效的尝试。

尝试(4)与我们在Aarch64下本机执行的操作类似: gcc -march=armv8-a+crc+crypto -mtune=cortex-a53 尝试(5)实际上启用了CRC,但是我似乎无法启用其他任何功能,例如PMULLPMULL2AESSHA1SHA2

  1. gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a+crc+crypto -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
  2. gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a+crc -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
  3. gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
  4. gcc -march=armv8-a+crc+crypto -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
  5. gcc -march=armv8-a+crc -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
  6. gcc -march=armv8-a -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe

$ gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/lib/gcc/arm-linux-gnueabihf/4.9/lto-wrapper
Target: arm-linux-gnueabihf
Configured with: ../src/configure -v --with-pkgversion='Raspbian 4.9.2-10' --with-bugurl=file:///usr/share/doc/gcc-4.9/README.Bugs --enable-languages=c,c++,java,go,d,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.9 --enable-shared --enable-linker-build-id --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.9 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --disable-libitm --disable-libquadmath --enable-plugin --with-system-zlib --disable-browser-plugin --enable-java-awt=gtk --enable-gtk-cairo --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-4.9-armhf/jre --enable-java-home --with-jvm-root-dir=/usr/lib/jvm/java-1.5.0-gcj-4.9-armhf --with-jvm-jar-dir=/usr/lib/jvm-exports/java-1.5.0-gcj-4.9-armhf --with-arch-directory=arm --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --enable-objc-gc --enable-multiarch --disable-sjlj-exceptions --with-arch=armv6 --with-fpu=vfp --with-float=hard --enable-checking=release --build=arm-linux-gnueabihf --host=arm-linux-gnueabihf --target=arm-linux-gnueabihf
Thread model: posix
gcc version 4.9.2 (Raspbian 4.9.2-10) 

很简单,“正确的-mfpu选项”应该是-mfpu=crypto-neon-fp-armv8

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM