Implementation notes: amd64, hydra1, crypto_stream/cryptmtv3

Computer: hydra1
Architecture: amd64
CPU ID: AuthenticAMD-00100fa0-178bfbff
SUPERCOP version: 20161220
Operation: crypto_stream
Primitive: cryptmtv3
TimeImplementationCompilerBenchmark dateSUPERCOP version
8996e/v3gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2016101320161009
9000e/v3gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2016101320161009
9001e/v3gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2016101320161009
9098e/v3gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2016101320161009
9105e/v3gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2016101320161009
9157e/v3gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2016101320161009
9165e/v3gcc -funroll-loops -march=nocona -O -fomit-frame-pointer2016101320161009
9213e/v3gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2016101320161009
9213e/v3gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2016101320161009
9214e/v3gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2016101320161009
9304e/v3gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2016101320161009
9304e/v3gcc -funroll-loops -march=k8 -O -fomit-frame-pointer2016101320161009
9312e/v3gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2016101320161009
9321e/v3gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2016101320161009
9501e/v3gcc -m64 -march=barcelona -O2 -fomit-frame-pointer2016101320161009
9501e/v3gcc -march=barcelona -O2 -fomit-frame-pointer2016101320161009
9595e/v3gcc -funroll-loops -O -fomit-frame-pointer2016101320161009
9595e/v3gcc -funroll-loops -m64 -O -fomit-frame-pointer2016101320161009
9597e/v3gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2016101320161009
9650e/v3gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016101320161009
9670e/v3gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2016101320161009
9672e/v3gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2016101320161009
9683e/v3gcc -march=barcelona -O3 -fomit-frame-pointer2016101320161009
9686e/v3gcc -m64 -march=k8 -O -fomit-frame-pointer2016101320161009
9686e/v3gcc -march=nocona -O3 -fomit-frame-pointer2016101320161009
9692e/v3gcc -m64 -march=barcelona -O3 -fomit-frame-pointer2016101320161009
9702e/v3gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2016101320161009
9719e/v3gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2016101320161009
9719e/v3gcc -funroll-loops -m64 -O3 -fomit-frame-pointer2016101320161009
9731e/v3gcc -funroll-loops -O3 -fomit-frame-pointer2016101320161009
9736e/v3gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2016101320161009
9795e/v3gcc -march=k8 -O2 -fomit-frame-pointer2016101320161009
9840e/v3gcc -fno-schedule-insns -O3 -fomit-frame-pointer2016101320161009
9845e/v3gcc -m64 -O3 -fomit-frame-pointer2016101320161009
9848e/v3gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2016101320161009
9849e/v3gcc -funroll-loops -m64 -O2 -fomit-frame-pointer2016101320161009
9850e/v3gcc -funroll-loops -O2 -fomit-frame-pointer2016101320161009
9858e/v3gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016101320161009
9872e/v3gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2016101320161009
9872e/v3gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2016101320161009
9933e/v3gcc -O2 -fomit-frame-pointer2016101320161009
9933e/v3gcc -fno-schedule-insns -O2 -fomit-frame-pointer2016101320161009
9936e/v3gcc -m64 -O2 -fomit-frame-pointer2016101320161009
10075e/v3gcc -m64 -march=nocona -O3 -fomit-frame-pointer2016101320161009
10078e/v3gcc -O3 -fomit-frame-pointer2016101320161009
10109e/v3gcc -m64 -O -fomit-frame-pointer2016101320161009
10123e/v3gcc -march=nocona -O2 -fomit-frame-pointer2016101320161009
10133e/v3gcc -m64 -march=nocona -O2 -fomit-frame-pointer2016101320161009
10172e/v3gcc -march=k8 -O3 -fomit-frame-pointer2016101320161009
10197e/v3gcc -m64 -march=k8 -O3 -fomit-frame-pointer2016101320161009
10248e/v3gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2016101320161009
10253e/v3gcc -m64 -march=nocona -O -fomit-frame-pointer2016101320161009
10254e/v3gcc -march=nocona -O -fomit-frame-pointer2016101320161009
10261e/v3gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2016101320161009
10261e/v3gcc -march=barcelona -O -fomit-frame-pointer2016101320161009
10266e/v3gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016101320161009
10275e/v3gcc -m64 -march=barcelona -O -fomit-frame-pointer2016101320161009
10282e/v3gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2016101320161009
10291e/v3gcc -m64 -march=core2 -O -fomit-frame-pointer2016101320161009
10373e/v3gcc -m64 -march=corei7 -O -fomit-frame-pointer2016101320161009
10394e/v3gcc -m64 -march=k8 -O2 -fomit-frame-pointer2016101320161009
10469e/v3gcc -fno-schedule-insns -O -fomit-frame-pointer2016101320161009
10470e/v3gcc -O -fomit-frame-pointer2016101320161009
10477e/v3gcc -march=k8 -O -fomit-frame-pointer2016101320161009
10544e/v3gcc -m64 -march=core2 -O2 -fomit-frame-pointer2016101320161009
10544e/v3gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2016101320161009
10545e/v3gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2016101320161009
10570e/v3gcc -m64 -march=corei7 -O2 -fomit-frame-pointer2016101320161009
10578e/v3clang -O3 -fomit-frame-pointer -Qunused-arguments2016101320161009
10822e/v3clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016101320161009
10836e/v3clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016101320161009
11239e/v3gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2016101320161009
11245e/v3gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2016101320161009
11390e/v3gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2016101320161009
11392e/v3gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2016101320161009
11416e/v3gcc -m64 -march=nocona -Os -fomit-frame-pointer2016101320161009
11436e/v3gcc -march=nocona -Os -fomit-frame-pointer2016101320161009
11534e/v3clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016101320161009
11552e/v3clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016101320161009
11571e/v3clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2016101320161009
11608e/v3gcc -march=barcelona -Os -fomit-frame-pointer2016101320161009
11611e/v3gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2016101320161009
11614e/v3gcc -m64 -march=barcelona -Os -fomit-frame-pointer2016101320161009
11746e/v3gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016101320161009
11824e/v3gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2016101320161009
11829e/v3gcc -m64 -march=core2 -Os -fomit-frame-pointer2016101320161009
11846e/v3gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2016101320161009
11854e/v3gcc -m64 -march=corei7 -Os -fomit-frame-pointer2016101320161009
12183e/v3gcc -Os -fomit-frame-pointer2016101320161009
12183e/v3gcc -fno-schedule-insns -Os -fomit-frame-pointer2016101320161009
12183e/v3gcc -m64 -Os -fomit-frame-pointer2016101320161009
12262e/v3gcc -march=k8 -Os -fomit-frame-pointer2016101320161009
12336e/v3gcc -m64 -march=k8 -Os -fomit-frame-pointer2016101320161009
12709e/v3gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2016101320161009
12709e/v3gcc -funroll-loops -m64 -Os -fomit-frame-pointer2016101320161009
12710e/v3gcc -funroll-loops -Os -fomit-frame-pointer2016101320161009
12773e/v3gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2016101320161009
12781e/v3gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2016101320161009
109029e/v3cc2016101320161009
109034e/v3gcc -funroll-loops2016101320161009
109230e/v3gcc2016101320161009

