Implementation notes: amd64, calvin, crypto_stream/cryptmtv3

Computer: calvin
Architecture: amd64
CPU ID: AuthenticAMD-00600f20-178bfbff
SUPERCOP version: 20171218
Operation: crypto_stream
Primitive: cryptmtv3
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
9520? ? ?? ? ?e/v3clang_-O3_-fomit-frame-pointer_-Qunused-arguments2017091020170904
10039? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2017091020170904
10057? ? ?? ? ?e/v3gcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2017091020170904
10112? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2017091020170904
10135? ? ?? ? ?e/v3gcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2017091020170904
10211? ? ?? ? ?e/v3gcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2017091020170904
10236? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2017091020170904
10250? ? ?? ? ?e/v3gcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2017091020170904
10294? ? ?? ? ?e/v3gcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2017091020170904
10296? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2017091020170904
10297? ? ?? ? ?e/v3gcc_-funroll-loops_-O3_-fomit-frame-pointer2017091020170904
10297? ? ?? ? ?e/v3gcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2017091020170904
10302? ? ?? ? ?e/v3gcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2017091020170904
10303? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2017091020170904
10363? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017091020170904
10367? ? ?? ? ?e/v3gcc_-funroll-loops_-O2_-fomit-frame-pointer2017091020170904
10368? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2017091020170904
10371? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2017091020170904
10389? ? ?? ? ?e/v3gcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2017091020170904
10391? ? ?? ? ?e/v3gcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2017091020170904
10406? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017091020170904
10522? ? ?? ? ?e/v3gcc_-funroll-loops_-O_-fomit-frame-pointer2017091020170904
10522? ? ?? ? ?e/v3gcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2017091020170904
10539? ? ?? ? ?e/v3gcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2017091020170904
10558? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2017091020170904
10573? ? ?? ? ?e/v3gcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2017091020170904
10577? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2017091020170904
10585? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2017091020170904
10975? ? ?? ? ?e/v3gcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2017091020170904
10977? ? ?? ? ?e/v3gcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2017091020170904
10982? ? ?? ? ?e/v3gcc_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2017091020170904
10985? ? ?? ? ?e/v3gcc_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2017091020170904
10996? ? ?? ? ?e/v3gcc_-march=nocona_-O3_-fomit-frame-pointer2017091020170904
11018? ? ?? ? ?e/v3gcc_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2017091020170904
11031? ? ?? ? ?e/v3gcc_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2017091020170904
11049? ? ?? ? ?e/v3gcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2017091020170904
11071? ? ?? ? ?e/v3gcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017091020170904
11072? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2017091020170904
11072? ? ?? ? ?e/v3gcc_-march=barcelona_-O3_-fomit-frame-pointer2017091020170904
11073? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2017091020170904
11074? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2017091020170904
11074? ? ?? ? ?e/v3gcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2017091020170904
11090? ? ?? ? ?e/v3gcc_-march=nocona_-O2_-fomit-frame-pointer2017091020170904
11097? ? ?? ? ?e/v3gcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017091020170904
11099? ? ?? ? ?e/v3gcc_-m64_-march=core2_-O2_-fomit-frame-pointer2017091020170904
11119? ? ?? ? ?e/v3gcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2017091020170904
11124? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2017091020170904
11130? ? ?? ? ?e/v3gcc_-march=nocona_-O_-fomit-frame-pointer2017091020170904
11135? ? ?? ? ?e/v3gcc_-m64_-march=nocona_-O_-fomit-frame-pointer2017091020170904
11139? ? ?? ? ?e/v3gcc_-march=barcelona_-O2_-fomit-frame-pointer2017091020170904
11158? ? ?? ? ?e/v3gcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2017091020170904
11160? ? ?? ? ?e/v3gcc_-m64_-march=core2_-O3_-fomit-frame-pointer2017091020170904
11179? ? ?? ? ?e/v3gcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2017091020170904
11209? ? ?? ? ?e/v3gcc_-O3_-fomit-frame-pointer2017091020170904
11211? ? ?? ? ?e/v3gcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2017091020170904
11241? ? ?? ? ?e/v3gcc_-m64_-march=k8_-O3_-fomit-frame-pointer2017091020170904
11244? ? ?? ? ?e/v3gcc_-m64_-O3_-fomit-frame-pointer2017091020170904
11253? ? ?? ? ?e/v3gcc_-march=k8_-O3_-fomit-frame-pointer2017091020170904
11263? ? ?? ? ?e/v3gcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2017091020170904
11276? ? ?? ? ?e/v3gcc_-m64_-march=k8_-O2_-fomit-frame-pointer2017091020170904
11277? ? ?? ? ?e/v3gcc_-march=k8_-O2_-fomit-frame-pointer2017091020170904
11286? ? ?? ? ?e/v3gcc_-O2_-fomit-frame-pointer2017091020170904
11286? ? ?? ? ?e/v3gcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2017091020170904
11292? ? ?? ? ?e/v3gcc_-m64_-O2_-fomit-frame-pointer2017091020170904
11300? ? ?? ? ?e/v3gcc_-march=nocona_-Os_-fomit-frame-pointer2017091020170904
11304? ? ?? ? ?e/v3gcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2017091020170904
11311? ? ?? ? ?e/v3gcc_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2017091020170904
11311? ? ?? ? ?e/v3gcc_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2017091020170904
11330? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2017091020170904
11331? ? ?? ? ?e/v3gcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2017091020170904
11341? ? ?? ? ?e/v3gcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2017091020170904
11356? ? ?? ? ?e/v3clang_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017091020170904
11369? ? ?? ? ?e/v3clang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2017091020170904
11373? ? ?? ? ?e/v3gcc_-m64_-march=core2_-Os_-fomit-frame-pointer2017091020170904
11373? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2017091020170904
11377? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2017091020170904
11386? ? ?? ? ?e/v3clang_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2017091020170904
11400? ? ?? ? ?e/v3clang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2017091020170904
11401? ? ?? ? ?e/v3gcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2017091020170904
11405? ? ?? ? ?e/v3gcc_-m64_-march=corei7_-O_-fomit-frame-pointer2017091020170904
11416? ? ?? ? ?e/v3gcc_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2017091020170904
11423? ? ?? ? ?e/v3gcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2017091020170904
11424? ? ?? ? ?e/v3gcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2017091020170904
11426? ? ?? ? ?e/v3gcc_-fno-schedule-insns_-O_-fomit-frame-pointer2017091020170904
11426? ? ?? ? ?e/v3gcc_-m64_-O_-fomit-frame-pointer2017091020170904
11427? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017091020170904
11428? ? ?? ? ?e/v3gcc_-O_-fomit-frame-pointer2017091020170904
11436? ? ?? ? ?e/v3gcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2017091020170904
11438? ? ?? ? ?e/v3gcc_-funroll-loops_-Os_-fomit-frame-pointer2017091020170904
11445? ? ?? ? ?e/v3gcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2017091020170904
11459? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2017091020170904
11459? ? ?? ? ?e/v3gcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2017091020170904
11463? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2017091020170904
11463? ? ?? ? ?e/v3gcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2017091020170904
11463? ? ?? ? ?e/v3gcc_-m64_-march=k8_-O_-fomit-frame-pointer2017091020170904
11466? ? ?? ? ?e/v3gcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017091020170904
11466? ? ?? ? ?e/v3gcc_-m64_-march=core2_-O_-fomit-frame-pointer2017091020170904
11468? ? ?? ? ?e/v3gcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2017091020170904
11468? ? ?? ? ?e/v3gcc_-march=barcelona_-Os_-fomit-frame-pointer2017091020170904
11474? ? ?? ? ?e/v3gcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2017091020170904
11476? ? ?? ? ?e/v3gcc_-march=barcelona_-O_-fomit-frame-pointer2017091020170904
11482? ? ?? ? ?e/v3gcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2017091020170904
11494? ? ?? ? ?e/v3gcc_-march=k8_-O_-fomit-frame-pointer2017091020170904
11532? ? ?? ? ?e/v3clang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017091020170904
11546? ? ?? ? ?e/v3clang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017091020170904
11573? ? ?? ? ?e/v3clang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017091020170904
11584? ? ?? ? ?e/v3gcc_-m64_-march=k8_-Os_-fomit-frame-pointer2017091020170904
11612? ? ?? ? ?e/v3gcc_-Os_-fomit-frame-pointer2017091020170904
11620? ? ?? ? ?e/v3gcc_-march=k8_-Os_-fomit-frame-pointer2017091020170904
11623? ? ?? ? ?e/v3gcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2017091020170904
11639? ? ?? ? ?e/v3gcc_-m64_-Os_-fomit-frame-pointer2017091020170904
11805? ? ?? ? ?e/v3gcc_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2017091020170904
83172? ? ?? ? ?e/v3cc2017091020170904
83182? ? ?? ? ?e/v3gcc2017091020170904
83219? ? ?? ? ?e/v3gcc_-funroll-loops2017091020170904

Test failure

Implementation: crypto_stream/cryptmtv3/e/v3
Compiler: gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer e/v3
gcc -m64 -march=core-avx2 -O -fomit-frame-pointer e/v3
gcc -m64 -march=core-avx2 -Os -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:2:
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->sfmt[N], ps->sfmt[POS1], ps->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 'crypto_stream_cryptmtv3_e_v3_ECRYPT_ctx' while the size is based on a different type 'crypto_stream_cryptmtv3_e_v3_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: 8, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments e/v3
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments e/v3
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments e/v3
clang -O3 -fwrapv -mavx -maes -mpclmul -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