Implementation notes: amd64, genji262, crypto_stream/speck128128ctr

Computer: genji262
Architecture: amd64
CPU ID: AuthenticAMD-00800f12-178bfbff
SUPERCOP version: 20191017
Operation: crypto_stream
Primitive: speck128128ctr

Checksum failure

Implementation: sse4
Security model: unknown
Compiler: icc -march=broadwell -mtune=broadwell -O2 -fomit-frame-pointer
10a6088229002738c15101b79285023d94e4218f17d2c2df2741fd673971df50
Number of similar (compiler,implementation) pairs: 18, namely:
CompilerImplementations
icc -march=broadwell -mtune=broadwell -O2 -fomit-frame-pointer sse4
icc -march=broadwell -mtune=broadwell -O3 -fomit-frame-pointer sse4
icc -march=core-avx-i -mtune=core-avx-i -O2 -fomit-frame-pointer sse4
icc -march=core-avx-i -mtune=core-avx-i -O3 -fomit-frame-pointer sse4
icc -march=core-avx2 -mtune=core-avx2 -O2 -fomit-frame-pointer sse4
icc -march=core-avx2 -mtune=core-avx2 -O3 -fomit-frame-pointer sse4
icc -march=corei7-avx -mtune=corei7-avx -O2 -fomit-frame-pointer sse4
icc -march=corei7-avx -mtune=corei7-avx -O3 -fomit-frame-pointer sse4
icc -march=corei7 -mtune=corei7 -O2 -fomit-frame-pointer sse4
icc -march=corei7 -mtune=corei7 -O3 -fomit-frame-pointer sse4
icc -march=haswell -mtune=haswell -O2 -fomit-frame-pointer sse4
icc -march=haswell -mtune=haswell -O3 -fomit-frame-pointer sse4
icc -march=ivybridge -mtune=ivybridge -O2 -fomit-frame-pointer sse4
icc -march=ivybridge -mtune=ivybridge -O3 -fomit-frame-pointer sse4
icc -march=sandybridge -mtune=sandybridge -O2 -fomit-frame-pointer sse4
icc -march=sandybridge -mtune=sandybridge -O3 -fomit-frame-pointer sse4
icc -march=skylake -mtune=skylake -O2 -fomit-frame-pointer sse4
icc -march=skylake -mtune=skylake -O3 -fomit-frame-pointer sse4

Test failure

Implementation: avx2
Security model: unknown
Compiler: icc -march=cannonlake -mtune=cannonlake -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 36, namely:
CompilerImplementations
icc -march=cannonlake -mtune=cannonlake -O2 -fomit-frame-pointer avx2
icc -march=cannonlake -mtune=cannonlake -O3 -fomit-frame-pointer avx2
icc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer avx2
icc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer avx2
icc -march=skylake-avx512 -mtune=skylake-avx512 -O2 -fomit-frame-pointer avx2
icc -march=skylake-avx512 -mtune=skylake-avx512 -O3 -fomit-frame-pointer avx2
icc -march=broadwell -mtune=broadwell -O2 -fomit-frame-pointer avx512
icc -march=broadwell -mtune=broadwell -O3 -fomit-frame-pointer avx512
icc -march=cannonlake -mtune=cannonlake -O2 -fomit-frame-pointer avx512
icc -march=cannonlake -mtune=cannonlake -O3 -fomit-frame-pointer avx512
icc -march=core-avx-i -mtune=core-avx-i -O2 -fomit-frame-pointer avx512
icc -march=core-avx-i -mtune=core-avx-i -O3 -fomit-frame-pointer avx512
icc -march=core-avx2 -mtune=core-avx2 -O2 -fomit-frame-pointer avx512
icc -march=core-avx2 -mtune=core-avx2 -O3 -fomit-frame-pointer avx512
icc -march=corei7-avx -mtune=corei7-avx -O2 -fomit-frame-pointer avx512
icc -march=corei7-avx -mtune=corei7-avx -O3 -fomit-frame-pointer avx512
icc -march=corei7 -mtune=corei7 -O2 -fomit-frame-pointer avx512
icc -march=corei7 -mtune=corei7 -O3 -fomit-frame-pointer avx512
icc -march=haswell -mtune=haswell -O2 -fomit-frame-pointer avx512
icc -march=haswell -mtune=haswell -O3 -fomit-frame-pointer avx512
icc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer avx512
icc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer avx512
icc -march=ivybridge -mtune=ivybridge -O2 -fomit-frame-pointer avx512
icc -march=ivybridge -mtune=ivybridge -O3 -fomit-frame-pointer avx512
icc -march=sandybridge -mtune=sandybridge -O2 -fomit-frame-pointer avx512
icc -march=sandybridge -mtune=sandybridge -O3 -fomit-frame-pointer avx512
icc -march=skylake-avx512 -mtune=skylake-avx512 -O2 -fomit-frame-pointer avx512
icc -march=skylake-avx512 -mtune=skylake-avx512 -O3 -fomit-frame-pointer avx512
icc -march=skylake -mtune=skylake -O2 -fomit-frame-pointer avx512
icc -march=skylake -mtune=skylake -O3 -fomit-frame-pointer avx512
icc -march=cannonlake -mtune=cannonlake -O2 -fomit-frame-pointer sse4
icc -march=cannonlake -mtune=cannonlake -O3 -fomit-frame-pointer sse4
icc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer sse4
icc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer sse4
icc -march=skylake-avx512 -mtune=skylake-avx512 -O2 -fomit-frame-pointer sse4
icc -march=skylake-avx512 -mtune=skylake-avx512 -O3 -fomit-frame-pointer sse4

