Implementation notes: amd64, gpu, crypto_kem/ledakem54

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: ledakem54
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
11878599? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
11927169? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
11996763? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101020190816
12035274? ? ?? ? ?portableoptgcc_-funroll-loops_-O3_-fomit-frame-pointer2019101020190816
12068694? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2019101020190816
12073167? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
1208621759372 0 0152904 776 1976portableoptclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101020190816
12091275? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101020190816
12115440? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
12130104? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2019101020190816
12154482? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2019101020190816
12157905? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2019101020190816
12175338? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
12211836? ? ?? ? ?portableoptgcc_-funroll-loops_-O2_-fomit-frame-pointer2019101020190816
12223818? ? ?? ? ?portableoptgcc_-march=barcelona_-O3_-fomit-frame-pointer2019101020190816
12415572? ? ?? ? ?portableoptgcc_-m64_-O3_-fomit-frame-pointer2019101020190816
12463431? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101020190816
12472692? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2019101020190816
12615522? ? ?? ? ?portableoptgcc_-march=k8_-O3_-fomit-frame-pointer2019101020190816
12666204? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2019101020190816
1273117560154 0 0156712 776 1624portableoptclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
12735036? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
12774894? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
12780861? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
1283031359816 0 0155040 776 1624portableoptclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019101020190816
12903108? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101020190816
12970920? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
13199613? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
1323504960154 0 0156712 776 1624portableoptclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
1325696160154 0 0156712 776 1624portableoptclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101020190816
13262931? ? ?? ? ?portableoptgcc_-O3_-fomit-frame-pointer2019101020190816
13341144? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2019101020190816
13437795? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
13461987? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
13595997? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
13630065? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
13679268? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
13735761? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2019101020190816
13822617? ? ?? ? ?portableoptgcc_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
13942743? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
14264388? ? ?? ? ?portableoptgcc_-funroll-loops_-O_-fomit-frame-pointer2019101020190816
14265630? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
14589603? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
14629788? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101020190816
14716734? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2019101020190816
15613662? ? ?? ? ?portableoptgcc_-O2_-fomit-frame-pointer2019101020190816
15700851? ? ?? ? ?portableoptgcc_-m64_-O2_-fomit-frame-pointer2019101020190816
15703212? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101020190816
16007721? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2019101020190816
16017411? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101020190816
16033665? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101020190816
16318332? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101020190816
16350384? ? ?? ? ?portableoptgcc_-march=k8_-O2_-fomit-frame-pointer2019101020190816
16382889? ? ?? ? ?portableoptgcc_-O_-fomit-frame-pointer2019101020190816
16431981? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2019101020190816
16558413? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
16613097? ? ?? ? ?portableoptgcc_-m64_-O_-fomit-frame-pointer2019101020190816
16792737? ? ?? ? ?portableoptgcc_-march=barcelona_-O2_-fomit-frame-pointer2019101020190816
17063991? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019101020190816
17210952? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O_-fomit-frame-pointer2019101020190816
17385615? ? ?? ? ?portableoptgcc_-march=k8_-O_-fomit-frame-pointer2019101020190816
17420178? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
17595888? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2019101020190816
17609613? ? ?? ? ?portableoptgcc_-march=barcelona_-O_-fomit-frame-pointer2019101020190816
17765904? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101020190816
17914896? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101020190816
18122061? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O_-fomit-frame-pointer2019101020190816
18398127? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
18702939? ? ?? ? ?portableoptgcc_-march=nocona_-O2_-fomit-frame-pointer2019101020190816
18994344? ? ?? ? ?portableoptgcc_-march=nocona_-O_-fomit-frame-pointer2019101020190816
19356402? ? ?? ? ?portableoptgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2019101020190816
19523910? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2019101020190816
19578960? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101020190816
19829694? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
19933044? ? ?? ? ?portableoptgcc_-march=k8_-Os_-fomit-frame-pointer2019101020190816
20003355? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101020190816
20025099? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101020190816
20026611? ? ?? ? ?portableoptgcc_-m64_-Os_-fomit-frame-pointer2019101020190816
20059002? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
20130783? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
20151402? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
20157057? ? ?? ? ?portableoptgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
20245089? ? ?? ? ?portableoptgcc_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
20249148? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
20364909? ? ?? ? ?portableoptgcc_-Os_-fomit-frame-pointer2019101020190816
20393613? ? ?? ? ?portableoptgcc_-funroll-loops_-Os_-fomit-frame-pointer2019101020190816
20429553? ? ?? ? ?portableoptgcc_-march=nocona_-Os_-fomit-frame-pointer2019101020190816
20515788? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2019101020190816
20744628? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101020190816
20759730? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
21036264? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101020190816
21112809? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2019101020190816
21240087? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2019101020190816
44362536? ? ?? ? ?portableoptgcc_-funroll-loops2019101020190816
44983875? ? ?? ? ?portableoptgcc2019101020190816
45880824? ? ?? ? ?portableoptcc2019101020190816

Test failure

Implementation: portableopt
Security model: unknown
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
error 111
crypto_kem_dec does not match k

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