Implementation notes: amd64, gpu, crypto_kem/rolloii128

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: rolloii128
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
1248190230976 48 731608263 3624 7288refclang++_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019101220190816
19607859? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101220190816
19792704? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101220190816
1989964831280 48 731611655 3624 7064refclang++_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101220190816
1991174131239 48 731610303 3624 7064refclang++_-O3_-fomit-frame-pointer_-Qunused-arguments2019101220190816
19941495? ? ?? ? ?refg++_-m64_-march=k8_-O_-fomit-frame-pointer2019101220190816
19943880? ? ?? ? ?refg++_-m64_-march=k8_-O3_-fomit-frame-pointer2019101220190816
19963161? ? ?? ? ?refg++_-O3_-fomit-frame-pointer2019101220190816
20004603? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2019101220190816
20035911? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2019101220190816
20059686? ? ?? ? ?refg++_-O2_-fomit-frame-pointer2019101220190816
2009571331280 48 731611655 3624 7064refclang++_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101220190816
20097756? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101220190816
20098149? ? ?? ? ?refg++_-m64_-O3_-fomit-frame-pointer2019101220190816
20126997? ? ?? ? ?refg++_-march=k8_-O2_-fomit-frame-pointer2019101220190816
20135886? ? ?? ? ?refg++_-m64_-march=core2_-O2_-fomit-frame-pointer2019101220190816
20136987? ? ?? ? ?refg++_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101220190816
20173140? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2019101220190816
20178168? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2019101220190816
20200953? ? ?? ? ?refg++_-m64_-march=k8_-O2_-fomit-frame-pointer2019101220190816
20203569? ? ?? ? ?refg++_-march=barcelona_-Os_-fomit-frame-pointer2019101220190816
20213571? ? ?? ? ?refg++_-march=nocona_-O_-fomit-frame-pointer2019101220190816
20234997? ? ?? ? ?refg++_-march=barcelona_-O_-fomit-frame-pointer2019101220190816
20242266? ? ?? ? ?refg++_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2019101220190816
20245041? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2019101220190816
20253630? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2019101220190816
20285931? ? ?? ? ?refg++_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101220190816
20327955? ? ?? ? ?refg++_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101220190816
20343591? ? ?? ? ?refg++_-m64_-march=corei7_-O_-fomit-frame-pointer2019101220190816
20365365? ? ?? ? ?refg++_-m64_-march=nocona_-O_-fomit-frame-pointer2019101220190816
20368233? ? ?? ? ?refg++_-O_-fomit-frame-pointer2019101220190816
20375457? ? ?? ? ?refg++_-march=k8_-O_-fomit-frame-pointer2019101220190816
2037924331280 48 731611655 3624 7064refclang++_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101220190816
20380170? ? ?? ? ?refg++_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2019101220190816
20388087? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101220190816
20404125? ? ?? ? ?refg++_-m64_-march=core2_-O_-fomit-frame-pointer2019101220190816
20439060? ? ?? ? ?refg++_-m64_-march=core2_-O3_-fomit-frame-pointer2019101220190816
20447442? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2019101220190816
20448303? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101220190816
20475177? ? ?? ? ?refg++_-march=k8_-Os_-fomit-frame-pointer2019101220190816
20490414? ? ?? ? ?refg++_-m64_-Os_-fomit-frame-pointer2019101220190816
20506383? ? ?? ? ?refg++_-march=barcelona_-O3_-fomit-frame-pointer2019101220190816
20518656? ? ?? ? ?refg++_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101220190816
20583261? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101220190816
20583654? ? ?? ? ?refg++_-march=nocona_-Os_-fomit-frame-pointer2019101220190816
20601195? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101220190816
20614113? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2019101220190816
20632887? ? ?? ? ?refg++_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2019101220190816
20658933? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2019101220190816
20683722? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2019101220190816
20865549? ? ?? ? ?refg++_-march=k8_-O3_-fomit-frame-pointer2019101220190816
20887377? ? ?? ? ?refg++_-m64_-march=core2_-Os_-fomit-frame-pointer2019101220190816
2089405231488 48 731609479 3624 7288refclang++_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101220190816
20953071? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101220190816
2098388430976 48 731608263 3624 7288refclang++_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101220190816
2098796131488 48 731609479 3624 7288refclang++_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2019101220190816
20997894? ? ?? ? ?refg++_-m64_-O2_-fomit-frame-pointer2019101220190816
21002973? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101220190816
21018792? ? ?? ? ?refg++_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101220190816
21023964? ? ?? ? ?refg++_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101220190816
21039258? ? ?? ? ?refg++_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101220190816
21103902? ? ?? ? ?refg++_-march=nocona_-O3_-fomit-frame-pointer2019101220190816
21106461? ? ?? ? ?refg++_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101220190816
21132219? ? ?? ? ?refg++_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101220190816
21181839? ? ?? ? ?refg++_-march=nocona_-O2_-fomit-frame-pointer2019101220190816
21189021? ? ?? ? ?refg++_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101220190816
21201108? ? ?? ? ?refg++_-fno-schedule-insns_-O_-fomit-frame-pointer2019101220190816
21214740? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101220190816
21221139? ? ?? ? ?refg++_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2019101220190816
21242472? ? ?? ? ?refg++_-m64_-march=k8_-Os_-fomit-frame-pointer2019101220190816
21258453? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101220190816
21277614? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101220190816
21305379? ? ?? ? ?refg++_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101220190816
21316851? ? ?? ? ?refg++_-m64_-O_-fomit-frame-pointer2019101220190816
21317139? ? ?? ? ?refg++_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101220190816
21336462? ? ?? ? ?refg++_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101220190816
21342609? ? ?? ? ?refg++_-march=barcelona_-O2_-fomit-frame-pointer2019101220190816
21354342? ? ?? ? ?refg++_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2019101220190816
21354375? ? ?? ? ?refg++_-Os_-fomit-frame-pointer2019101220190816
21367986? ? ?? ? ?refg++_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2019101220190816
27360783? ? ?? ? ?refg++2019101220190816

