Implementation notes: amd64, gpu, crypto_kem/bike3l1

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: bike3l1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
529190119864 8 11432011 3416 6584ref_ntlclang++_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019100820190816
769173619864 8 11432011 3416 6584ref_ntlclang++_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019100820190816
773487621270 8 11430252 3408 6872ref_ntlclang++_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019100820190816
775653919864 8 11432011 3416 6584ref_ntlclang++_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019100820190816
779584521366 8 11431020 3408 6872ref_ntlclang++_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019100820190816
807558321366 8 11431020 3408 6872ref_ntlclang++_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2019100820190816
810757821270 8 11430252 3408 6872ref_ntlclang++_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019100820190816
8137026? ? ?? ? ?ref_ntlg++_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2019100820190816
857958319850 8 11430667 3416 6584ref_ntlclang++_-O3_-fomit-frame-pointer_-Qunused-arguments2019100820190816
9857379? ? ?? ? ?ref_ntlg++_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019100820190816
10394673? ? ?? ? ?ref_ntlg++_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019100820190816
10716903? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019100820190816
10745433? ? ?? ? ?ref_ntlg++_-m64_-march=corei7_-O3_-fomit-frame-pointer2019100820190816
10758507? ? ?? ? ?ref_ntlg++_-m64_-O3_-fomit-frame-pointer2019100820190816
10791486? ? ?? ? ?ref_ntlg++_-march=k8_-O3_-fomit-frame-pointer2019100820190816
10811163? ? ?? ? ?ref_ntlg++_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2019100820190816
10825263? ? ?? ? ?ref_ntlg++_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019100820190816
10886565? ? ?? ? ?ref_ntlg++_-m64_-march=k8_-O3_-fomit-frame-pointer2019100820190816
10902843? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-O3_-fomit-frame-pointer2019100820190816
10937973? ? ?? ? ?ref_ntlg++_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2019100820190816
11098863? ? ?? ? ?ref_ntlg++_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2019100820190816
11296386? ? ?? ? ?ref_ntlg++_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019100820190816
11344722? ? ?? ? ?ref_ntlg++_-O3_-fomit-frame-pointer2019100820190816
11415123? ? ?? ? ?ref_ntlg++_-march=k8_-O2_-fomit-frame-pointer2019100820190816
11460453? ? ?? ? ?ref_ntlg++_-march=k8_-O_-fomit-frame-pointer2019100820190816
11464296? ? ?? ? ?ref_ntlg++_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2019100820190816
11507901? ? ?? ? ?ref_ntlg++_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2019100820190816
11543973? ? ?? ? ?ref_ntlg++_-fno-schedule-insns_-O2_-fomit-frame-pointer2019100820190816
11596044? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-O_-fomit-frame-pointer2019100820190816
11638158? ? ?? ? ?ref_ntlg++_-m64_-march=k8_-O2_-fomit-frame-pointer2019100820190816
11641287? ? ?? ? ?ref_ntlg++_-fno-schedule-insns_-O3_-fomit-frame-pointer2019100820190816
11642904? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019100820190816
11676036? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019100820190816
11689920? ? ?? ? ?ref_ntlg++_-march=barcelona_-O3_-fomit-frame-pointer2019100820190816
11724210? ? ?? ? ?ref_ntlg++_-march=barcelona_-O_-fomit-frame-pointer2019100820190816
11735319? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-O2_-fomit-frame-pointer2019100820190816
11798331? ? ?? ? ?ref_ntlg++_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2019100820190816
11855958? ? ?? ? ?ref_ntlg++_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2019100820190816
11861964? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019100820190816
11894238? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019100820190816
11899341? ? ?? ? ?ref_ntlg++_-march=barcelona_-O2_-fomit-frame-pointer2019100820190816
11972859? ? ?? ? ?ref_ntlg++_-m64_-march=corei7_-O2_-fomit-frame-pointer2019100820190816
12044934? ? ?? ? ?ref_ntlg++_-fno-schedule-insns_-O_-fomit-frame-pointer2019100820190816
12107820? ? ?? ? ?ref_ntlg++_-O_-fomit-frame-pointer2019100820190816
12109593? ? ?? ? ?ref_ntlg++_-m64_-march=nocona_-O3_-fomit-frame-pointer2019100820190816
12124173? ? ?? ? ?ref_ntlg++_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2019100820190816
12215907? ? ?? ? ?ref_ntlg++_-m64_-O2_-fomit-frame-pointer2019100820190816
12232515? ? ?? ? ?ref_ntlg++_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2019100820190816
12258138? ? ?? ? ?ref_ntlg++_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019100820190816
12303600? ? ?? ? ?ref_ntlg++_-march=nocona_-O3_-fomit-frame-pointer2019100820190816
12392808? ? ?? ? ?ref_ntlg++_-m64_-march=barcelona_-O_-fomit-frame-pointer2019100820190816
12400065? ? ?? ? ?ref_ntlg++_-m64_-march=k8_-O_-fomit-frame-pointer2019100820190816
12543258? ? ?? ? ?ref_ntlg++_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2019100820190816
12757917? ? ?? ? ?ref_ntlg++_-m64_-march=corei7_-O_-fomit-frame-pointer2019100820190816
12776391? ? ?? ? ?ref_ntlg++_-O2_-fomit-frame-pointer2019100820190816
12818349? ? ?? ? ?ref_ntlg++_-march=nocona_-O2_-fomit-frame-pointer2019100820190816
12852087? ? ?? ? ?ref_ntlg++_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2019100820190816
12856881? ? ?? ? ?ref_ntlg++_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2019100820190816
12896784? ? ?? ? ?ref_ntlg++_-m64_-O_-fomit-frame-pointer2019100820190816
13327500? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019100820190816
13417773? ? ?? ? ?ref_ntlg++_-march=nocona_-O_-fomit-frame-pointer2019100820190816
13756398? ? ?? ? ?ref_ntlg++_-m64_-march=nocona_-O_-fomit-frame-pointer2019100820190816
14070681? ? ?? ? ?ref_ntlg++_-m64_-march=nocona_-O2_-fomit-frame-pointer2019100820190816
14178873? ? ?? ? ?ref_ntlg++_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2019100820190816
14219334? ? ?? ? ?ref_ntlg++_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019100820190816
14365731? ? ?? ? ?ref_ntlg++_-march=barcelona_-Os_-fomit-frame-pointer2019100820190816
14380233? ? ?? ? ?ref_ntlg++_-m64_-march=k8_-Os_-fomit-frame-pointer2019100820190816
14457336? ? ?? ? ?ref_ntlg++_-m64_-march=corei7_-Os_-fomit-frame-pointer2019100820190816
14541351? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019100820190816
14643462? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019100820190816
14848077? ? ?? ? ?ref_ntlg++_-m64_-march=nocona_-Os_-fomit-frame-pointer2019100820190816
14928834? ? ?? ? ?ref_ntlg++_-m64_-Os_-fomit-frame-pointer2019100820190816
15044820? ? ?? ? ?ref_ntlg++_-fno-schedule-insns_-Os_-fomit-frame-pointer2019100820190816
15063627? ? ?? ? ?ref_ntlg++_-m64_-march=core2_-Os_-fomit-frame-pointer2019100820190816
15067107? ? ?? ? ?ref_ntlg++_-march=nocona_-Os_-fomit-frame-pointer2019100820190816
15077016? ? ?? ? ?ref_ntlg++_-Os_-fomit-frame-pointer2019100820190816
15246138? ? ?? ? ?ref_ntlg++_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2019100820190816
15320451? ? ?? ? ?ref_ntlg++_-march=k8_-Os_-fomit-frame-pointer2019100820190816
15334494? ? ?? ? ?ref_ntlg++_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2019100820190816
15391173? ? ?? ? ?ref_ntlg++_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019100820190816
22184637? ? ?? ? ?ref_ntlg++2019100820190816