Compiler output

Implementation: avx2
Security model: unknown
Compiler: clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
stream.c: In file included from stream.c:20:
stream.c: In file included from ./Speck128128AVX2.h:17:
stream.c: In file included from ./Intrinsics_AVX2_128block.h:5:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/immintrin.h:27:
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:55:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:61:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:68:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:74:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:84:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:90:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:97:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2
clang -march=native -O -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2
clang -march=native -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx2

Compiler output

Implementation: avx512
Security model: unknown
Compiler: clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
stream.c: In file included from stream.c:21:
stream.c: In file included from ./Speck128128AVX512.h:17:
stream.c: In file included from ./Intrinsics_AVX512_128block.h:5:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/immintrin.h:27:
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:55:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:61:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:68:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:74:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:84:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:90:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:97:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx512
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx512
clang -march=native -O -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx512
clang -march=native -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx512
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE avx512

Compiler output

Implementation: avx512
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
stream.c: In file included from Speck128128AVX512.h:17,
stream.c: from stream.c:21:
stream.c: stream.c: In function 'Encrypt':
stream.c: Intrinsics_AVX512_128block.h:25:21: warning: AVX512F vector return without AVX512F enabled changes the ABI [-Wpsabi]
stream.c: 25 | #define SET1(X,c) (X=SET(c,c,c,c,c,c,c,c))
stream.c: | ~~^~~~~~~~~~~~~~~~~~~~~~
stream.c: stream.c:135:5: note: in expansion of macro 'SET1'
stream.c: 135 | SET1(X[0],nonce[1]); SET8(Y[0],nonce[0]);
stream.c: | ^~~~
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/immintrin.h:55,
stream.c: from Intrinsics_AVX512_128block.h:5,
stream.c: from Speck128128AVX512.h:17,
stream.c: from stream.c:21:
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/avx512fintrin.h:6408:1: error: inlining failed in call to always_inline '_mm512_storeu_si512': target specific option mismatch
stream.c: 6408 | _mm512_storeu_si512 (void *__P, __m512i __A)
stream.c: | ^~~~~~~~~~~~~~~~~~~
stream.c: In file included from Speck128128AVX512.h:17,
stream.c: from stream.c:21:
stream.c: Intrinsics_AVX512_128block.h:32:18: note: called from here
stream.c: 32 | #define ST(ip,X) _mm512_storeu_si512((void *)(ip),X)
stream.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
stream.c: Intrinsics_AVX512_128block.h:33:43: note: in expansion of macro 'ST'
stream.c: 33 | #define STORE(out,X,Y) (ST(out,LOW(Y,X)), ST(out+64,HIGH(Y,X)))
stream.c: | ^~
stream.c: stream.c:138:5: note: in expansion of macro 'STORE'
stream.c: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE avx512
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE avx512
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE avx512
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE avx512

Compiler output

Implementation: sse4
Security model: unknown
Compiler: clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
stream.c: In file included from stream.c:20:
stream.c: In file included from ./Speck128128SSE4.h:17:
stream.c: In file included from ./Intrinsics_SSE4_128block.h:5:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/smmintrin.h:32:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/tmmintrin.h:31:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/pmmintrin.h:31:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/emmintrin.h:31:
stream.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/xmmintrin.h:31:
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:55:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:61:72: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:68:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:74:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:84:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ^
stream.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/mmintrin.h:90:74: warning: unknown attribute '__artificial__' ignored [-Wunknown-attributes]
stream.c: extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
stream.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -march=native -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sse4
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sse4
clang -march=native -O -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sse4
clang -march=native -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sse4
clang -mcpu=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sse4

Compiler output

Implementation: sse4
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
stream.c: stream.c:99:12: error: static declaration of 'Encrypt' follows non-static declaration
stream.c: 99 | static int Encrypt(unsigned char *out, u64 nonce[], u128 rk[], u64 key[], int numbytes)
stream.c: | ^~~~~~~
stream.c: stream.c:23:5: note: previous declaration of 'Encrypt' was here
stream.c: 23 | int Encrypt(unsigned char *out, u64 nonce[], u128 rk[], u64 key[], int numbytes);
stream.c: | ^~~~~~~
stream.c: stream.c:212:12: error: static declaration of 'Encrypt_Xor' follows non-static declaration
stream.c: 212 | static int Encrypt_Xor(unsigned char *out, const unsigned char *in, u64 nonce[], u128 rk[], u64 key[], int numbytes)
stream.c: | ^~~~~~~~~~~
stream.c: stream.c:25:5: note: previous declaration of 'Encrypt_Xor' was here
stream.c: 25 | int Encrypt_Xor(unsigned char *out, const unsigned char *in, u64 nonce[], u128 rk[], u64 key[], int numbytes);
stream.c: | ^~~~~~~~~~~
stream.c: stream.c:253:12: error: static declaration of 'ExpandKey' follows non-static declaration
stream.c: 253 | static int ExpandKey(u64 K[], u128 rk[], u64 key[])
stream.c: | ^~~~~~~~~
stream.c: stream.c:26:5: note: previous declaration of 'ExpandKey' was here
stream.c: 26 | int ExpandKey(u64 K[], u128 rk[], u64 key[]);
stream.c: | ^~~~~~~~~

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE sse4
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE sse4
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE sse4
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE sse4