Implementation notes: amd64, skylake, crypto_aead/deoxysneq128128v1

Computer: skylake
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20161026
Operation: crypto_aead
Primitive: deoxysneq128128v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
7106optgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
7118optgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
7134optgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
7138optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
7192optgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
7220optgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
7236optgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
7242optgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
7248optgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
7248optgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
7248optgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
7248optgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
7250optgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
7260optgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
7278optgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
7316optgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
7330optgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
7378optgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
7382optgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
7432optgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
746412refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
748934refclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
749674refclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments2016121620161026
751364refclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
752052refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
752286refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments2016121620161026
755290refclang -O3 -fomit-frame-pointer -Qunused-arguments2016121620161026
761594refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
762680refclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
764750refclang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
945962refgcc -m64 -O3 -fomit-frame-pointer2016121620161026
948380refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
952200refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2016121620161026
953954refgcc -O3 -fomit-frame-pointer2016121620161026
978894refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
981676refgcc -funroll-loops -O3 -fomit-frame-pointer2016121620161026
983446refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2016121620161026
984300refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2016121620161026
988082refgcc -march=nocona -O3 -fomit-frame-pointer2016121620161026
988468refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
994342refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
994742refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
999634refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
1003052refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2016121620161026
1007994refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1088976refgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
1099914refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
1100350refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2016121620161026
1103002refgcc -march=k8 -O3 -fomit-frame-pointer2016121620161026
1103088refgcc -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1103280refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
1111174refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
1111800refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
1112998refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
1114374refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
1122240refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2016121620161026
1122488refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1122584refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2016121620161026
1122626refgcc -funroll-loops -O2 -fomit-frame-pointer2016121620161026
1132056refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
1132738refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1146650refgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
1146738refgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
1149684refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
1149902refgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
1150814refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
1151604refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2016121620161026
1153742refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
1157238refgcc -march=nocona -O2 -fomit-frame-pointer2016121620161026
1157440refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2016121620161026
1158660refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer2016121620161026
1160882refgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
1164868refgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
1168642refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2016121620161026
1208054refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
1209086refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
1209398refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2016121620161026
1209862refgcc -O2 -fomit-frame-pointer2016121620161026
1210698refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2016121620161026
1212296refgcc -m64 -O2 -fomit-frame-pointer2016121620161026
1212440refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2016121620161026
1212748refgcc -march=k8 -O2 -fomit-frame-pointer2016121620161026
1231846refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1232410refgcc -march=barcelona -O2 -fomit-frame-pointer2016121620161026
1950288refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2016121620161026
1950712refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
1951100refgcc -funroll-loops -Os -fomit-frame-pointer2016121620161026
1953138refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
1954194refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2016121620161026
1960020refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2016121620161026
1963772refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
1964358refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
1967268refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2016121620161026
1976122refgcc -m64 -march=core2 -O -fomit-frame-pointer2016121620161026
1983542refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2016121620161026
1985976refgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
1989524refgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
1990646refgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
1994900refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2016121620161026
1997414refgcc -m64 -march=corei7 -O -fomit-frame-pointer2016121620161026
2002318refgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
2007294refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
2011084refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
2014226refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2016121620161026
2027374refgcc -march=k8 -O -fomit-frame-pointer2016121620161026
2030606refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2016121620161026
2041788refgcc -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
2080554refgcc -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
2082174refgcc -funroll-loops -O -fomit-frame-pointer2016121620161026
2084052refgcc -march=k8 -Os -fomit-frame-pointer2016121620161026
2087426refgcc -m64 -Os -fomit-frame-pointer2016121620161026
2088594refgcc -funroll-loops -m64 -O -fomit-frame-pointer2016121620161026
2091360refgcc -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
2094738refgcc -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
2096348refgcc -march=nocona -Os -fomit-frame-pointer2016121620161026
2097016refgcc -march=barcelona -Os -fomit-frame-pointer2016121620161026
2104434refgcc -Os -fomit-frame-pointer2016121620161026
2106662refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2016121620161026
2108136refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
2110210refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2016121620161026
2110656refgcc -m64 -march=core2 -Os -fomit-frame-pointer2016121620161026
2112736refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2016121620161026
2113750refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
2118394refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
2121578refgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
2125452refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
2131504refgcc -march=barcelona -O -fomit-frame-pointer2016121620161026
2133786refgcc -O -fomit-frame-pointer2016121620161026
2135986refgcc -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
2139264refgcc -m64 -O -fomit-frame-pointer2016121620161026
2142302refgcc -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
2228872refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
2237022refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
2246968refgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
2306180refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2016121620161026
2312364refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
2408836refgcc -march=nocona -O -fomit-frame-pointer2016121620161026
2410624refgcc -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
4275142refcc2016121620161026
4285658refgcc -funroll-loops2016121620161026
4327702refgcc2016121620161026

Compiler output

