Implementation notes: amd64, gpu, crypto_kem/ledakem12

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: ledakem12
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
2334711? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
2352036? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2019101020190816
2377575? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
2401449? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
2408256? ? ?? ? ?portableoptgcc_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
2413098? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101020190816
2423619? ? ?? ? ?portableoptgcc_-funroll-loops_-O2_-fomit-frame-pointer2019101020190816
2431632? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
245048156644 0 0152624 776 1624portableoptclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
2450994? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2019101020190816
2453985? ? ?? ? ?portableoptgcc_-march=k8_-O3_-fomit-frame-pointer2019101020190816
2455542? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
2458848? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2019101020190816
246707456644 0 0152624 776 1624portableoptclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
2475210? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2019101020190816
2481165? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
2483748? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
2485812? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101020190816
2488446? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101020190816
249072365429 0 0158256 776 1976portableoptclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101020190816
2493930? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
249582056644 0 0152624 776 1624portableoptclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
250218356393 0 0151072 776 1624portableoptclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019101020190816
2521053? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
2529372? ? ?? ? ?portableoptgcc_-m64_-O3_-fomit-frame-pointer2019101020190816
2532039? ? ?? ? ?portableoptgcc_-O3_-fomit-frame-pointer2019101020190816
2537688? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2019101020190816
2546067? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
2558217? ? ?? ? ?portableoptgcc_-funroll-loops_-O3_-fomit-frame-pointer2019101020190816
2603538? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
2607615? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
2617743? ? ?? ? ?portableoptgcc_-funroll-loops_-O_-fomit-frame-pointer2019101020190816
2682573? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
2690046? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2019101020190816
2691441? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
2691489? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2019101020190816
2695308? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
2695410? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
2700921? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
2703732? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
2784549? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
2834760? ? ?? ? ?portableoptgcc_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
2914827? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
2918451? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2019101020190816
2949099? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
3076188? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2019101020190816
3108525? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101020190816
3110184? ? ?? ? ?portableoptgcc_-m64_-O2_-fomit-frame-pointer2019101020190816
3132573? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
3137274? ? ?? ? ?portableoptgcc_-O2_-fomit-frame-pointer2019101020190816
3165525? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
3169281? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101020190816
3172815? ? ?? ? ?portableoptgcc_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
3180543? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
3223347? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101020190816
3230343? ? ?? ? ?portableoptgcc_-march=k8_-O2_-fomit-frame-pointer2019101020190816
3297270? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
3312870? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101020190816
3346017? ? ?? ? ?portableoptgcc_-march=k8_-O_-fomit-frame-pointer2019101020190816
3362262? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O_-fomit-frame-pointer2019101020190816
3369177? ? ?? ? ?portableoptgcc_-m64_-O_-fomit-frame-pointer2019101020190816
3372537? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101020190816
3388578? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
3389016? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2019101020190816
3393792? ? ?? ? ?portableoptgcc_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
3401526? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
3488778? ? ?? ? ?portableoptgcc_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
3500394? ? ?? ? ?portableoptgcc_-O_-fomit-frame-pointer2019101020190816
3505482? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
3695532? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
3786168? ? ?? ? ?portableoptgcc_-march=nocona_-O_-fomit-frame-pointer2019101020190816
3989661? ? ?? ? ?portableoptgcc_-Os_-fomit-frame-pointer2019101020190816
3996297? ? ?? ? ?portableoptgcc_-funroll-loops_-Os_-fomit-frame-pointer2019101020190816
4013520? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101020190816
4030479? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101020190816
4040520? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
4060371? ? ?? ? ?portableoptgcc_-m64_-Os_-fomit-frame-pointer2019101020190816
4080930? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
4081926? ? ?? ? ?portableoptgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
4103523? ? ?? ? ?portableoptgcc_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
4107279? ? ?? ? ?portableoptgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2019101020190816
4110672? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2019101020190816
4112253? ? ?? ? ?portableoptgcc_-march=k8_-Os_-fomit-frame-pointer2019101020190816
4120065? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
4120434? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
4149156? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101020190816
4153761? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
4174431? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2019101020190816
4187673? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
4188915? ? ?? ? ?portableoptgcc_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
4200678? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
4221093? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
4251183? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
8658276? ? ?? ? ?portableoptcc2019101020190816
8774334? ? ?? ? ?portableoptgcc_-funroll-loops2019101020190816
9019953? ? ?? ? ?portableoptgcc2019101020190816

