Implementation notes: amd64, genji154, crypto_hash/essence256

Computer: genji154
Architecture: amd64
CPU ID: GenuineIntel-00050671-bfebfbff
SUPERCOP version: 20170228
Operation: crypto_hash
Primitive: essence256
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
114140? ? ?? ? ?gccclang_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
114205? ? ?? ? ?gccclang_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2017041020170228
114387? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2017041020170228
114426? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2017041020170228
114686? ? ?? ? ?gccclang_-O3_-fwrapv_-march=x86-64_-mcpu=core-avx2_-mavx2_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2017041020170228
114725? ? ?? ? ?gccclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2017041020170228
116961? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2017022620170105
117234? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2017022620170105
121849? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O3_-fomit-frame-pointer2017022620170105
122434? ? ?? ? ?gccclang_-O3_-fomit-frame-pointer_-Qunused-arguments2017041020170228
122447? ? ?? ? ?gccclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
122655? ? ?? ? ?gccclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
122824? ? ?? ? ?gccclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2017041020170228
129831? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2017022620170105
129831? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2017022620170105
133211? ? ?? ? ?gccgcc_-m64_-O3_-fomit-frame-pointer2017022620170105
133627? ? ?? ? ?gccgcc_-O3_-fomit-frame-pointer2017022620170105
133692? ? ?? ? ?gccgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2017022620170105
134446? ? ?? ? ?gccgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2017022620170105
134953? ? ?? ? ?gccgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2017022620170105
134966? ? ?? ? ?gccgcc_-funroll-loops_-O3_-fomit-frame-pointer2017022620170105
135122? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2017022620170105
135226? ? ?? ? ?gccgcc_-march=k8_-O3_-fomit-frame-pointer2017022620170105
135603? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2017022620170105
135629? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2017022620170105
135642? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2017022620170105
136149? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2017022620170105
136162? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
136240? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2017022620170105
136695? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
137761? ? ?? ? ?gccgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2017022620170105
137904? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
137956? ? ?? ? ?gccgcc_-march=barcelona_-O3_-fomit-frame-pointer2017022620170105
137969? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2017022620170105
137982? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2017022620170105
138164? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
138229? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
138359? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2017022620170105
138450? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2017022620170105
138489? ? ?? ? ?gccgcc_-funroll-loops_-O2_-fomit-frame-pointer2017022620170105
146887? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
146913? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
147056? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
147082? ? ?? ? ?gccgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
147082? ? ?? ? ?gccgcc_-march=nocona_-O3_-fomit-frame-pointer2017022620170105
147186? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
150774? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2017022620170105
151307? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2017022620170105
152776? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-Os_-fomit-frame-pointer2017022620170105
154219? ? ?? ? ?gccgcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2017022620170105
154401? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2017022620170105
162877? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
163345? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
165230? ? ?? ? ?gccgcc_-funroll-loops_-O_-fomit-frame-pointer2017022620170105
165477? ? ?? ? ?gccgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2017022620170105
165711? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2017022620170105
166803? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2017022620170105
166920? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2017022620170105
169923? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O2_-fomit-frame-pointer2017022620170105
170638? ? ?? ? ?gccgcc_-m64_-Os_-fomit-frame-pointer2017022620170105
170638? ? ?? ? ?gccgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2017022620170105
170768? ? ?? ? ?gccgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2017022620170105
170846? ? ?? ? ?gccgcc_-march=k8_-Os_-fomit-frame-pointer2017022620170105
170963? ? ?? ? ?gccgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2017022620170105
170963? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2017022620170105
171093? ? ?? ? ?gccgcc_-Os_-fomit-frame-pointer2017022620170105
172458? ? ?? ? ?gccgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2017022620170105
172510? ? ?? ? ?gccgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2017022620170105
172523? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2017022620170105
172562? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2017022620170105
172679? ? ?? ? ?gccgcc_-funroll-loops_-Os_-fomit-frame-pointer2017022620170105
173953? ? ?? ? ?gccgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
174200? ? ?? ? ?gccgcc_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
175695? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
175747? ? ?? ? ?gccgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2017022620170105
175760? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2017022620170105
176098? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2017022620170105
177814? ? ?? ? ?gccgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2017022620170105
178464? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2017022620170105
178620? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2017022620170105
182507? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2017022620170105
183040? ? ?? ? ?gccgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2017022620170105
184496? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2017022620170105
184964? ? ?? ? ?gccgcc_-m64_-O2_-fomit-frame-pointer2017022620170105
185029? ? ?? ? ?gccgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2017022620170105
185224? ? ?? ? ?gccgcc_-O2_-fomit-frame-pointer2017022620170105
186082? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
186277? ? ?? ? ?gccgcc_-march=barcelona_-O2_-fomit-frame-pointer2017022620170105
186342? ? ?? ? ?gccgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2017022620170105
188045? ? ?? ? ?gccgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2017022620170105
188058? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2017022620170105
188175? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2017022620170105
200616? ? ?? ? ?gccgcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2017022620170105
200616? ? ?? ? ?gccgcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2017022620170105
201851? ? ?? ? ?gccgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
201890? ? ?? ? ?gccgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
202267? ? ?? ? ?gccgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
202345? ? ?? ? ?gccgcc_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2017022620170105
202410? ? ?? ? ?gccgcc_-m64_-march=core-avx2_-O_-fomit-frame-pointer2017022620170105
202566? ? ?? ? ?gccgcc_-march=nocona_-Os_-fomit-frame-pointer2017022620170105
203255? ? ?? ? ?gccgcc_-march=k8_-O2_-fomit-frame-pointer2017022620170105
203528? ? ?? ? ?gccgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2017022620170105
204893? ? ?? ? ?gccgcc_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
205218? ? ?? ? ?gccgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2017022620170105
209664? ? ?? ? ?gccgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2017022620170105
209937? ? ?? ? ?gccgcc_-march=nocona_-O_-fomit-frame-pointer2017022620170105
210392? ? ?? ? ?gccgcc_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2017022620170105
211094? ? ?? ? ?gccgcc_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
211354? ? ?? ? ?gccgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2017022620170105
213317? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2017022620170105
213395? ? ?? ? ?gccgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2017022620170105
213460? ? ?? ? ?gccgcc_-m64_-march=core2_-O_-fomit-frame-pointer2017022620170105
217620? ? ?? ? ?gccgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2017022620170105
221962? ? ?? ? ?gccgcc_-O_-fomit-frame-pointer2017022620170105
222066? ? ?? ? ?gccgcc_-m64_-O_-fomit-frame-pointer2017022620170105
222768? ? ?? ? ?gccgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2017022620170105
231400? ? ?? ? ?gccgcc_-march=k8_-O_-fomit-frame-pointer2017022620170105
231543? ? ?? ? ?gccgcc_-m64_-march=k8_-O_-fomit-frame-pointer2017022620170105
799773? ? ?? ? ?gccgcc_-funroll-loops2017022620170105
801073? ? ?? ? ?gccgcc2017022620170105
802594? ? ?? ? ?gcccc2017022620170105

Test failure

Implementation: crypto_hash/essence256/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/essence256/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