Implementation notes: amd64, skylake, crypto_aead/aes128n8t8clocv2

Computer: skylake
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20161026
Operation: crypto_aead
Primitive: aes128n8t8clocv2
TimeImplementationCompilerBenchmark dateSUPERCOP version
17414aesniclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
17422aesniclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
17446aesnigcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
17490aesnigcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
17500aesnigcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
17578aesniclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
17582aesnigcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
17666aesniclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
17744aesnigcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
17782aesnigcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
17830aesnigcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
17834aesnigcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
17836aesnigcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
18002aesnigcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
18038aesnigcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
18044aesnigcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
18110aesnigcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
18120aesnigcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
18150aesnigcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
18274aesnigcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
18302aesnigcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
18306aesnigcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
18312aesnigcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
18380aesnigcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
110034refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2016121620161026
110410refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2016121620161026
110594refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2016121620161026
110624refgcc -funroll-loops -O2 -fomit-frame-pointer2016121620161026
111162refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
111264refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
111292refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
111466refgcc -march=nocona -O2 -fomit-frame-pointer2016121620161026
111512refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
111596refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
111900refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2016121620161026
111938refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2016121620161026
111938refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2016121620161026
111986refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2016121620161026
111988refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
112042refgcc -funroll-loops -Os -fomit-frame-pointer2016121620161026
112324refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2016121620161026
112330refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
112368refgcc -m64 -march=nocona -Os -fomit-frame-pointer2016121620161026
112376refgcc -march=nocona -Os -fomit-frame-pointer2016121620161026
112588refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2016121620161026
112720refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2016121620161026
112828refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
112936refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2016121620161026
113100refgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer2016121620161026
113142refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2016121620161026
113186refgcc -funroll-loops -O3 -fomit-frame-pointer2016121620161026
113268refgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer2016121620161026
113420refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2016121620161026
113542refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
113560refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2016121620161026
113568refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2016121620161026
113728refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2016121620161026
113754refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
113798refgcc -m64 -march=core2 -Os -fomit-frame-pointer2016121620161026
113818refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
113818refgcc -march=k8 -Os -fomit-frame-pointer2016121620161026
113820refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2016121620161026
113886refgcc -march=k8 -O2 -fomit-frame-pointer2016121620161026
113900refgcc -Os -fomit-frame-pointer2016121620161026
113908refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2016121620161026
113914refgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer2016121620161026
113974refgcc -fno-schedule-insns -Os -fomit-frame-pointer2016121620161026
113980refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2016121620161026
113980refgcc -march=barcelona -Os -fomit-frame-pointer2016121620161026
114098refgcc -m64 -march=k8 -Os -fomit-frame-pointer2016121620161026
114204refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2016121620161026
114224refgcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer2016121620161026
114274refgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer2016121620161026
114360refgcc -O2 -fomit-frame-pointer2016121620161026
114402refgcc -m64 -O2 -fomit-frame-pointer2016121620161026
114402refgcc -m64 -Os -fomit-frame-pointer2016121620161026
114418refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016121620161026
114482refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016121620161026
114562refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2016121620161026
114742refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2016121620161026
114810refgcc -march=barcelona -O2 -fomit-frame-pointer2016121620161026
115000refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
115172refgcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer2016121620161026
115324refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
115382refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2016121620161026
115458refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016121620161026
115460refgcc -funroll-loops -O -fomit-frame-pointer2016121620161026
115464refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2016121620161026
115640refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016121620161026
115686refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
116028refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2016121620161026
116156refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2016121620161026
116326refclang -O3 -fomit-frame-pointer -Qunused-arguments2016121620161026
116388refgcc -march=nocona -O3 -fomit-frame-pointer2016121620161026
116722refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2016121620161026
116738refclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
116946refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2016121620161026
117018refgcc -funroll-loops -m64 -O -fomit-frame-pointer2016121620161026
117150refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2016121620161026
117340refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
117830refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
117870refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2016121620161026
117968refclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
118010refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2016121620161026
118080refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer2016121620161026
118192refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2016121620161026
118202refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2016121620161026
118250refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2016121620161026
118366refgcc -m64 -march=corei7-avx -O -fomit-frame-pointer2016121620161026
118404refgcc -m64 -march=core-avx2 -O -fomit-frame-pointer2016121620161026
118410refgcc -m64 -march=core2 -O -fomit-frame-pointer2016121620161026
118446refgcc -m64 -march=k8 -O -fomit-frame-pointer2016121620161026
118496refgcc -march=barcelona -O3 -fomit-frame-pointer2016121620161026
118502refgcc -m64 -march=core-avx-i -O -fomit-frame-pointer2016121620161026
118568refgcc -O -fomit-frame-pointer2016121620161026
118604refclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
118610refclang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
118646refgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer2016121620161026
118756refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2016121620161026
118792refgcc -m64 -march=barcelona -O -fomit-frame-pointer2016121620161026
118848refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2016121620161026
119006refgcc -march=k8 -O3 -fomit-frame-pointer2016121620161026
119174refgcc -O3 -fomit-frame-pointer2016121620161026
119350refgcc -march=k8 -O -fomit-frame-pointer2016121620161026
119362refgcc -march=barcelona -O -fomit-frame-pointer2016121620161026
119410refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments2016121620161026
119484refgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer2016121620161026
119518refgcc -m64 -O -fomit-frame-pointer2016121620161026
119758refgcc -m64 -march=corei7 -O -fomit-frame-pointer2016121620161026
119940refgcc -m64 -O3 -fomit-frame-pointer2016121620161026
120054refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016121620161026
120178refgcc -march=nocona -O -fomit-frame-pointer2016121620161026
120182refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016121620161026
120186refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016121620161026
120346refgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer2016121620161026
120458refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2016121620161026
120822refgcc -m64 -march=nocona -O -fomit-frame-pointer2016121620161026
120984refgcc -fno-schedule-insns -O -fomit-frame-pointer2016121620161026
121146refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016121620161026
121282refclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments2016121620161026
121606refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016121620161026
122314refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016121620161026
227008refcc2016121620161026
227074refgcc2016121620161026
234752refgcc -funroll-loops2016121620161026

