Raspberry Pi 3 uses a Broadcom SoC with and ARMv8 A53 core。 Debian Jessieに基づく32ビットOSも使用しています。 ARMのARM NEON programming quick reference、3.2節によれば、命令がを設定:ARMv8-aでAarch32命令セットを有効にするにはどうすればよいですか?
ARMv8-AArch32命令セットは、A32(ARM命令セット、32ビット固定長命令セット)及びT32(Thumb命令セットで構成され、 16ビット固定長命令セット、Thumb2命令セット、16または32ビット長命令セット)。 ARMv7-A命令セットのスーパーセットであるため、既存のソフトウェアを実行するために必要な下位互換性が保持されます。 A32とT32には、A64命令セットとの位置合わせを維持するために、NEON除算と暗号拡張命令を含むいくつかの追加があります。 NEON倍精度浮動小数点(IEEE準拠)もサポートされています。
私は一種のHow to test Aarch32 execution environment on Aarch64?でしばらく前にGCCのメーリングリストに同様の質問をしかし、私はかなりの答えを理解していなかった。
あなたはアームツールチェーンとCRCの拡張子をコンパイルしたら
-march=armv8-a+crc
を使用して有効にするか、有効にする-mcpu
オプションを選択して有効にすることができます。暗号拡張を有効にするには、右の-mfpu
オプションを指定する必要があります。
私の質問は簡単です...私はどのようにしてRaspberry Pi 3のCRC拡張とCrypto拡張を有効にしますか?
ここでは動作しないいくつかの試みがあります。
試行(4)は、Aarch64:gcc -march=armv8-a+crc+crypto -mtune=cortex-a53
でネイティブに行う方法と似ています。試行(5)は実際にCRCを有効にしますが、PMULL
,PMULL2
,AES
,SHA1
およびSHA2
のような有効にすることはできません。
gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a+crc+crypto -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a+crc -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
gcc -D__ARM_FEATURE_CRYPTO -D__ARM_FEATURE_CRC -march=armv8-a -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
gcc -march=armv8-a+crc+crypto -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
gcc -march=armv8-a+crc -mcpu=cortex-a53 -mfpu=neon test.cc -o test.exe
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 = neon-vfpv4とすることをお勧めします。-mfpu = neonは古いCortex-A8/A9 FPU用であり、いくつかの新しい命令では欠けています。 – Notlikethat
これらの人たちはどこからこのようなことを思いついたのですか?それは、[GCCコマンドラインスイッチのARMブログ](http://community.arm.com/groups/tools/blog/2013/04/15/arm-cortex-a-processors-and-gcc-command-lines)があります。 [AArch64 Options](http://gcc.gnu.org/onlinedocs/gcc/AArch64-Options.html)に記載されていれば、それはいいと思います。 – jww
@jww:あなたはAArch64をターゲットにしていません。関連するコンパイラオプションは、常にホストではなくターゲットに依存します。 AArch64システムからクロスコンパイルしても問題ありません。私は '-m32'だけには適用されるが、' -m64'や '-mx32'には適用されないx86オプションがあると確信しています。アーキテクチャはAArch32とAArch64よりもおそらくもっと似ているので、私はドキュメントがx86のためにもっといっそうまとまっていると思うが。 –