Implementation notes: amd64, genji154, crypto_hash/essence384

Computer: genji154
Architecture: amd64
CPU ID: GenuineIntel-00050671-bfebfbff
SUPERCOP version: 20170228
Operation: crypto_hash
Primitive: essence384
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
67275? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2017022620170105
67275? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2017022620170105
72839? ? ?? ? ?gccgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2017022620170105
75283? ? ?? ? ?gccclang_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2017041020170228
75517? ? ?? ? ?gccclang_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
75907? ? ?? ? ?gccclang_-O3_-fwrapv_-march=x86-64_-mcpu=core-avx2_-mavx2_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2017041020170228
75920? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2017041020170228
76076? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2017041020170228
76193? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2017041020170228
79300? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O3_-fomit-frame-pointer2017022620170105
83382? ? ?? ? ?gccclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
83460? ? ?? ? ?gccclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
83538? ? ?? ? ?gccclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
83616? ? ?? ? ?gccclang_-O3_-fomit-frame-pointer_-Qunused-arguments2017041020170228
84084? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2017022620170105
84188? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2017022620170105
86177? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2017022620170105
86294? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2017022620170105
86554? ? ?? ? ?gccgcc_-funroll-loops_-O3_-fomit-frame-pointer2017022620170105
87139? ? ?? ? ?gccgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2017022620170105
87178? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2017022620170105
87191? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2017022620170105
87230? ? ?? ? ?gccgcc_-O3_-fomit-frame-pointer2017022620170105
87334? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
87347? ? ?? ? ?gccgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2017022620170105
87399? ? ?? ? ?gccgcc_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
87555? ? ?? ? ?gccgcc_-m64_-O3_-fomit-frame-pointer2017022620170105
87750? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
87828? ? ?? ? ?gccgcc_-march=k8_-O3_-fomit-frame-pointer2017022620170105
87893? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2017022620170105
87958? ? ?? ? ?gccgcc_-funroll-loops_-O2_-fomit-frame-pointer2017022620170105
87984? ? ?? ? ?gccgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2017022620170105
87997? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
88166? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
88270? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2017022620170105
88439? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2017022620170105
88543? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2017022620170105
88621? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2017022620170105
88725? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2017022620170105
89271? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
97682? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2017022620170105
97877? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2017022620170105
98683? ? ?? ? ?gccgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
99060? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
99125? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2017022620170105
99190? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O2_-fomit-frame-pointer2017022620170105
99255? ? ?? ? ?gccgcc_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
99281? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2017022620170105
99359? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
99541? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
99723? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-Os_-fomit-frame-pointer2017022620170105
99762? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
100997? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2017022620170105
101023? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2017022620170105
101660? ? ?? ? ?gccgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2017022620170105
103688? ? ?? ? ?gccgcc_-m64_-O2_-fomit-frame-pointer2017022620170105
103831? ? ?? ? ?gccgcc_-O2_-fomit-frame-pointer2017022620170105
103987? ? ?? ? ?gccgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2017022620170105
104429? ? ?? ? ?gccgcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2017022620170105
104585? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2017022620170105
104884? ? ?? ? ?gccgcc_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
105131? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2017022620170105
105157? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
105209? ? ?? ? ?gccgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2017022620170105
105352? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2017022620170105
105651? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2017022620170105
105924? ? ?? ? ?gccgcc_-funroll-loops_-Os_-fomit-frame-pointer2017022620170105
105950? ? ?? ? ?gccgcc_-m64_-Os_-fomit-frame-pointer2017022620170105
105963? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2017022620170105
105976? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2017022620170105
105976? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2017022620170105
105989? ? ?? ? ?gccgcc_-march=k8_-Os_-fomit-frame-pointer2017022620170105
106002? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2017022620170105
106015? ? ?? ? ?gccgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2017022620170105
106028? ? ?? ? ?gccgcc_-Os_-fomit-frame-pointer2017022620170105
106028? ? ?? ? ?gccgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2017022620170105
106106? ? ?? ? ?gccgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2017022620170105
106106? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2017022620170105
106119? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2017022620170105
106171? ? ?? ? ?gccgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2017022620170105
107705? ? ?? ? ?gccgcc_-funroll-loops_-O_-fomit-frame-pointer2017022620170105
107718? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2017022620170105
107796? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2017022620170105
108472? ? ?? ? ?gccgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2017022620170105
108524? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
108537? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
108953? ? ?? ? ?gccgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
108953? ? ?? ? ?gccgcc_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
109057? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
109213? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
109486? ? ?? ? ?gccgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2017022620170105
109577? ? ?? ? ?gccgcc_-march=k8_-O2_-fomit-frame-pointer2017022620170105
119314? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2017022620170105
119496? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2017022620170105
122096? ? ?? ? ?gccgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
122200? ? ?? ? ?gccgcc_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
122941? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2017022620170105
123071? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2017022620170105
127049? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2017022620170105
127283? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2017022620170105
128063? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O_-fomit-frame-pointer2017022620170105
128336? ? ?? ? ?gccgcc_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
128648? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
128882? ? ?? ? ?gccgcc_-m64_-march=core2_-O_-fomit-frame-pointer2017022620170105
128908? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2017022620170105
129168? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2017022620170105
129194? ? ?? ? ?gccgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2017022620170105
129389? ? ?? ? ?gccgcc_-march=nocona_-O_-fomit-frame-pointer2017022620170105
129545? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
129831? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
130650? ? ?? ? ?gccgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
130767? ? ?? ? ?gccgcc_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
131963? ? ?? ? ?gccgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2017022620170105
132457? ? ?? ? ?gccgcc_-O_-fomit-frame-pointer2017022620170105
132457? ? ?? ? ?gccgcc_-m64_-O_-fomit-frame-pointer2017022620170105
132535? ? ?? ? ?gccgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2017022620170105
138541? ? ?? ? ?gccgcc_-march=k8_-O_-fomit-frame-pointer2017022620170105
138580? ? ?? ? ?gccgcc_-m64_-march=k8_-O_-fomit-frame-pointer2017022620170105
466518? ? ?? ? ?gcccc2017022620170105
468143? ? ?? ? ?gccgcc_-funroll-loops2017022620170105
470561? ? ?? ? ?gccgcc2017022620170105