Test failure

Implementation: ref_ntl
Security model: unknown
Compiler: g++ -m64 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
g++ -m64 -march=core-avx2 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx2 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx2 -Os -fomit-frame-pointer ref_ntl

Compiler output

Implementation: ref_ntl
Security model: unknown
Compiler: clang++ -O3 -fomit-frame-pointer -Qunused-arguments
aes_ctr_prf.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
conversions.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
decode.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
kem.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
parallel_hash.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
sampling.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
utilities.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]

Number of similar (compiler,implementation) pairs: 8, namely:
CompilerImplementations
clang++ -O3 -fomit-frame-pointer -Qunused-arguments ref_ntl
clang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref_ntl
clang++ -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments ref_ntl
clang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments ref_ntl
clang++ -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref_ntl
clang++ -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref_ntl
clang++ -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref_ntl
clang++ -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref_ntl

Compiler output

Implementation: ref_ntl
Security model: unknown
Compiler: g++
measure.cpp: /usr/bin/ld: /home/z/supercop/supercop-20190816/supercop-data/gpu/amd64/lib/fastrandombytes.o: relocation R_X86_64_32 against `.bss' can not be used when making a PIE object; recompile with -fPIC
measure.cpp: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.cpp: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 69, namely:
CompilerImplementations
g++ ref_ntl
g++ -O2 -fomit-frame-pointer ref_ntl
g++ -O3 -fomit-frame-pointer ref_ntl
g++ -O -fomit-frame-pointer ref_ntl
g++ -Os -fomit-frame-pointer ref_ntl
g++ -fno-schedule-insns -O2 -fomit-frame-pointer ref_ntl
g++ -fno-schedule-insns -O3 -fomit-frame-pointer ref_ntl
g++ -fno-schedule-insns -O -fomit-frame-pointer ref_ntl
g++ -fno-schedule-insns -Os -fomit-frame-pointer ref_ntl
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ref_ntl
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ref_ntl
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref_ntl
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref_ntl
g++ -m64 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -O -fomit-frame-pointer ref_ntl
g++ -m64 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx-i -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx-i -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=core-avx-i -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7-avx -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7-avx -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7-avx -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=corei7 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=k8 -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=k8 -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=k8 -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=k8 -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=native -mtune=native -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer ref_ntl
g++ -m64 -march=nocona -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=nocona -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=nocona -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=nocona -Os -fomit-frame-pointer ref_ntl
g++ -march=barcelona -O2 -fomit-frame-pointer ref_ntl
g++ -march=barcelona -O3 -fomit-frame-pointer ref_ntl
g++ -march=barcelona -O -fomit-frame-pointer ref_ntl
g++ -march=barcelona -Os -fomit-frame-pointer ref_ntl
g++ -march=k8 -O2 -fomit-frame-pointer ref_ntl
g++ -march=k8 -O3 -fomit-frame-pointer ref_ntl
g++ -march=k8 -O -fomit-frame-pointer ref_ntl
g++ -march=k8 -Os -fomit-frame-pointer ref_ntl
g++ -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv ref_ntl
g++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv ref_ntl
g++ -march=native -mtune=native -O -fomit-frame-pointer -fwrapv ref_ntl
g++ -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv ref_ntl
g++ -march=nocona -O2 -fomit-frame-pointer ref_ntl
g++ -march=nocona -O3 -fomit-frame-pointer ref_ntl
g++ -march=nocona -O -fomit-frame-pointer ref_ntl
g++ -march=nocona -Os -fomit-frame-pointer ref_ntl

Compiler output

Implementation: ref_ntl
Security model: unknown
Compiler: g++ -m64 -march=barcelona -O2 -fomit-frame-pointer
measure.cpp: /usr/bin/ld: /home/z/supercop/supercop-20190816/supercop-data/gpu/amd64/lib/fastrandombytes.o: relocation R_X86_64_32 against `.bss' can not be used when making a PIE object; recompile with -fPIC
measure.cpp: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.cpp: collect2: error: ld returned 1 exit status
measure.cpp: /usr/bin/ld: /home/z/supercop/supercop-20190816/supercop-data/gpu/amd64/lib/fastrandombytes.o: relocation R_X86_64_32 against `.bss' can not be used when making a PIE object; recompile with -fPIC
measure.cpp: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.cpp: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
g++ -m64 -march=barcelona -O2 -fomit-frame-pointer ref_ntl
g++ -m64 -march=barcelona -O3 -fomit-frame-pointer ref_ntl
g++ -m64 -march=barcelona -O -fomit-frame-pointer ref_ntl
g++ -m64 -march=barcelona -Os -fomit-frame-pointer ref_ntl