Implementation notes: x86, samba, crypto_stream/cryptmtv3

Computer: samba
Architecture: x86
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20190803
Operation: crypto_stream
Primitive: cryptmtv3
TimeImplementationCompilerBenchmark dateSUPERCOP version
6402e/v3gcc -m32 -march=barcelona -O3 -fomit-frame-pointer2019070620190110
6408e/v3gcc -funroll-loops -m32 -march=barcelona -O3 -fomit-frame-pointer2019070620190110
6415e/v3gcc -funroll-loops -m32 -march=barcelona -O2 -fomit-frame-pointer2019070620190110
6451e/v3gcc -funroll-loops -m32 -march=nocona -O2 -fomit-frame-pointer2019070620190110
6452e/v3gcc -funroll-loops -m32 -march=k8 -O3 -fomit-frame-pointer2019070620190110
6452e/v3gcc -funroll-loops -m32 -march=prescott -O2 -fomit-frame-pointer2019070620190110
6469e/v3gcc -m32 -march=k8 -O3 -fomit-frame-pointer2019070620190110
6482e/v3gcc -funroll-loops -m32 -march=nocona -O3 -fomit-frame-pointer2019070620190110
6484e/v3gcc -funroll-loops -m32 -march=prescott -O3 -fomit-frame-pointer2019070620190110
6492e/v3gcc -funroll-loops -m32 -march=pentium4 -O2 -fomit-frame-pointer2019070620190110
6494e/v3gcc -funroll-loops -m32 -march=k8 -O2 -fomit-frame-pointer2019070620190110
6516e/v3gcc -funroll-loops -m32 -march=pentium-m -O2 -fomit-frame-pointer2019070620190110
6552e/v3gcc -funroll-loops -m32 -march=pentium-m -O3 -fomit-frame-pointer2019070620190110
6554e/v3gcc -funroll-loops -m32 -march=pentium4 -O3 -fomit-frame-pointer2019070620190110
6563e/v3gcc -funroll-loops -m32 -march=prescott -O -fomit-frame-pointer2019070620190110
6577e/v3gcc -m32 -march=core-avx-i -O2 -fomit-frame-pointer2019070620190110
6579e/v3gcc -m32 -march=corei7 -O2 -fomit-frame-pointer2019070620190110
6585e/v3gcc -m32 -march=corei7 -O3 -fomit-frame-pointer2019070620190110
6591e/v3gcc -funroll-loops -m32 -march=nocona -O -fomit-frame-pointer2019070620190110
6597e/v3gcc -m32 -march=corei7-avx -O2 -fomit-frame-pointer2019070620190110
6605e/v3gcc -m32 -march=corei7-avx -O3 -fomit-frame-pointer2019070620190110
6613e/v3gcc -m32 -march=core-avx-i -O3 -fomit-frame-pointer2019070620190110
6625e/v3gcc -funroll-loops -m32 -march=pentium4 -O -fomit-frame-pointer2019070620190110
6627e/v3gcc -funroll-loops -m32 -march=barcelona -O -fomit-frame-pointer2019070620190110
6647e/v3gcc -funroll-loops -m32 -march=k8 -O -fomit-frame-pointer2019070620190110
6661e/v3gcc -funroll-loops -m32 -march=pentium-m -O -fomit-frame-pointer2019070620190110
6670e/v3gcc -m32 -march=native -mtune=native -O3 -fomit-frame-pointer2019070620190110
6678e/v3gcc -m32 -march=native -mtune=native -O2 -fomit-frame-pointer2019070620190110
6685e/v3gcc -m32 -march=core-avx2 -O2 -fomit-frame-pointer2019070620190110
6693e/v3gcc -m32 -march=core-avx2 -O3 -fomit-frame-pointer2019070620190110
6780e/v3gcc -m32 -march=corei7 -O -fomit-frame-pointer2019070620190110
6821e/v3gcc -m32 -march=core-avx2 -O -fomit-frame-pointer2019070620190110
6825e/v3gcc -m32 -march=native -mtune=native -O -fomit-frame-pointer2019070620190110
6826e/v3gcc -m32 -march=corei7 -Os -fomit-frame-pointer2019070620190110
6829e/v3gcc -m32 -march=corei7-avx -Os -fomit-frame-pointer2019070620190110
6833e/v3gcc -m32 -march=corei7-avx -O -fomit-frame-pointer2019070620190110
6834e/v3gcc -m32 -march=core-avx-i -Os -fomit-frame-pointer2019070620190110
6835e/v3gcc -m32 -march=core-avx-i -O -fomit-frame-pointer2019070620190110
6839e/v3gcc -m32 -march=nocona -O2 -fomit-frame-pointer2019070620190110
6851e/v3gcc -m32 -march=prescott -O2 -fomit-frame-pointer2019070620190110
6867e/v3gcc -m32 -march=core2 -O2 -fomit-frame-pointer2019070620190110
6867e/v3gcc -m32 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2019070620190110
6869e/v3gcc -m32 -march=core-avx2 -Os -fomit-frame-pointer2019070620190110
6869e/v3gcc -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2019070620190110
6869e/v3gcc -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer2019070620190110
6875e/v3gcc -m32 -march=core2 -msse4 -O3 -fomit-frame-pointer2019070620190110
6875e/v3gcc -m32 -march=native -mtune=native -Os -fomit-frame-pointer2019070620190110
6881e/v3gcc -m32 -march=core2 -O3 -fomit-frame-pointer2019070620190110
6883e/v3gcc -m32 -march=pentium4 -O3 -fomit-frame-pointer2019070620190110
6889e/v3gcc -m32 -march=prescott -O3 -fomit-frame-pointer2019070620190110
6907e/v3gcc -m32 -march=barcelona -O2 -fomit-frame-pointer2019070620190110
6911e/v3gcc -m32 -march=k8 -O2 -fomit-frame-pointer2019070620190110
6916e/v3gcc -m32 -march=pentium4 -O2 -fomit-frame-pointer2019070620190110
6921e/v3gcc -m32 -march=pentium-m -O2 -fomit-frame-pointer2019070620190110
6922e/v3gcc -m32 -march=nocona -O3 -fomit-frame-pointer2019070620190110
6994e/v3gcc -m32 -march=core2 -O -fomit-frame-pointer2019070620190110
6998e/v3gcc -m32 -march=pentium-m -O3 -fomit-frame-pointer2019070620190110
7000e/v3gcc -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer2019070620190110
7006e/v3gcc -m32 -march=core2 -msse4 -O -fomit-frame-pointer2019070620190110
7006e/v3gcc -m32 -march=prescott -O -fomit-frame-pointer2019070620190110
7008e/v3gcc -m32 -march=nocona -O -fomit-frame-pointer2019070620190110
7085e/v3gcc -m32 -march=pentium4 -O -fomit-frame-pointer2019070620190110
7093e/v3gcc -m32 -march=barcelona -O -fomit-frame-pointer2019070620190110
7097e/v3gcc -m32 -march=k8 -O -fomit-frame-pointer2019070620190110
7121e/v3gcc -funroll-loops -m32 -march=barcelona -Os -fomit-frame-pointer2019070620190110
7156e/v3gcc -m32 -march=core2 -msse4 -Os -fomit-frame-pointer2019070620190110
7157e/v3gcc -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer2019070620190110
7160e/v3gcc -m32 -march=pentium-m -O -fomit-frame-pointer2019070620190110
7175e/v3gcc -funroll-loops -m32 -march=nocona -Os -fomit-frame-pointer2019070620190110
7182e/v3gcc -funroll-loops -m32 -march=prescott -Os -fomit-frame-pointer2019070620190110
7182e/v3gcc -m32 -march=nocona -Os -fomit-frame-pointer2019070620190110
7188e/v3gcc -m32 -march=barcelona -Os -fomit-frame-pointer2019070620190110
7197e/v3gcc -m32 -march=prescott -Os -fomit-frame-pointer2019070620190110
7202e/v3gcc -funroll-loops -m32 -march=k8 -Os -fomit-frame-pointer2019070620190110
7205e/v3gcc -funroll-loops -m32 -march=pentium4 -Os -fomit-frame-pointer2019070620190110
7209e/v3gcc -m32 -march=pentium4 -Os -fomit-frame-pointer2019070620190110
7237e/v3gcc -m32 -march=core2 -Os -fomit-frame-pointer2019070620190110
7246e/v3gcc -m32 -march=k8 -Os -fomit-frame-pointer2019070620190110
7339e/v3gcc -funroll-loops -m32 -march=pentium-m -Os -fomit-frame-pointer2019070620190110
7359e/v3gcc -m32 -march=pentium-m -Os -fomit-frame-pointer2019070620190110
8443e/v3gcc -funroll-loops -m32 -O2 -fomit-frame-pointer2019070620190110
8458e/v3gcc -funroll-loops -m32 -march=pentiumpro -O2 -fomit-frame-pointer2019070620190110
8474e/v3gcc -funroll-loops -m32 -march=pentium2 -O2 -fomit-frame-pointer2019070620190110
8502e/v3gcc -funroll-loops -m32 -march=athlon -O2 -fomit-frame-pointer2019070620190110
8508e/v3gcc -m32 -march=k6 -O3 -fomit-frame-pointer2019070620190110
8510e/v3gcc -m32 -march=k6-2 -O3 -fomit-frame-pointer2019070620190110
8518e/v3gcc -m32 -march=k6-3 -O3 -fomit-frame-pointer2019070620190110
8584e/v3gcc -funroll-loops -m32 -march=pentiumpro -O3 -fomit-frame-pointer2019070620190110
8593e/v3gcc -m32 -O3 -fomit-frame-pointer2019070620190110
8603e/v3gcc -funroll-loops -m32 -O3 -fomit-frame-pointer2019070620190110
8603e/v3gcc -m32 -march=pentium2 -O3 -fomit-frame-pointer2019070620190110
8606e/v3gcc -funroll-loops -m32 -march=k6 -O3 -fomit-frame-pointer2019070620190110
8629e/v3gcc -funroll-loops -m32 -march=k6-3 -O2 -fomit-frame-pointer2019070620190110
8631e/v3gcc -funroll-loops -m32 -march=pentium2 -O3 -fomit-frame-pointer2019070620190110
8635e/v3gcc -funroll-loops -m32 -march=k6 -O2 -fomit-frame-pointer2019070620190110
8641e/v3gcc -funroll-loops -m32 -march=k6-2 -O2 -fomit-frame-pointer2019070620190110
8643e/v3gcc -m32 -march=pentiumpro -O3 -fomit-frame-pointer2019070620190110
8665e/v3gcc -funroll-loops -m32 -march=k6-2 -O3 -fomit-frame-pointer2019070620190110
8665e/v3gcc -funroll-loops -m32 -march=k6-3 -O3 -fomit-frame-pointer2019070620190110
8669e/v3gcc -m32 -march=athlon -O3 -fomit-frame-pointer2019070620190110
8680e/v3gcc -funroll-loops -m32 -march=athlon -O3 -fomit-frame-pointer2019070620190110
8689e/v3gcc -funroll-loops -m32 -O -fomit-frame-pointer2019070620190110
8718e/v3gcc -funroll-loops -m32 -march=athlon -O -fomit-frame-pointer2019070620190110
8766e/v3gcc -funroll-loops -m32 -march=i486 -O -fomit-frame-pointer2019070620190110
8773e/v3gcc -funroll-loops -m32 -march=i386 -O -fomit-frame-pointer2019070620190110
8804e/v3gcc -funroll-loops -m32 -march=pentium-mmx -O -fomit-frame-pointer2019070620190110
8805e/v3gcc -funroll-loops -m32 -march=pentium2 -O -fomit-frame-pointer2019070620190110
8810e/v3gcc -funroll-loops -m32 -march=k6 -O -fomit-frame-pointer2019070620190110
8813e/v3gcc -funroll-loops -m32 -march=k6-3 -O -fomit-frame-pointer2019070620190110
8844e/v3gcc -funroll-loops -m32 -march=k6-2 -O -fomit-frame-pointer2019070620190110
8857e/v3gcc -funroll-loops -m32 -march=pentium -O -fomit-frame-pointer2019070620190110
8917e/v3gcc -funroll-loops -m32 -march=pentiumpro -O -fomit-frame-pointer2019070620190110
8957e/v3gcc -funroll-loops -m32 -march=pentium-mmx -O2 -fomit-frame-pointer2019070620190110
8980e/v3gcc -funroll-loops -m32 -march=pentium -O2 -fomit-frame-pointer2019070620190110
9028e/v3gcc -m32 -march=pentium -O3 -fomit-frame-pointer2019070620190110
9064e/v3gcc -funroll-loops -m32 -march=i386 -O2 -fomit-frame-pointer2019070620190110
9065e/v3gcc -m32 -march=pentium-mmx -O3 -fomit-frame-pointer2019070620190110
9082e/v3gcc -funroll-loops -m32 -march=pentium-mmx -O3 -fomit-frame-pointer2019070620190110
9091e/v3gcc -funroll-loops -m32 -march=pentium -O3 -fomit-frame-pointer2019070620190110
9101e/v3gcc -m32 -march=i486 -O3 -fomit-frame-pointer2019070620190110
9109e/v3gcc -m32 -march=i386 -O3 -fomit-frame-pointer2019070620190110
9115e/v3gcc -funroll-loops -m32 -march=i486 -O2 -fomit-frame-pointer2019070620190110
9135e/v3gcc -funroll-loops -m32 -march=i486 -O3 -fomit-frame-pointer2019070620190110
9168e/v3gcc -funroll-loops -m32 -march=i386 -O3 -fomit-frame-pointer2019070620190110
10028e/v3gcc -m32 -march=athlon -O2 -fomit-frame-pointer2019070620190110
10076e/v3gcc -m32 -O2 -fomit-frame-pointer2019070620190110
10117e/v3gcc -m32 -march=pentium2 -O2 -fomit-frame-pointer2019070620190110
10177e/v3gcc -m32 -march=pentiumpro -O2 -fomit-frame-pointer2019070620190110
10343e/v3gcc -m32 -march=k6-3 -O2 -fomit-frame-pointer2019070620190110
10346e/v3gcc -m32 -march=k6-2 -O2 -fomit-frame-pointer2019070620190110
10346e/v3gcc -m32 -march=k6 -O2 -fomit-frame-pointer2019070620190110
10516e/v3gcc -m32 -O -fomit-frame-pointer2019070620190110
10547e/v3gcc -m32 -march=pentium-mmx -O2 -fomit-frame-pointer2019070620190110
10553e/v3gcc -m32 -march=pentium -O2 -fomit-frame-pointer2019070620190110
10592e/v3gcc -m32 -march=pentium -O -fomit-frame-pointer2019070620190110
10595e/v3gcc -m32 -march=pentium-mmx -O -fomit-frame-pointer2019070620190110
10629e/v3gcc -m32 -march=k6-3 -O -fomit-frame-pointer2019070620190110
10631e/v3gcc -m32 -march=k6-2 -O -fomit-frame-pointer2019070620190110
10664e/v3gcc -m32 -march=i486 -O -fomit-frame-pointer2019070620190110
10691e/v3gcc -m32 -march=athlon -O -fomit-frame-pointer2019070620190110
10699e/v3gcc -m32 -march=pentiumpro -O -fomit-frame-pointer2019070620190110
10726e/v3gcc -m32 -march=k6 -O -fomit-frame-pointer2019070620190110
10732e/v3gcc -m32 -march=pentium2 -O -fomit-frame-pointer2019070620190110
10748e/v3gcc -m32 -march=i486 -O2 -fomit-frame-pointer2019070620190110
10754e/v3gcc -m32 -march=i386 -O -fomit-frame-pointer2019070620190110
10790e/v3gcc -m32 -march=i386 -O2 -fomit-frame-pointer2019070620190110
11444e/v3gcc -m32 -Os -fomit-frame-pointer2019070620190110
11466e/v3gcc -m32 -march=athlon -Os -fomit-frame-pointer2019070620190110
11500e/v3gcc -funroll-loops -m32 -Os -fomit-frame-pointer2019070620190110
11537e/v3gcc -funroll-loops -m32 -march=athlon -Os -fomit-frame-pointer2019070620190110
11574e/v3gcc -m32 -march=pentium-mmx -Os -fomit-frame-pointer2019070620190110
11582e/v3gcc -m32 -march=pentium -Os -fomit-frame-pointer2019070620190110
11599e/v3gcc -funroll-loops -m32 -march=pentium-mmx -Os -fomit-frame-pointer2019070620190110
11613e/v3gcc -funroll-loops -m32 -march=pentium -Os -fomit-frame-pointer2019070620190110
11706e/v3gcc -m32 -march=k6 -Os -fomit-frame-pointer2019070620190110
11710e/v3gcc -funroll-loops -m32 -march=k6 -Os -fomit-frame-pointer2019070620190110
11727e/v3gcc -m32 -march=k6-3 -Os -fomit-frame-pointer2019070620190110
11732e/v3gcc -funroll-loops -m32 -march=i386 -Os -fomit-frame-pointer2019070620190110
11744e/v3gcc -m32 -march=k6-2 -Os -fomit-frame-pointer2019070620190110
11754e/v3gcc -m32 -march=i486 -Os -fomit-frame-pointer2019070620190110
11757e/v3gcc -funroll-loops -m32 -march=k6-3 -Os -fomit-frame-pointer2019070620190110
11787e/v3gcc -funroll-loops -m32 -march=i486 -Os -fomit-frame-pointer2019070620190110
11795e/v3gcc -funroll-loops -m32 -march=k6-2 -Os -fomit-frame-pointer2019070620190110
11806e/v3gcc -m32 -march=i386 -Os -fomit-frame-pointer2019070620190110
12187e/v3gcc -funroll-loops -m32 -march=pentium2 -Os -fomit-frame-pointer2019070620190110
12205e/v3gcc -m32 -march=pentium2 -Os -fomit-frame-pointer2019070620190110
12219e/v3gcc -funroll-loops -m32 -march=pentiumpro -Os -fomit-frame-pointer2019070620190110
12230e/v3gcc -m32 -march=pentiumpro -Os -fomit-frame-pointer2019070620190110

