2016-07-28 15 views
1

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のような有効にすることはできません。

  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) 

答えて

4

"-mfpuオプション"は-mfpu=crypto-neon-fp-armv8である必要があります。

+0

でも、-mfpu = neon-vfpv4とすることをお勧めします。-mfpu = neonは古いCortex-A8/A9 FPU用であり、いくつかの新しい命令では欠けています。 – Notlikethat

+0

これらの人たちはどこからこのようなことを思いついたのですか?それは、[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

+0

@jww:あなたはAArch64をターゲットにしていません。関連するコンパイラオプションは、常にホストではなくターゲットに依存します。 AArch64システムからクロスコンパイルしても問題ありません。私は '-m32'だけには適用されるが、' -m64'や '-mx32'には適用されないx86オプションがあると確信しています。アーキテクチャはAArch32とAArch64よりもおそらくもっと似ているので、私はドキュメントがx86のためにもっといっそうまとまっていると思うが。 –

関連する問題