Compiler output

Implementation: crypto_aead/aes128n8t8clocv2/aesni
Compiler: cc
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: encrypt.c: In function 'crypto_aead_aes128n8t8clocv2_aesni_encrypt':
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:69:1: error: inlining failed in call to always_inline '_mm_aesenclast_si128': target specific option mismatch
encrypt.c: _mm_aesenclast_si128 (__m128i __X, __m128i __Y)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:67:8: note: called from here
encrypt.c: out = _mm_aesenclast_si128(out, roundkeys[10]);\
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: encrypt.c:143:5: note: in expansion of macro 'AES128_encrypt'
encrypt.c: AES128_encrypt(estate, estate);
encrypt.c: ^~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.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
encrypt.c: _mm_aesenc_si128 (__m128i __X, __m128i __Y)
encrypt.c: ^~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:66:8: note: called from here
encrypt.c: out = _mm_aesenc_si128(out, roundkeys[9]); \
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: encrypt.c:143:5: note: in expansion of macro 'AES128_encrypt'
encrypt.c: AES128_encrypt(estate, estate);
encrypt.c: ^~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.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
encrypt.c: ...

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
cc aesni
gcc aesni
gcc -funroll-loops aesni

Compiler output

Implementation: crypto_aead/aes128n8t8clocv2/aesni
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
encrypt.c: In file included from encrypt.c:38:
encrypt.c: ./aes.h:30:2: error: '__builtin_ia32_aeskeygenassist128' needs target feature aes
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 1); roundkeys[1] = x0;
encrypt.c: ^
encrypt.c: ./aes.h:13:7: note: expanded from macro 'EXPAND_ASSIST'
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: /usr/bin/../lib/clang/3.9.0/include/__wmmintrin_aes.h:147:12: note: expanded from macro '_mm_aeskeygenassist_si128'
encrypt.c: (__m128i)__builtin_ia32_aeskeygenassist128((__v2di)(__m128i)(C), (int)(R))
encrypt.c: ^
encrypt.c: In file included from encrypt.c:38:
encrypt.c: ./aes.h:31:2: error: '__builtin_ia32_aeskeygenassist128' needs target feature aes
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 2); roundkeys[2] = x0;
encrypt.c: ^
encrypt.c: ./aes.h:13:7: note: expanded from macro 'EXPAND_ASSIST'
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: /usr/bin/../lib/clang/3.9.0/include/__wmmintrin_aes.h:147:12: note: expanded from macro '_mm_aeskeygenassist_si128'
encrypt.c: (__m128i)__builtin_ia32_aeskeygenassist128((__v2di)(__m128i)(C), (int)(R))
encrypt.c: ^
encrypt.c: In file included from encrypt.c:38:
encrypt.c: ./aes.h:32:2: error: '__builtin_ia32_aeskeygenassist128' needs target feature aes
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 4); roundkeys[3] = x0;
encrypt.c: ^
encrypt.c: ./aes.h:13:7: note: expanded from macro 'EXPAND_ASSIST'
encrypt.c: ...

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

