Implementation notes: amd64, skylake, crypto_aead/deoxysneq256128v1

Computer: skylake
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20161026
Operation: crypto_aead
Primitive: deoxysneq256128v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
7764optgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
7772optgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
7776optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
7906optgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
7908optgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
7912optgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
7916optgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
7916optgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
7918optgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
7920optgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
7924optgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
7926optgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
7928optgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
7932optgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
7934optgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
8028optgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
8080optgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
8096optgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
8236optgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
8258optgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
1044154refclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1046374refclang -O3 -fomit-frame-pointer -Qunused-arguments2016121620161026
1048162refclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments2016121620161026
1049984refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
1050686refclang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1052762refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
1064964refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1065062refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments2016121620161026
1068392refclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
1077716refclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
1261370refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2016121620161026
1262722refgcc -O3 -fomit-frame-pointer2016121620161026
1263584refgcc -m64 -O3 -fomit-frame-pointer2016121620161026
1264202refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
1297836refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
1297986refgcc -funroll-loops -O3 -fomit-frame-pointer2016121620161026
1298046refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2016121620161026
1315054refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
1325684refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
1326136refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2016121620161026
1336340refgcc -march=nocona -O3 -fomit-frame-pointer2016121620161026
1430270refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1432738refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1436640refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
1445054refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2016121620161026
1527172refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
1529906refgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
1546506refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
1606908refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer2016121620161026
1609292refgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
1617852refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2016121620161026
1620528refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2016121620161026
1644272refgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
1663412refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2016121620161026
1663986refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
1664522refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
1666598refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2016121620161026
1687484refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
1688428refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1688450refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2016121620161026
1688460refgcc -funroll-loops -O2 -fomit-frame-pointer2016121620161026
1689152refgcc -march=k8 -O3 -fomit-frame-pointer2016121620161026
1689450refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
1691566refgcc -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1700378refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1700530refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1878924refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
1879796refgcc -march=nocona -O2 -fomit-frame-pointer2016121620161026
1888282refgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
1888348refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
1889900refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2016121620161026
1890126refgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
1890610refgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
1891474refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
1998512refgcc -march=k8 -O2 -fomit-frame-pointer2016121620161026
1999024refgcc -O2 -fomit-frame-pointer2016121620161026
1999060refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2016121620161026
1999146refgcc -m64 -O2 -fomit-frame-pointer2016121620161026
1999210refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
1999370refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2016121620161026
1999630refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
2004238refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2016121620161026
2039512refgcc -march=barcelona -O2 -fomit-frame-pointer2016121620161026
2039896refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
2755248refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2016121620161026
2757574refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
2826500refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2016121620161026
2850586refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
2865730refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2016121620161026
2878686refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
3042472refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2016121620161026
3046298refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
3051090refgcc -funroll-loops -O -fomit-frame-pointer2016121620161026
3068074refgcc -funroll-loops -m64 -O -fomit-frame-pointer2016121620161026
3084150refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2016121620161026
3088924refgcc -m64 -march=corei7 -O -fomit-frame-pointer2016121620161026
3092946refgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
3095294refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
3118344refgcc -m64 -march=core2 -O -fomit-frame-pointer2016121620161026
3127350refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2016121620161026
3128058refgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
3163874refgcc -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
3163944refgcc -march=k8 -O -fomit-frame-pointer2016121620161026
3172004refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2016121620161026
3173846refgcc -funroll-loops -Os -fomit-frame-pointer2016121620161026
3177168refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2016121620161026
3188088refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
3189258refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
3191186refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
3208724refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2016121620161026
3208742refgcc -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
3223054refgcc -march=barcelona -O -fomit-frame-pointer2016121620161026
3277800refgcc -O -fomit-frame-pointer2016121620161026
3302024refgcc -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
3312168refgcc -m64 -O -fomit-frame-pointer2016121620161026
3476176refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
3485038refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
3494626refgcc -march=nocona -Os -fomit-frame-pointer2016121620161026
3496884refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2016121620161026
3498786refgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
3501498refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
3501550refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
3506090refgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
3515988refgcc -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
3528656refgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
3556648refgcc -march=k8 -Os -fomit-frame-pointer2016121620161026
3558106refgcc -m64 -march=core2 -Os -fomit-frame-pointer2016121620161026
3558974refgcc -m64 -Os -fomit-frame-pointer2016121620161026
3562004refgcc -Os -fomit-frame-pointer2016121620161026
3563332refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
3565156refgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
3567182refgcc -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
3571392refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2016121620161026
3572148refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2016121620161026
3573266refgcc -march=barcelona -Os -fomit-frame-pointer2016121620161026
3576152refgcc -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
3698156refgcc -march=nocona -O -fomit-frame-pointer2016121620161026
3724058refgcc -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
7109596refgcc -funroll-loops2016121620161026
7127062refcc2016121620161026
7135938refgcc2016121620161026

