Implementation notes: amd64, gpu, crypto_kem/lake3

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: lake3
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
571096829071 48 811608279 3640 7064refclang++_-O3_-fomit-frame-pointer_-Qunused-arguments2019101020190816
575589629198 48 811607327 3640 7320refclang++_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2019101020190816
8245221? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
8338728? ? ?? ? ?refg++_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
8383413? ? ?? ? ?refg++_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
8407164? ? ?? ? ?refg++_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
8500560? ? ?? ? ?refg++_-m64_-O3_-fomit-frame-pointer2019101020190816
8503395? ? ?? ? ?refg++_-m64_-march=core2_-O2_-fomit-frame-pointer2019101020190816
8525220? ? ?? ? ?refg++_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2019101020190816
8536032? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2019101020190816
9079242? ? ?? ? ?refg++_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
9079944? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2019101020190816
9099465? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
9102954? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
9104103? ? ?? ? ?refg++_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
9112680? ? ?? ? ?refg++_-O3_-fomit-frame-pointer2019101020190816
9112884? ? ?? ? ?refg++_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
9118860? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101020190816
9127482? ? ?? ? ?refg++_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
913369829130 48 811609631 3640 7064refclang++_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
9141162? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2019101020190816
9148692? ? ?? ? ?refg++_-m64_-march=core2_-O3_-fomit-frame-pointer2019101020190816
915665129150 48 811606623 3640 7320refclang++_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019101020190816
9158376? ? ?? ? ?refg++_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2019101020190816
9159162? ? ?? ? ?refg++_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
9175524? ? ?? ? ?refg++_-O_-fomit-frame-pointer2019101020190816
9180927? ? ?? ? ?refg++_-m64_-march=core2_-O_-fomit-frame-pointer2019101020190816
9188823? ? ?? ? ?refg++_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
9189516? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2019101020190816
918960029130 48 811609631 3640 7064refclang++_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
9214170? ? ?? ? ?refg++_-march=k8_-O_-fomit-frame-pointer2019101020190816
9253215? ? ?? ? ?refg++_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101020190816
9296331? ? ?? ? ?refg++_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
9302373? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101020190816
9318378? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2019101020190816
9332643? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101020190816
9339147? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2019101020190816
934358729198 48 811607327 3640 7320refclang++_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
9347820? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101020190816
9358227? ? ?? ? ?refg++_-m64_-march=corei7_-O_-fomit-frame-pointer2019101020190816
9368340? ? ?? ? ?refg++_-m64_-O_-fomit-frame-pointer2019101020190816
9371274? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2019101020190816
9376761? ? ?? ? ?refg++_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
9382176? ? ?? ? ?refg++_-m64_-O2_-fomit-frame-pointer2019101020190816
9397710? ? ?? ? ?refg++_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101020190816
9408501? ? ?? ? ?refg++_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
9424710? ? ?? ? ?refg++_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
9430038? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101020190816
9440070? ? ?? ? ?refg++_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2019101020190816
9473307? ? ?? ? ?refg++_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
9490389? ? ?? ? ?refg++_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2019101020190816
9497193? ? ?? ? ?refg++_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
949968929150 48 811606623 3640 7320refclang++_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101020190816
9502332? ? ?? ? ?refg++_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
9516678? ? ?? ? ?refg++_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2019101020190816
9528483? ? ?? ? ?refg++_-march=k8_-Os_-fomit-frame-pointer2019101020190816
954431129130 48 811609631 3640 7064refclang++_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
9546966? ? ?? ? ?refg++_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
9575409? ? ?? ? ?refg++_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101020190816
9576159? ? ?? ? ?refg++_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2019101020190816
9580770? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101020190816
9582456? ? ?? ? ?refg++_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2019101020190816
9586542? ? ?? ? ?refg++_-march=nocona_-O_-fomit-frame-pointer2019101020190816
9590979? ? ?? ? ?refg++_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2019101020190816
9594501? ? ?? ? ?refg++_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
9607005? ? ?? ? ?refg++_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
9611373? ? ?? ? ?refg++_-m64_-march=core2_-Os_-fomit-frame-pointer2019101020190816
9622461? ? ?? ? ?refg++_-Os_-fomit-frame-pointer2019101020190816
9622512? ? ?? ? ?refg++_-march=k8_-O3_-fomit-frame-pointer2019101020190816
9623034? ? ?? ? ?refg++_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
9623205? ? ?? ? ?refg++_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101020190816
9623382? ? ?? ? ?refg++_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
9628848? ? ?? ? ?refg++_-march=k8_-O2_-fomit-frame-pointer2019101020190816
9630165? ? ?? ? ?refg++_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
9634032? ? ?? ? ?refg++_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101020190816
9637614? ? ?? ? ?refg++_-m64_-Os_-fomit-frame-pointer2019101020190816
9644538? ? ?? ? ?refg++_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
9675582? ? ?? ? ?refg++_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
9684078? ? ?? ? ?refg++_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2019101020190816
9692718? ? ?? ? ?refg++_-O2_-fomit-frame-pointer2019101020190816
10927503? ? ?? ? ?refg++2019101020190816

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
hash.c: clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated [-Wdeprecated]
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