Implementation notes: amd64, skylake, crypto_aead/deoxyseq256128v1

Computer: skylake
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20161026
Operation: crypto_aead
Primitive: deoxyseq256128v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
11436optgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
11448optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
11684optgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
11740optgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
11760optgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
11766optgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
11770optgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
11774optgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
11776optgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
11776optgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
11778optgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
11794optgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
11832optgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
11866optgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
11870optgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
11882optgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
11894optgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
11920optgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
11932optgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
12136optgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
12510optclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
12642optclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
12658optclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
12666optclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
1592338refclang -O3 -fomit-frame-pointer -Qunused-arguments2016121620161026
1598786refclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
1599752refclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments2016121620161026
1599988refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1600654refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
1602940refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments2016121620161026
1603888refclang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1607262refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
1608266refclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1652994refclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1905772refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2016121620161026
1905900refgcc -O3 -fomit-frame-pointer2016121620161026
1909194refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
1911724refgcc -m64 -O3 -fomit-frame-pointer2016121620161026
1952500refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
1955656refgcc -funroll-loops -O3 -fomit-frame-pointer2016121620161026
1977764refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2016121620161026
1982478refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
1997016refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2016121620161026
2002464refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
2008208refgcc -march=nocona -O3 -fomit-frame-pointer2016121620161026
2165604refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
2167194refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2016121620161026
2176260refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2016121620161026
2177794refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
2310952refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
2328100refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
2338534refgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
2414696refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
2416162refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2016121620161026
2433710refgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
2434940refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2016121620161026
2435226refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer2016121620161026
2439734refgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
2444724refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2016121620161026
2481478refgcc -funroll-loops -O2 -fomit-frame-pointer2016121620161026
2481990refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
2482716refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2016121620161026
2495262refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
2495400refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2016121620161026
2538490refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2016121620161026
2543586refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
2553052refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
2553646refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
2556556refgcc -march=k8 -O3 -fomit-frame-pointer2016121620161026
2590768refgcc -march=barcelona -O3 -fomit-frame-pointer2016121620161026
2839506refgcc -march=nocona -O2 -fomit-frame-pointer2016121620161026
2840314refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
2852790refgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
2853366refgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
2886878refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
2887244refgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
2889772refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2016121620161026
2911858refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
3024988refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2016121620161026
3025278refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2016121620161026
3031144refgcc -march=k8 -O2 -fomit-frame-pointer2016121620161026
3038286refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2016121620161026
3060950refgcc -O2 -fomit-frame-pointer2016121620161026
3061356refgcc -m64 -O2 -fomit-frame-pointer2016121620161026
3071530refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
3073996refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
3082628refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
3083044refgcc -march=barcelona -O2 -fomit-frame-pointer2016121620161026
3919608refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2016121620161026
3937552refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
4146300refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2016121620161026
4168374refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
4173324refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
4198386refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2016121620161026
4542718refgcc -funroll-loops -O -fomit-frame-pointer2016121620161026
4547906refgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
4551488refgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
4582158refgcc -funroll-loops -m64 -O -fomit-frame-pointer2016121620161026
4597254refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
4737622refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
4747296refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2016121620161026
4773174refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2016121620161026
4773710refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
4801954refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2016121620161026
4815942refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
4820972refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2016121620161026
4850908refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
4855422refgcc -funroll-loops -Os -fomit-frame-pointer2016121620161026
4859792refgcc -march=k8 -Os -fomit-frame-pointer2016121620161026
4866300refgcc -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
4875766refgcc -m64 -Os -fomit-frame-pointer2016121620161026
4878512refgcc -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
4881664refgcc -Os -fomit-frame-pointer2016121620161026
4903246refgcc -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
4905912refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2016121620161026
4906542refgcc -m64 -march=core2 -Os -fomit-frame-pointer2016121620161026
4911746refgcc -march=barcelona -Os -fomit-frame-pointer2016121620161026
4912860refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2016121620161026
4917700refgcc -march=k8 -O -fomit-frame-pointer2016121620161026
4919718refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
4944816refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2016121620161026
5031420refgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
5033238refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2016121620161026
5059502refgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
5066030refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2016121620161026
5079120refgcc -m64 -march=core2 -O -fomit-frame-pointer2016121620161026
5083744refgcc -m64 -march=corei7 -O -fomit-frame-pointer2016121620161026
5132334refgcc -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
5172734refgcc -march=barcelona -O -fomit-frame-pointer2016121620161026
5186024refgcc -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
5186406refgcc -O -fomit-frame-pointer2016121620161026
5186482refgcc -m64 -O -fomit-frame-pointer2016121620161026
5288340refgcc -march=nocona -O -fomit-frame-pointer2016121620161026
5319284refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
5355392refgcc -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
5365240refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
5374874refgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
5384008refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
5396006refgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
5413228refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
5694352refgcc -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
5695084refgcc -march=nocona -Os -fomit-frame-pointer2016121620161026
10745072refgcc2016121620161026
10774656refcc2016121620161026
10808222refgcc -funroll-loops2016121620161026

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: cc
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: deoxys-256.c: In function 'XLS':
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:95:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[16] , t ) );
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:28:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '_mm_shuffle_epi8': target specific option mismatch
deoxys-256.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:94:40: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[15] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: ...