Implementation: crypto_aead/deoxysneq128128v1/opt
Compiler: cc
deoxys.c: In file included from deoxys.c:30:0:
deoxys.c: deoxys.c: In function 'deoxys_aead_encrypt':
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: In file included from deoxys.c:31:0:
deoxys.c: tweakable-cipher.macros:7:22: note: called from here
deoxys.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys.c: tweakable-cipher.macros:28:13: note: in expansion of macro 'permute'
deoxys.c: new_key = permute( new_key, H_PERMUTATION);
deoxys.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/deoxysneq128128v1/opt
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
deoxys.c: deoxys.c:46:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_AD_LAST = constant8( (0x6 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:49:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:50:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_CHKSUM = constant8( (0x5 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.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.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c: ^
deoxys.c: ./tweakable-cipher.macros:7:22: note: expanded from macro 'permute'
deoxys.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys.c: ^
deoxys.c: deoxys.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.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/deoxysneq128128v1/opt
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
deoxys.c: deoxys.c:46:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_AD_LAST = constant8( (0x6 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:49:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:50:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_CHKSUM = constant8( (0x5 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:446:15: warning: comparison of unsigned expression deoxys.c: if( c_len deoxys.c: ~~~~~ ^ ~
deoxys.c: deoxys.c:296:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_AD_LAST = constant8( (0x6 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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/deoxysneq128128v1/opt
Compiler: clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments
deoxys.c: deoxys.c:46:50: warning: implicit conversion from 'int' to 'char' changes value from 192 to -64 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_AD_LAST = constant8( (0x6 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:49:56: warning: implicit conversion from 'int' to 'char' changes value from 128 to -128 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_M_LAST_NONZERO = constant8( (0x4 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.c:50:49: warning: implicit conversion from 'int' to 'char' changes value from 160 to -96 [-Wconstant-conversion]
deoxys.c: const __m128i MSB_CHKSUM = constant8( (0x5 deoxys.c: ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
deoxys.c: ./tweakable-cipher.macros:12:171: note: expanded from macro 'constant8'
deoxys.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.c: ~~~~~~~~~~~~ ^~~
deoxys.c: deoxys.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.c: AES( State, subkeys, Tweak, tTweak );
deoxys.c: ^
deoxys.c: ./tweakable-cipher.macros:69:5: note: expanded from macro 'AES'
deoxys.c: s = enc( s , xor( subkeys[ 1] , t ) );t=permute( t , H_PERMUTATION);\
deoxys.c: ^
deoxys.c: ./tweakable-cipher.macros:1:18: note: expanded from macro 'enc'
deoxys.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/deoxysneq128128v1/opt
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
deoxys.c: In file included from deoxys.c:30:0:
deoxys.c: deoxys.c: In function 'deoxys_aead_encrypt':
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: In file included from deoxys.c:31:0:
deoxys.c: tweakable-cipher.macros:7:22: note: called from here
deoxys.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys.c: tweakable-cipher.macros:28:13: note: in expansion of macro 'permute'
deoxys.c: new_key = permute( new_key, H_PERMUTATION);
deoxys.c: ...
deoxys.c: In file included from deoxys.c:30:0:
deoxys.c: deoxys.c: In function 'deoxys_aead_encrypt':
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: deoxys.c:96:11: note: called from here
deoxys.c: tmp = permute( tmp, H_PERMUTATION );
deoxys.c:
deoxys.c: In file included from deoxys.c:30:0:
deoxys.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.c: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: In file included from deoxys.c:31:0:
deoxys.c: tweakable-cipher.macros:7:22: note: called from here
deoxys.c: #define permute(a,b) _mm_shuffle_epi8(a,b)
deoxys.c: ^~~~~~~~~~~~~~~~~~~~~
deoxys.c: tweakable-cipher.macros:28:13: note: in expansion of macro 'permute'
deoxys.c: new_key = permute( new_key, H_PERMUTATION);
deoxys.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/deoxysneq128128v1/opt
Compiler: gcc -m64 -march=core2 -O2 -fomit-frame-pointer
deoxys.c: In file included from deoxys.c:29:0:
deoxys.c: deoxys.c: In function 'deoxys_aead_encrypt':
deoxys.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.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: In file included from deoxys.c:31:0:
deoxys.c: tweakable-cipher.macros:82:3: note: called from here
deoxys.c: s = enc( s , xor( subkeys[14] , t ) );
deoxys.c:
deoxys.c: deoxys.c:120:4: note: in expansion of macro 'AES'
deoxys.c: AES( State, subkeys, Tweak, tTweak );
deoxys.c: ^~~
deoxys.c: In file included from deoxys.c:29:0:
deoxys.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.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
deoxys.c: ^~~~~~~~~~~~~~~~
deoxys.c: In file included from deoxys.c:31:0:
deoxys.c: tweakable-cipher.macros:81:3: note: called from here
deoxys.c: s = enc( s , xor( subkeys[13] , t ) );t=permute( t , H_PERMUTATION);\
deoxys.c:
deoxys.c: deoxys.c:120:4: note: in expansion of macro 'AES'
deoxys.c: AES( State, subkeys, Tweak, tTweak );
deoxys.c: ^~~
deoxys.c: In file included from deoxys.c:29:0:
deoxys.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.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