Test failure

Implementation: ref
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
g++ -m64 -march=core-avx2 -O -fomit-frame-pointer ref
g++ -m64 -march=core-avx2 -Os -fomit-frame-pointer ref

Compiler output

Implementation: ref
Security model: unknown
Compiler: clang++ -O3 -fomit-frame-pointer -Qunused-arguments
rng.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
clang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments ref
clang++ -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang++ -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang++ -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang++ -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: ref
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
g++ -O2 -fomit-frame-pointer ref
g++ -O3 -fomit-frame-pointer ref
g++ -O -fomit-frame-pointer ref
g++ -Os -fomit-frame-pointer ref
g++ -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O3 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -fno-schedule-insns -Os -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref
g++ -m64 -O2 -fomit-frame-pointer ref
g++ -m64 -O3 -fomit-frame-pointer ref
g++ -m64 -O -fomit-frame-pointer ref
g++ -m64 -Os -fomit-frame-pointer ref
g++ -m64 -march=core-avx-i -O2 -fomit-frame-pointer ref
g++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer ref
g++ -m64 -march=core-avx-i -O -fomit-frame-pointer ref
g++ -m64 -march=core-avx-i -Os -fomit-frame-pointer ref
g++ -m64 -march=core2 -O2 -fomit-frame-pointer ref
g++ -m64 -march=core2 -O3 -fomit-frame-pointer ref
g++ -m64 -march=core2 -O -fomit-frame-pointer ref
g++ -m64 -march=core2 -Os -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4 -O -fomit-frame-pointer ref
g++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer ref
g++ -m64 -march=corei7-avx -O2 -fomit-frame-pointer ref
g++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer ref
g++ -m64 -march=corei7-avx -O -fomit-frame-pointer ref
g++ -m64 -march=corei7-avx -Os -fomit-frame-pointer ref
g++ -m64 -march=corei7 -O2 -fomit-frame-pointer ref
g++ -m64 -march=corei7 -O3 -fomit-frame-pointer ref
g++ -m64 -march=corei7 -O -fomit-frame-pointer ref
g++ -m64 -march=corei7 -Os -fomit-frame-pointer ref
g++ -m64 -march=k8 -O2 -fomit-frame-pointer ref
g++ -m64 -march=k8 -O3 -fomit-frame-pointer ref
g++ -m64 -march=k8 -O -fomit-frame-pointer ref
g++ -m64 -march=k8 -Os -fomit-frame-pointer ref
g++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer ref
g++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer ref
g++ -m64 -march=native -mtune=native -O -fomit-frame-pointer ref
g++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer ref
g++ -m64 -march=nocona -O2 -fomit-frame-pointer ref
g++ -m64 -march=nocona -O3 -fomit-frame-pointer ref
g++ -m64 -march=nocona -O -fomit-frame-pointer ref
g++ -m64 -march=nocona -Os -fomit-frame-pointer ref
g++ -march=barcelona -O2 -fomit-frame-pointer ref
g++ -march=barcelona -O3 -fomit-frame-pointer ref
g++ -march=barcelona -O -fomit-frame-pointer ref
g++ -march=barcelona -Os -fomit-frame-pointer ref
g++ -march=k8 -O2 -fomit-frame-pointer ref
g++ -march=k8 -O3 -fomit-frame-pointer ref
g++ -march=k8 -O -fomit-frame-pointer ref
g++ -march=k8 -Os -fomit-frame-pointer ref
g++ -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -O -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv ref
g++ -march=nocona -O2 -fomit-frame-pointer ref
g++ -march=nocona -O3 -fomit-frame-pointer ref
g++ -march=nocona -O -fomit-frame-pointer ref
g++ -march=nocona -Os -fomit-frame-pointer ref

Compiler output

Implementation: ref
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
g++ -m64 -march=barcelona -O3 -fomit-frame-pointer ref
g++ -m64 -march=barcelona -O -fomit-frame-pointer ref
g++ -m64 -march=barcelona -Os -fomit-frame-pointer ref