Number of similar (compiler,implementation) pairs: 71, namely:
CompilerImplementations
cc opt
gcc opt
gcc -O2 -fomit-frame-pointer opt
gcc -O3 -fomit-frame-pointer opt
gcc -O -fomit-frame-pointer opt
gcc -Os -fomit-frame-pointer opt
gcc -fno-schedule-insns -O2 -fomit-frame-pointer opt
gcc -fno-schedule-insns -O3 -fomit-frame-pointer opt
gcc -fno-schedule-insns -O -fomit-frame-pointer opt
gcc -fno-schedule-insns -Os -fomit-frame-pointer opt
gcc -funroll-loops opt
gcc -funroll-loops -O2 -fomit-frame-pointer opt
gcc -funroll-loops -O3 -fomit-frame-pointer opt
gcc -funroll-loops -O -fomit-frame-pointer opt
gcc -funroll-loops -Os -fomit-frame-pointer opt
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer opt
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer opt
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer opt
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer opt
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -O -fomit-frame-pointer opt
gcc -funroll-loops -m64 -Os -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer opt
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer opt
gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer opt
gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer opt
gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer opt
gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer opt
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer opt
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer opt
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer opt
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer opt
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer opt
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer opt
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer opt
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer opt
gcc -m64 -O2 -fomit-frame-pointer opt
gcc -m64 -O3 -fomit-frame-pointer opt
gcc -m64 -O -fomit-frame-pointer opt
gcc -m64 -Os -fomit-frame-pointer opt
gcc -m64 -march=k8 -O2 -fomit-frame-pointer opt
gcc -m64 -march=k8 -O3 -fomit-frame-pointer opt
gcc -m64 -march=k8 -O -fomit-frame-pointer opt
gcc -m64 -march=k8 -Os -fomit-frame-pointer opt
gcc -m64 -march=nocona -O2 -fomit-frame-pointer opt
gcc -m64 -march=nocona -O3 -fomit-frame-pointer opt
gcc -m64 -march=nocona -O -fomit-frame-pointer opt
gcc -m64 -march=nocona -Os -fomit-frame-pointer opt
gcc -march=barcelona -O2 -fomit-frame-pointer opt
gcc -march=barcelona -O3 -fomit-frame-pointer opt
gcc -march=barcelona -O -fomit-frame-pointer opt
gcc -march=barcelona -Os -fomit-frame-pointer opt
gcc -march=k8 -O2 -fomit-frame-pointer opt
gcc -march=k8 -O3 -fomit-frame-pointer opt
gcc -march=k8 -O -fomit-frame-pointer opt
gcc -march=k8 -Os -fomit-frame-pointer opt
gcc -march=nocona -O2 -fomit-frame-pointer opt
gcc -march=nocona -O3 -fomit-frame-pointer opt
gcc -march=nocona -O -fomit-frame-pointer opt
gcc -march=nocona -Os -fomit-frame-pointer opt

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:77:45: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS1 = constant8( (0x8 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:78:45: warning: implicit conversion from 'int' to 'char' changes value from 144 to -112 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS2 = constant8( (0x9 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:92:21: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'XLS' that is compiled without support for 'ssse3'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^
deoxys-256.c: ./tweakable-cipher.macros:79:41: note: expanded from macro 'AES'
deoxys-256.c: s = xor( s , xor( subkeys[ 0] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c: ^
deoxys-256.c: ./tweakable-cipher.macros:7:22: note: expanded from macro 'permute'
deoxys-256.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys-256.c: ^
deoxys-256.c: deoxys-256.c:92:21: error: always_inline function '_mm_aesenc_si128' requires target feature 'aes', but would be inlined into function 'XLS' that is compiled without support for 'aes'
deoxys-256.c: ./tweakable-cipher.macros:80:5: note: expanded from macro 'AES'
deoxys-256.c: s = enc( s , xor( subkeys[ 1] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c: ^
deoxys-256.c: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments opt
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments opt
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments opt
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments opt

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:77:45: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS1 = constant8( (0x8 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:78:45: warning: implicit conversion from 'int' to 'char' changes value from 144 to -112 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS2 = constant8( (0x9 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:585:16: warning: comparison of unsigned expression deoxys-256.c: if( c_len deoxys-256.c: ~~~~~ ^ ~
deoxys-256.c: 3 warnings generated.

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments opt
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments opt

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:77:45: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS1 = constant8( (0x8 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:78:45: warning: implicit conversion from 'int' to 'char' changes value from 144 to -112 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_XLS2 = constant8( (0x9 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: #define constant8(b15,b14,b13,b12,b11,b10,b9,b8,b7,b6,b5,b4,b3,b2,b1,b0) _mm_set_epi8 ((b0),(b1),(b2),(b3),(b4),(b5),(b6),(b7),(b8),(b9),(b10),(b11),(b12),(b13),(b14),(b15))
deoxys-256.c: ~~~~~~~~~~~~ ^~~
deoxys-256.c: deoxys-256.c:92:21: error: always_inline function '_mm_aesenc_si128' requires target feature 'aes', but would be inlined into function 'XLS' that is compiled without support for 'aes'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^
deoxys-256.c: ./tweakable-cipher.macros:80:5: note: expanded from macro 'AES'
deoxys-256.c: s = enc( s , xor( subkeys[ 1] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c: ^
deoxys-256.c: ./tweakable-cipher.macros:1:18: note: expanded from macro 'enc'
deoxys-256.c: #define enc(a,b) _mm_aesenc_si128(a,b)
deoxys-256.c: ^
deoxys-256.c: deoxys-256.c:92:21: error: always_inline function '_mm_aesenc_si128' requires target feature 'aes', but would be inlined into function 'XLS' that is compiled without support for 'aes'
deoxys-256.c: ./tweakable-cipher.macros:81:5: note: expanded from macro 'AES'
deoxys-256.c: s = enc( s , xor( subkeys[ 2] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c: ^
deoxys-256.c: ...

Number of similar (compiler,implementation) pairs: 2, namely:
CompilerImplementations
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments opt

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: deoxys-256.c: In function 'XLS':
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:95:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[16] , t ) );
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:28:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '_mm_shuffle_epi8': target specific option mismatch
deoxys-256.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:94:40: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[15] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: ...
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: deoxys-256.c: In function 'XLS':
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:95:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[16] , t ) );
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:28:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '_mm_shuffle_epi8': target specific option mismatch
deoxys-256.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:94:40: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[15] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -m64 -march=barcelona -O2 -fomit-frame-pointer opt
gcc -m64 -march=barcelona -O3 -fomit-frame-pointer opt
gcc -m64 -march=barcelona -O -fomit-frame-pointer opt
gcc -m64 -march=barcelona -Os -fomit-frame-pointer opt

Compiler output

Implementation: crypto_aead/deoxyseq256128v1/opt
Compiler: gcc -m64 -march=core2 -O2 -fomit-frame-pointer
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: deoxys-256.c: In function 'XLS':
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:95:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[16] , t ) );
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys-256.c: ^~~~~~~~~~~~~~~~
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: tweakable-cipher.macros:94:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[15] , t ) );t=permute( t , H_PERMUTATION);\
deoxys-256.c:
deoxys-256.c: deoxys-256.c:92:21: note: in expansion of macro 'AES'
deoxys-256.c: if( Direction){ AES( State , subkeys , Tweak , tTweak ); }
deoxys-256.c: ^~~
deoxys-256.c: In file included from deoxys-256.c:27:0:
deoxys-256.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:61:1: error: inlining failed in call to always_inline '_mm_aesenc_si128': target specific option mismatch
deoxys-256.c: ...

Number of similar (compiler,implementation) pairs: 16, namely:
CompilerImplementations
gcc -m64 -march=core2 -O2 -fomit-frame-pointer opt
gcc -m64 -march=core2 -O3 -fomit-frame-pointer opt
gcc -m64 -march=core2 -O -fomit-frame-pointer opt
gcc -m64 -march=core2 -Os -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer opt
gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer opt
gcc -m64 -march=corei7 -O2 -fomit-frame-pointer opt
gcc -m64 -march=corei7 -O3 -fomit-frame-pointer opt
gcc -m64 -march=corei7 -O -fomit-frame-pointer opt
gcc -m64 -march=corei7 -Os -fomit-frame-pointer opt