Test failure

Implementation: portableopt
Security model: unknown
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
error 111
crypto_kem_dec returns nonzero

Number of similar (compiler,implementation) pairs: 19, namely:
CompilerImplementations
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments portableopt
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments portableopt
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments portableopt
gcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=core-avx-i -O -fomit-frame-pointer portableopt
gcc -m64 -march=core-avx-i -Os -fomit-frame-pointer portableopt
gcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=corei7-avx -O -fomit-frame-pointer portableopt
gcc -m64 -march=corei7-avx -Os -fomit-frame-pointer portableopt
gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer portableopt
gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer portableopt
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv portableopt
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv portableopt
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv portableopt
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv portableopt

Test failure

Implementation: portableopt
Security model: unknown
Compiler: gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

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

Compiler output

Implementation: portableopt
Security model: unknown
Compiler: cc
measure.c: /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.c: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 87, namely:
CompilerImplementations
cc portableopt
gcc portableopt
gcc -O2 -fomit-frame-pointer portableopt
gcc -O3 -fomit-frame-pointer portableopt
gcc -O -fomit-frame-pointer portableopt
gcc -Os -fomit-frame-pointer portableopt
gcc -fno-schedule-insns -O2 -fomit-frame-pointer portableopt
gcc -fno-schedule-insns -O3 -fomit-frame-pointer portableopt
gcc -fno-schedule-insns -O -fomit-frame-pointer portableopt
gcc -fno-schedule-insns -Os -fomit-frame-pointer portableopt
gcc -funroll-loops portableopt
gcc -funroll-loops -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -O -fomit-frame-pointer portableopt
gcc -funroll-loops -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer portableopt
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -O -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer portableopt
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer portableopt
gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer portableopt
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer portableopt
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer portableopt
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer portableopt
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer portableopt
gcc -m64 -O2 -fomit-frame-pointer portableopt
gcc -m64 -O3 -fomit-frame-pointer portableopt
gcc -m64 -O -fomit-frame-pointer portableopt
gcc -m64 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -O -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer portableopt
gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=corei7 -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=corei7 -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=corei7 -O -fomit-frame-pointer portableopt
gcc -m64 -march=corei7 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=k8 -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=k8 -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=k8 -O -fomit-frame-pointer portableopt
gcc -m64 -march=k8 -Os -fomit-frame-pointer portableopt
gcc -m64 -march=nocona -O2 -fomit-frame-pointer portableopt
gcc -m64 -march=nocona -O3 -fomit-frame-pointer portableopt
gcc -m64 -march=nocona -O -fomit-frame-pointer portableopt
gcc -m64 -march=nocona -Os -fomit-frame-pointer portableopt
gcc -march=barcelona -O2 -fomit-frame-pointer portableopt
gcc -march=barcelona -O3 -fomit-frame-pointer portableopt
gcc -march=barcelona -O -fomit-frame-pointer portableopt
gcc -march=barcelona -Os -fomit-frame-pointer portableopt
gcc -march=k8 -O2 -fomit-frame-pointer portableopt
gcc -march=k8 -O3 -fomit-frame-pointer portableopt
gcc -march=k8 -O -fomit-frame-pointer portableopt
gcc -march=k8 -Os -fomit-frame-pointer portableopt
gcc -march=nocona -O2 -fomit-frame-pointer portableopt
gcc -march=nocona -O3 -fomit-frame-pointer portableopt
gcc -march=nocona -O -fomit-frame-pointer portableopt
gcc -march=nocona -Os -fomit-frame-pointer portableopt

Compiler output

Implementation: portableopt
Security model: unknown
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
measure.c: /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.c: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.c: collect2: error: ld returned 1 exit status
measure.c: /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.c: /usr/bin/ld: final link failed: Nonrepresentable section on output
measure.c: collect2: error: ld returned 1 exit status

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