Compiler output

Implementation: crypto_stream/cryptmtv3/e/v3
Compiler: gcc -funroll-loops -m32 -march=pentium3 -O2 -fomit-frame-pointer
cryptmt-v3.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/xmmintrin.h:1252:0,
cryptmt-v3.c: from /home/djb/supercop-20190110/supercop-data/samba/x86/include/ecrypt-config.h:302,
cryptmt-v3.c: from e/cryptmt-v3.c:9,
cryptmt-v3.c: from cryptmt-v3.c:2:
cryptmt-v3.c: e/sse2.c: In function '_mm_recursion':
cryptmt-v3.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/emmintrin.h:1291:1: error: inlining failed in call to always_inline '_mm_xor_si128': target specific option mismatch
cryptmt-v3.c: _mm_xor_si128 (__m128i __A, __m128i __B)
cryptmt-v3.c: ^~~~~~~~~~~~~
cryptmt-v3.c: In file included from e/cryptmt-v3.c:66:0,
cryptmt-v3.c: from cryptmt-v3.c:2:
cryptmt-v3.c: e/sse2.c:39:7: note: called from here
cryptmt-v3.c: c = _mm_xor_si128(c, a);
cryptmt-v3.c: ~~^~~~~~~~~~~~~~~~~~~~~
cryptmt-v3.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/xmmintrin.h:1252:0,
cryptmt-v3.c: from /home/djb/supercop-20190110/supercop-data/samba/x86/include/ecrypt-config.h:302,
cryptmt-v3.c: from e/cryptmt-v3.c:9,
cryptmt-v3.c: from cryptmt-v3.c:2:
cryptmt-v3.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/emmintrin.h:1291:1: error: inlining failed in call to always_inline '_mm_xor_si128': target specific option mismatch
cryptmt-v3.c: _mm_xor_si128 (__m128i __A, __m128i __B)
cryptmt-v3.c: ^~~~~~~~~~~~~
cryptmt-v3.c: In file included from e/cryptmt-v3.c:66:0,
cryptmt-v3.c: from cryptmt-v3.c:2:
cryptmt-v3.c: e/sse2.c:38:7: note: called from here
cryptmt-v3.c: c = _mm_xor_si128(c, b);
cryptmt-v3.c: ~~^~~~~~~~~~~~~~~~~~~~~
cryptmt-v3.c: ...

Number of similar (compiler,implementation) pairs: 8, namely:
CompilerImplementations
gcc -funroll-loops -m32 -march=pentium3 -O2 -fomit-frame-pointer e/v3
gcc -funroll-loops -m32 -march=pentium3 -O3 -fomit-frame-pointer e/v3
gcc -funroll-loops -m32 -march=pentium3 -O -fomit-frame-pointer e/v3
gcc -funroll-loops -m32 -march=pentium3 -Os -fomit-frame-pointer e/v3
gcc -m32 -march=pentium3 -O2 -fomit-frame-pointer e/v3
gcc -m32 -march=pentium3 -O3 -fomit-frame-pointer e/v3
gcc -m32 -march=pentium3 -O -fomit-frame-pointer e/v3
gcc -m32 -march=pentium3 -Os -fomit-frame-pointer e/v3