Compiler output

Implementation: crypto_aead/deoxysneq256128v1/opt
Compiler: cc
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: deoxys-256.c: In function 'deoxys_aead_encrypt':
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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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:30:0:
deoxys-256.c: tweakable-cipher.macros:7:22: note: called from here
deoxys-256.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys-256.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: tweakable-cipher.macros:31:14: note: in expansion of macro 'permute'
deoxys-256.c: new_key2 = permute( new_key2, H_PERMUTATION);
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/deoxysneq256128v1/opt
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:47:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_AD_LAST = constant8( (0x6 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:50:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 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:51:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_CHKSUM = constant8( (0x5 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:96:13: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'deoxys_aead_encrypt' that is compiled without support for 'ssse3'
deoxys-256.c: tmp = permute( tmp, 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:104:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'deoxys_aead_encrypt' that is compiled without support for 'ssse3'
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/deoxysneq256128v1/opt
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:47:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_AD_LAST = constant8( (0x6 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:50:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 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:51:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_CHKSUM = constant8( (0x5 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:440:15: warning: comparison of unsigned expression deoxys-256.c: if( c_len deoxys-256.c: ~~~~~ ^ ~
deoxys-256.c: deoxys-256.c:294:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_AD_LAST = constant8( (0x6 deoxys-256.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys-256.c: ...

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/deoxysneq256128v1/opt
Compiler: clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments
deoxys-256.c: deoxys-256.c:47:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_AD_LAST = constant8( (0x6 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:50:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 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:51:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys-256.c: const __m128i MSB_CHKSUM = constant8( (0x5 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:120:4: error: always_inline function '_mm_aesenc_si128' requires target feature 'aes', but would be inlined into function 'deoxys_aead_encrypt' that is compiled without support for 'aes'
deoxys-256.c: AES( State, subkeys, Tweak, tTweak );
deoxys-256.c: ^
deoxys-256.c: ./tweakable-cipher.macros:79: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: ...

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/deoxysneq256128v1/opt
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: deoxys-256.c: In function 'deoxys_aead_encrypt':
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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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:30:0:
deoxys-256.c: tweakable-cipher.macros:7:22: note: called from here
deoxys-256.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys-256.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: tweakable-cipher.macros:31:14: note: in expansion of macro 'permute'
deoxys-256.c: new_key2 = permute( new_key2, H_PERMUTATION);
deoxys-256.c: ...
deoxys-256.c: In file included from deoxys-256.c:29:0:
deoxys-256.c: deoxys-256.c: In function 'deoxys_aead_encrypt':
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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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: deoxys-256.c:96:11: note: called from here
deoxys-256.c: tmp = permute( tmp, H_PERMUTATION );
deoxys-256.c:
deoxys-256.c: In file included from deoxys-256.c:29: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:30:0:
deoxys-256.c: tweakable-cipher.macros:7:22: note: called from here
deoxys-256.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys-256.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys-256.c: tweakable-cipher.macros:31:14: note: in expansion of macro 'permute'
deoxys-256.c: new_key2 = permute( new_key2, H_PERMUTATION);
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/deoxysneq256128v1/opt
Compiler: gcc -m64 -march=core2 -O2 -fomit-frame-pointer
deoxys-256.c: In file included from deoxys-256.c:28:0:
deoxys-256.c: deoxys-256.c: In function 'deoxys_aead_encrypt':
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:30:0:
deoxys-256.c: tweakable-cipher.macros:94:3: note: called from here
deoxys-256.c: s = enc( s , xor( subkeys[16] , t ) );
deoxys-256.c:
deoxys-256.c: deoxys-256.c:120:4: note: in expansion of macro 'AES'
deoxys-256.c: 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/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:30:0:
deoxys-256.c: tweakable-cipher.macros:93: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:120:4: note: in expansion of macro 'AES'
deoxys-256.c: 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/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