Implementation notes: amd64, gpu, crypto_encrypt/ledapkc50

Computer: gpu
Architecture: amd64
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_encrypt
Primitive: ledapkc50
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
6257323568924 8 0165531 808 1648portableoptclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101320190816
65019471? ? ?? ? ?portableoptgcc_-m64_-O_-fomit-frame-pointer2019101320190816
90008721? ? ?? ? ?portableoptgcc_-funroll-loops_-O2_-fomit-frame-pointer2019101320190816
91715826? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2019101320190816
92168433? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2019101320190816
92783706? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2019101320190816
92927877? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101320190816
93939417? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2019101320190816
94554609? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101320190816
94969545? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2019101320190816
95141370? ? ?? ? ?portableoptgcc_-march=barcelona_-O2_-fomit-frame-pointer2019101320190816
96045918? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2019101320190816
96707937? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101320190816
9695370368924 8 0165531 808 1648portableoptclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101320190816
96962523? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019101320190816
97074879? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2019101320190816
97109634? ? ?? ? ?portableoptgcc_-O2_-fomit-frame-pointer2019101320190816
9746115368748 8 0162203 808 2000portableoptclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019101320190816
97462524? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019101320190816
98346327? ? ?? ? ?portableoptgcc_-march=nocona_-O2_-fomit-frame-pointer2019101320190816
98462007? ? ?? ? ?portableoptgcc_-m64_-O2_-fomit-frame-pointer2019101320190816
98636529? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2019101320190816
98691519? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2019101320190816
99087546? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2019101320190816
9966691568725 8 0163987 808 1648portableoptclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019101320190816
100782018? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019101320190816
100826259? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019101320190816
100934607? ? ?? ? ?portableoptgcc_-m64_-O3_-fomit-frame-pointer2019101320190816
101172459? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101320190816
101335806? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2019101320190816
101350800? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O_-fomit-frame-pointer2019101320190816
101484078? ? ?? ? ?portableoptgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2019101320190816
101701557? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2019101320190816
101761503? ? ?? ? ?portableoptgcc_-march=k8_-O2_-fomit-frame-pointer2019101320190816
101874411? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2019101320190816
101956089? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2019101320190816
10201834268924 8 0165531 808 1648portableoptclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019101320190816
102154575? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O_-fomit-frame-pointer2019101320190816
102275286? ? ?? ? ?portableoptgcc_-march=k8_-O_-fomit-frame-pointer2019101320190816
102581976? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2019101320190816
102590205? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2019101320190816
102897201? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2019101320190816
103028040? ? ?? ? ?portableoptgcc_-march=barcelona_-O_-fomit-frame-pointer2019101320190816
103335675? ? ?? ? ?portableoptgcc_-m64_-Os_-fomit-frame-pointer2019101320190816
103504560? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019101320190816
103939410? ? ?? ? ?portableoptgcc_-O_-fomit-frame-pointer2019101320190816
104197152? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101320190816
104210967? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019101320190816
104403075? ? ?? ? ?portableoptgcc_-funroll-loops_-O3_-fomit-frame-pointer2019101320190816
104450295? ? ?? ? ?portableoptgcc_-O3_-fomit-frame-pointer2019101320190816
104474472? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2019101320190816
104741976? ? ?? ? ?portableoptgcc_-funroll-loops_-O_-fomit-frame-pointer2019101320190816
104791701? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019101320190816
105000363? ? ?? ? ?portableoptgcc_-march=barcelona_-O3_-fomit-frame-pointer2019101320190816
105086493? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2019101320190816
105529071? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2019101320190816
105961437? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101320190816
106036551? ? ?? ? ?portableoptgcc_-march=nocona_-O3_-fomit-frame-pointer2019101320190816
106164375? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2019101320190816
106320330? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2019101320190816
106484775? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2019101320190816
106548921? ? ?? ? ?portableoptgcc_-Os_-fomit-frame-pointer2019101320190816
106590771? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2019101320190816
106686879? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101320190816
106688778? ? ?? ? ?portableoptgcc_-march=nocona_-Os_-fomit-frame-pointer2019101320190816
106702557? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101320190816
106809372? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2019101320190816
106859040? ? ?? ? ?portableoptgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101320190816
106866912? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2019101320190816
106904760? ? ?? ? ?portableoptgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101320190816
107090340? ? ?? ? ?portableoptgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2019101320190816
107236626? ? ?? ? ?portableoptgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2019101320190816
107266650? ? ?? ? ?portableoptgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2019101320190816
107352453? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2019101320190816
107508564? ? ?? ? ?portableoptgcc_-march=nocona_-O_-fomit-frame-pointer2019101320190816
107708028? ? ?? ? ?portableoptgcc_-march=k8_-O3_-fomit-frame-pointer2019101320190816
107876487? ? ?? ? ?portableoptgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2019101320190816
108053562? ? ?? ? ?portableoptgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2019101320190816
108415461? ? ?? ? ?portableoptgcc_-march=barcelona_-Os_-fomit-frame-pointer2019101320190816
108510741? ? ?? ? ?portableoptgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2019101320190816
108842598? ? ?? ? ?portableoptgcc_-march=k8_-Os_-fomit-frame-pointer2019101320190816
108908661? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2019101320190816
108971262? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019101320190816
110588580? ? ?? ? ?portableoptgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2019101320190816
111318210? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2019101320190816
111548544? ? ?? ? ?portableoptgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019101320190816
111749868? ? ?? ? ?portableoptgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2019101320190816
111946896? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2019101320190816
112121019? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2019101320190816
114171900? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2019101320190816
114461871? ? ?? ? ?portableoptgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2019101320190816
114934110? ? ?? ? ?portableoptgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2019101320190816
115177407? ? ?? ? ?portableoptgcc_-funroll-loops_-Os_-fomit-frame-pointer2019101320190816
284346741? ? ?? ? ?portableoptcc2019101320190816
286128303? ? ?? ? ?portableoptgcc2019101320190816
286755606? ? ?? ? ?portableoptgcc_-funroll-loops2019101320190816

Test failure

Implementation: portableopt
Security model: unknown
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
error 111
Decode FAIL
crypto_encrypt_open 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