Implementation notes: amd64, h4atom, crypto_stream/simon128256ctr

Computer: h4atom
Architecture: amd64
CPU ID: GenuineIntel-000106ca-bfe9fbff
SUPERCOP version: 20160806
Operation: crypto_stream
Primitive: simon128256ctr
TimeImplementationCompilerBenchmark dateSUPERCOP version
55744sse4gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016081220160806
62360sse4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016081220160806
62368sse4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016081220160806
67728sse4gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016081220160806

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: ...

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: 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: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:121:3: error: always_inline function '_mm256_set_epi64x' requires target feature 'xsave', but would be inlined into function 'Encrypt' that is compiled without support for 'xsave'
stream.c: SET1(X[0],nonce[1]);
stream.c: ^
stream.c: ./Intrinsics_AVX2_128block.h:22:22: note: expanded from macro 'SET1'
stream.c: #define SET1(X,c) (X=SET(c,c,c,c))
stream.c: ^
stream.c: ./Intrinsics_AVX2_128block.h:21:13: note: expanded from macro 'SET'
stream.c: #define SET _mm256_set_epi64x
stream.c: ^
stream.c: stream.c:122:3: error: always_inline function '_mm256_set_epi64x' requires target feature 'xsave', but would be inlined into function 'Encrypt' that is compiled without support for 'xsave'
stream.c: SET4(Y[0],nonce[0]);
stream.c: ^
stream.c: ./Intrinsics_AVX2_128block.h:23:22: note: expanded from macro 'SET4'
stream.c: #define SET4(X,c) (X=SET(c+3,c+1,c+2,c), c+=4)
stream.c: ^
stream.c: ./Intrinsics_AVX2_128block.h:21:13: note: expanded from macro 'SET'
stream.c: #define SET _mm256_set_epi64x
stream.c: ^
stream.c: stream.c:124:21: error: always_inline function '_mm256_xor_si256' requires target feature 'xsave', but would be inlined into function 'Encrypt' that is compiled without support for 'xsave'
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/avx2
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
stream.c: stream.c: In function 'crypto_stream_simon128256ctr_avx2':
stream.c: stream.c:42:3: warning: implicit declaration of function 'ExpandKey' [-Wimplicit-function-declaration]
stream.c: ExpandKey(K,rk,key);
stream.c: ^
stream.c: stream.c:54:5: warning: implicit declaration of function 'Encrypt' [-Wimplicit-function-declaration]
stream.c: Encrypt(out,nonce,rk,key,320);
stream.c: ^
stream.c: stream.c: In function 'crypto_stream_simon128256ctr_avx2_xor':
stream.c: stream.c:189:5: warning: implicit declaration of function 'Encrypt_Xor' [-Wimplicit-function-declaration]
stream.c: Encrypt_Xor(out,in,nonce,rk,key,320);
stream.c: ^
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/5/include/immintrin.h:41:0,
stream.c: from /usr/lib/gcc/x86_64-linux-gnu/5/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: ...

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

Compiler output

Implementation: crypto_stream/simon128256ctr/sse4
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
stream.c: stream.c: In function 'crypto_stream_simon128256ctr_sse4':
stream.c: stream.c:42:3: warning: implicit declaration of function 'ExpandKey' [-Wimplicit-function-declaration]
stream.c: ExpandKey(K,rk,key);
stream.c: ^
stream.c: stream.c:54:5: warning: implicit declaration of function 'Encrypt' [-Wimplicit-function-declaration]
stream.c: Encrypt(out,nonce,rk,key,128);
stream.c: ^
stream.c: stream.c: In function 'crypto_stream_simon128256ctr_sse4_xor':
stream.c: stream.c:163:5: warning: implicit declaration of function 'Encrypt_Xor' [-Wimplicit-function-declaration]
stream.c: Encrypt_Xor(out,in,nonce,rk,key,128);
stream.c: ^

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