Implementation notes: amd64, gpu, crypto_kem/ledakem52

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: ledakem52
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
10880952? ? ?? ? ?portableoptgcc_-funroll-loops_-O2_-fomit-frame-pointer2019101020190816
10909005? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2019101020190816
10974999? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2019101020190816
11017149? ? ?? ? ?portableoptgcc_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
11026677? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
11059182? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2019101020190816
11129469? ? ?? ? ?portableoptgcc_-m64_-O3_-fomit-frame-pointer2019101020190816
11161377? ? ?? ? ?portableoptgcc_-funroll-loops_-O3_-fomit-frame-pointer2019101020190816
1116286558026 0 0154632 776 1624portableoptclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
11163024? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
11176095? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
11193078? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
11226834? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
11231121? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2019101020190816
1131146454876 0 0148392 776 1976portableoptclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101020190816
11367453? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
11380062? ? ?? ? ?portableoptgcc_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
11390427? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
11408967? ? ?? ? ?portableoptgcc_-march=k8_-O3_-fomit-frame-pointer2019101020190816
11462481? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
11484174? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
11506059? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2019101020190816
11534256? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
11546088? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101020190816
11551104? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
11557896? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
11562540? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101020190816
11565363? ? ?? ? ?portableoptgcc_-O3_-fomit-frame-pointer2019101020190816
11620476? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
11642871? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
11725233? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
11766405? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2019101020190816
11771619? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101020190816
1180151458026 0 0154632 776 1624portableoptclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
1181390157686 0 0152960 776 1624portableoptclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019101020190816
11868519? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
11922357? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
11974497? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2019101020190816
11986398? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
12050022? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
12260397? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
1242170458026 0 0154632 776 1624portableoptclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
12492018? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
12503559? ? ?? ? ?portableoptgcc_-funroll-loops_-O_-fomit-frame-pointer2019101020190816
12705819? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2019101020190816
14304357? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101020190816
14402085? ? ?? ? ?portableoptgcc_-O_-fomit-frame-pointer2019101020190816
14444484? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
14445174? ? ?? ? ?portableoptgcc_-O2_-fomit-frame-pointer2019101020190816
14518170? ? ?? ? ?portableoptgcc_-m64_-O2_-fomit-frame-pointer2019101020190816
14632992? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
14685363? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101020190816
14722392? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
14723997? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2019101020190816
14750313? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101020190816
14777502? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2019101020190816
14822133? ? ?? ? ?portableoptgcc_-m64_-O_-fomit-frame-pointer2019101020190816
14879763? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
14894724? ? ?? ? ?portableoptgcc_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
14921589? ? ?? ? ?portableoptgcc_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
14994555? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
15095106? ? ?? ? ?portableoptgcc_-march=k8_-O2_-fomit-frame-pointer2019101020190816
15157275? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
15171168? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101020190816
15179715? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
15281859? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101020190816
15322050? ? ?? ? ?portableoptgcc_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
15396969? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O_-fomit-frame-pointer2019101020190816
15443511? ? ?? ? ?portableoptgcc_-march=k8_-O_-fomit-frame-pointer2019101020190816
16529832? ? ?? ? ?portableoptgcc_-march=nocona_-O_-fomit-frame-pointer2019101020190816
16752396? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
17041437? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101020190816
17444400? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101020190816
17506908? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
17535174? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
17552763? ? ?? ? ?portableoptgcc_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
17557134? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
17569677? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
17607120? ? ?? ? ?portableoptgcc_-Os_-fomit-frame-pointer2019101020190816
17626860? ? ?? ? ?portableoptgcc_-m64_-Os_-fomit-frame-pointer2019101020190816
17637699? ? ?? ? ?portableoptgcc_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
17652648? ? ?? ? ?portableoptgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2019101020190816
17777913? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101020190816
17963568? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
18000864? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
18033687? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
18049683? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2019101020190816
18056655? ? ?? ? ?portableoptgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
18079131? ? ?? ? ?portableoptgcc_-march=k8_-Os_-fomit-frame-pointer2019101020190816
18088944? ? ?? ? ?portableoptgcc_-funroll-loops_-Os_-fomit-frame-pointer2019101020190816
18160935? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
18258210? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2019101020190816
18309312? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
39972207? ? ?? ? ?portableoptgcc_-funroll-loops2019101020190816
40958823? ? ?? ? ?portableoptcc2019101020190816
41153514? ? ?? ? ?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