Compiler output

Implementation: crypto_aead/aes128n8t8clocv2/aesni
Compiler: gcc -O2 -fomit-frame-pointer
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: aes.h: In function 'AES128_KeyExpansion':
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:39:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 54); roundkeys[10] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:38:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 27); roundkeys[9] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: ...

Number of similar (compiler,implementation) pairs: 84, namely:
CompilerImplementations
gcc -O2 -fomit-frame-pointer aesni
gcc -O3 -fomit-frame-pointer aesni
gcc -O -fomit-frame-pointer aesni
gcc -Os -fomit-frame-pointer aesni
gcc -fno-schedule-insns -O2 -fomit-frame-pointer aesni
gcc -fno-schedule-insns -O3 -fomit-frame-pointer aesni
gcc -fno-schedule-insns -O -fomit-frame-pointer aesni
gcc -fno-schedule-insns -Os -fomit-frame-pointer aesni
gcc -funroll-loops -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -O -fomit-frame-pointer aesni
gcc -funroll-loops -Os -fomit-frame-pointer aesni
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer aesni
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer aesni
gcc -m64 -O2 -fomit-frame-pointer aesni
gcc -m64 -O3 -fomit-frame-pointer aesni
gcc -m64 -O -fomit-frame-pointer aesni
gcc -m64 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer aesni
gcc -m64 -march=corei7 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=corei7 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=corei7 -O -fomit-frame-pointer aesni
gcc -m64 -march=corei7 -Os -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O -fomit-frame-pointer aesni
gcc -m64 -march=k8 -Os -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O2 -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O3 -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O -fomit-frame-pointer aesni
gcc -m64 -march=nocona -Os -fomit-frame-pointer aesni
gcc -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -march=barcelona -O -fomit-frame-pointer aesni
gcc -march=barcelona -Os -fomit-frame-pointer aesni
gcc -march=k8 -O2 -fomit-frame-pointer aesni
gcc -march=k8 -O3 -fomit-frame-pointer aesni
gcc -march=k8 -O -fomit-frame-pointer aesni
gcc -march=k8 -Os -fomit-frame-pointer aesni
gcc -march=nocona -O2 -fomit-frame-pointer aesni
gcc -march=nocona -O3 -fomit-frame-pointer aesni
gcc -march=nocona -O -fomit-frame-pointer aesni
gcc -march=nocona -Os -fomit-frame-pointer aesni

Compiler output

Implementation: crypto_aead/aes128n8t8clocv2/aesni
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: aes.h: In function 'AES128_KeyExpansion':
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:39:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 54); roundkeys[10] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:38:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 27); roundkeys[9] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: ...
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: aes.h: In function 'AES128_KeyExpansion':
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:39:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 54); roundkeys[10] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: _mm_aeskeygenassist_si128 (__m128i __X, const int __C)
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:38:0:
encrypt.c: aes.h:13:5: note: called from here
encrypt.c: v2 = _mm_aeskeygenassist_si128(v4, aes_const); \
encrypt.c: ^
encrypt.c: aes.h:38:2: note: in expansion of macro 'EXPAND_ASSIST'
encrypt.c: EXPAND_ASSIST(x0, x1, x2, x0, 27); roundkeys[9] = x0;
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: In file included from encrypt.c:7:0:
encrypt.c: /usr/lib/gcc/x86_64-pc-linux-gnu/6.2.1/include/wmmintrin.h:87:1: error: inlining failed in call to always_inline '_mm_aeskeygenassist_si128': target specific option mismatch
encrypt.c: ...

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