Implementation notes: amd64, waldorf, crypto_stream/simon128256ctr

Computer: waldorf
Architecture: amd64
CPU ID: GenuineIntel-000106e5-bfebfbff
SUPERCOP version: 20160715
Operation: crypto_stream
Primitive: simon128256ctr
TimeImplementationCompilerBenchmark dateSUPERCOP version
39316sse4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016071820160715
43828sse4gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016071820160715
47708sse4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016071820160715
56356sse4gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016071820160715

Compiler output

Implementation: crypto_stream/simon128256ctr/avx2
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
stream.c: stream.c:33:3: error: use of undeclared identifier '__m256i'
stream.c: u256 rk[72];
stream.c: ^
stream.c: ./Intrinsics_AVX2_128block.h:10:14: note: expanded from macro 'u256'
stream.c: #define u256 __m256i
stream.c: ^
stream.c: stream.c:42:3: warning: implicit declaration of function 'ExpandKey' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: ExpandKey(K,rk,key);
stream.c: ^
stream.c: stream.c:42:15: error: use of undeclared identifier 'rk'
stream.c: ExpandKey(K,rk,key);
stream.c: ^
stream.c: stream.c:54:5: warning: implicit declaration of function 'Encrypt' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: Encrypt(out,nonce,rk,key,320);
stream.c: ^
stream.c: stream.c:54:23: error: use of undeclared identifier 'rk'
stream.c: Encrypt(out,nonce,rk,key,320);
stream.c: ^
stream.c: stream.c:59:23: error: use of undeclared identifier 'rk'
stream.c: Encrypt(out,nonce,rk,key,256);
stream.c: ^
stream.c: stream.c:64:23: error: use of undeclared identifier 'rk'
stream.c: Encrypt(out,nonce,rk,key,192);
stream.c: ^
stream.c: stream.c:69:23: error: use of undeclared identifier 'rk'
stream.c: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments avx2

Compiler output

Implementation: crypto_stream/simon128256ctr/sse4
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
stream.c: stream.c:42:3: warning: implicit declaration of function 'ExpandKey' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: ExpandKey(K,rk,key);
stream.c: ^
stream.c: stream.c:46:31: warning: implicit declaration of function '_lrotl' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: for(i=0;i stream.c: ^
stream.c: ./Simon128256SSE4.h:36:27: note: expanded from macro 'R2'
stream.c: #define R2(x,y,k1,k2) (y^=f(x), y^=k1, x^=f(y), x^=k2)
stream.c: ^
stream.c: ./Simon128256SSE4.h:35:16: note: expanded from macro 'f'
stream.c: #define f(x) ((LCS(x,1) & LCS(x,8)) ^ LCS(x,2))
stream.c: ^
stream.c: ./Intrinsics_SSE4_128block.h:12:13: note: expanded from macro 'LCS'
stream.c: #define LCS _lrotl
stream.c: ^
stream.c: stream.c:54:5: warning: implicit declaration of function 'Encrypt' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: Encrypt(out,nonce,rk,key,128);
stream.c: ^
stream.c: stream.c:163:5: warning: implicit declaration of function 'Encrypt_Xor' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: Encrypt_Xor(out,in,nonce,rk,key,128);
stream.c: ^
stream.c: stream.c:245:3: warning: implicit declaration of function '_lrotr' is invalid in C99 [-Wimplicit-function-declaration]
stream.c: EK(A,B,C,D,rk,key);
stream.c: ^
stream.c: ./Simon128256SSE4.h:59:8: note: expanded from macro 'EK'
stream.c: ...
try.c: crypto_stream_simon128256ctr.a(stream.o): In function `crypto_stream_simon128256ctr_sse4':
try.c: stream.c:(.text+0x...): undefined reference to `_lrotl'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotl'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotl'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotl'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotl'
try.c: crypto_stream_simon128256ctr.a(stream.o):stream.c:(.text+0x...): more undefined references to `_lrotl' follow
try.c: crypto_stream_simon128256ctr.a(stream.o): In function `ExpandKey':
try.c: stream.c:(.text+0x...): undefined reference to `_lrotr'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotr'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotr'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotr'
try.c: stream.c:(.text+0x...): undefined reference to `_lrotr'
try.c: crypto_stream_simon128256ctr.a(stream.o):stream.c:(.text+0x...): more undefined references to `_lrotr' follow
try.c: clang: error: linker command failed with exit code 1 (use -v to see invocation)

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sse4

Compiler output

Implementation: crypto_stream/simon128256ctr/avx2
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
stream.c: In file included from Simon128256AVX2.h:17:0,
stream.c: from stream.c:20:
stream.c: stream.c: In function 'Encrypt':
stream.c: Intrinsics_AVX2_128block.h:22:21: warning: AVX vector return without AVX enabled changes the ABI [-Wpsabi]
stream.c: #define SET1(X,c) (X=SET(c,c,c,c))
stream.c: ^
stream.c: stream.c:121:3: note: in expansion of macro 'SET1'
stream.c: SET1(X[0],nonce[1]);
stream.c: ^
stream.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/4.9/include/immintrin.h:41:0,
stream.c: from /usr/lib/gcc/x86_64-linux-gnu/4.9/include/x86intrin.h:46,
stream.c: from Intrinsics_AVX2_128block.h:5,
stream.c: from Simon128256AVX2.h:17,
stream.c: from stream.c:20:
stream.c: /usr/lib/gcc/x86_64-linux-gnu/4.9/include/avxintrin.h:1266:1: error: inlining failed in call to always_inline '_mm256_set_epi64x': target specific option mismatch
stream.c: _mm256_set_epi64x (long long __A, long long __B, long long __C,
stream.c: ^
stream.c: In file included from Simon128256AVX2.h:17:0,
stream.c: from stream.c:20:
stream.c: Intrinsics_AVX2_128block.h:21:13: error: called from here
stream.c: #define SET _mm256_set_epi64x
stream.c: ^
stream.c: Intrinsics_AVX2_128block.h:22:22: note: in expansion of macro 'SET'
stream.c: #define SET1(X,c) (X=SET(c,c,c,c))
stream.c: ^
stream.c: ...

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