Test failure

Implementation: crypto_hash/essence384/gcc
Compiler: icc
error 111
crypto_hash is nondeterministic

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
icc gcc
icc -no-vec gcc
icc -xMIC-AVX512 -O2 -fomit-frame-pointer gcc
icc -xMIC-AVX512 -O3 -fomit-frame-pointer gcc

Compiler output

Implementation: crypto_hash/essence384/gcc
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
essence_L_tables.c: In file included from essence_L_tables.c:12:
essence_L_tables.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
essence_L_tables.c: #ifndef _ESSENCE_API_H_
essence_L_tables.c: ^~~~~~~~~~~~~~~
essence_L_tables.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
essence_L_tables.c: #define _ESSENCE_H_API_
essence_L_tables.c: ^~~~~~~~~~~~~~~
essence_L_tables.c: _ESSENCE_API_H_
essence_L_tables.c: 1 warning generated.
essence_api.c: In file included from essence_api.c:11:
essence_api.c: In file included from ./essence.h:11:
essence_api.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
essence_api.c: #ifndef _ESSENCE_API_H_
essence_api.c: ^~~~~~~~~~~~~~~
essence_api.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
essence_api.c: #define _ESSENCE_H_API_
essence_api.c: ^~~~~~~~~~~~~~~
essence_api.c: _ESSENCE_API_H_
essence_api.c: 1 warning generated.
essence_compress_256.c: In file included from essence_compress_256.c:11:
essence_compress_256.c: In file included from ./essence.h:11:
essence_compress_256.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
essence_compress_256.c: #ifndef _ESSENCE_API_H_
essence_compress_256.c: ^~~~~~~~~~~~~~~
essence_compress_256.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
essence_compress_256.c: #define _ESSENCE_H_API_
essence_compress_256.c: ^~~~~~~~~~~~~~~
essence_compress_256.c: _ESSENCE_API_H_
essence_compress_256.c: 1 warning generated.
essence_compress_256_dual.c: In file included from essence_compress_256_dual.c:11:
essence_compress_256_dual.c: In file included from ./essence.h:11:
essence_compress_256_dual.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
essence_compress_256_dual.c: #ifndef _ESSENCE_API_H_
essence_compress_256_dual.c: ^~~~~~~~~~~~~~~
essence_compress_256_dual.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
essence_compress_256_dual.c: #define _ESSENCE_H_API_
essence_compress_256_dual.c: ^~~~~~~~~~~~~~~
essence_compress_256_dual.c: _ESSENCE_API_H_
essence_compress_256_dual.c: 1 warning generated.
essence_compress_512.c: In file included from essence_compress_512.c:10:
essence_compress_512.c: In file included from ./essence.h:11:
essence_compress_512.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
essence_compress_512.c: #ifndef _ESSENCE_API_H_
essence_compress_512.c: ^~~~~~~~~~~~~~~
essence_compress_512.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
essence_compress_512.c: #define _ESSENCE_H_API_
essence_compress_512.c: ^~~~~~~~~~~~~~~
essence_compress_512.c: _ESSENCE_API_H_
essence_compress_512.c: 1 warning generated.
hash.c: In file included from hash.c:2:
hash.c: ./essence_api.h:13:9: warning: '_ESSENCE_API_H_' is used as a header guard here, followed by #define of a different macro [-Wheader-guard]
hash.c: #ifndef _ESSENCE_API_H_
hash.c: ^~~~~~~~~~~~~~~
hash.c: ./essence_api.h:14:9: note: '_ESSENCE_H_API_' is defined here; did you mean '_ESSENCE_API_H_'?
hash.c: #define _ESSENCE_H_API_
hash.c: ^~~~~~~~~~~~~~~
hash.c: _ESSENCE_API_H_
hash.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 10, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments gcc
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments gcc
clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments gcc
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments gcc
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments gcc
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments gcc
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments gcc
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments gcc
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments gcc
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments gcc