Test failure

Implementation: crypto_stream/cryptmtv3/e/v3
Compiler: gcc -m64 -march=core2 -O3 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -m64 -march=core2 -O3 -fomit-frame-pointer e/v3

Compiler output

Implementation: crypto_stream/cryptmtv3/e/v3
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
cryptmt-v3.c: In file included from cryptmt-v3.c:1:
cryptmt-v3.c: ./e/cryptmt-v3.c:189:18: warning: array index 156 is past the end of the array (which contains 156 elements) [-Warray-bounds]
cryptmt-v3.c: do_recursion(ps->gt;sfmt[N], ps->gt;sfmt[POS1], ps->gt;sfmt[N - 1]);
cryptmt-v3.c: ^ ~
cryptmt-v3.c: ./e/cryptmt-v3.c:25:5: note: array 'sfmt' declared here
cryptmt-v3.c: u32 sfmt[N][4];
cryptmt-v3.c: ^
cryptmt-v3.c: ./e/cryptmt-v3.c:403:27: warning: 'memset' call operates on objects of type 'ECRYPT_ctx' while the size is based on a different type 'ECRYPT_ctx *' [-Wsizeof-pointer-memaccess]
cryptmt-v3.c: memset(ctx, 0, sizeof(ctx));
cryptmt-v3.c: ~~~ ^~~
cryptmt-v3.c: ./e/cryptmt-v3.c:403:27: note: did you mean to dereference the argument to 'sizeof' (and multiply it by the number of elements)?
cryptmt-v3.c: memset(ctx, 0, sizeof(ctx));
cryptmt-v3.c: ^~~
cryptmt-v3.c: 2 warnings generated.

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