Implementation notes: amd64, h4e350, crypto_dh

Computer: h4e350
Architecture: amd64
CPU ID: AuthenticAMD-00500f10-178bfbff
CPU cycles/second: 1600000000...1600000000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140526...20141020

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
136290001.00clauscrypto_dh/claus/opensslgcc -fno-schedule-insns -Os -fomit-frame-pointer (4.6.3)
158217031.16clauscrypto_dh/claus/cryptoppclang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer
clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
51305821.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
curve2251crypto_dh/curve2251/mpfqgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
14613151.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
10036291.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
10150621.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
10320241.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
10770691.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -fno-schedule-insns -O3 -fomit-frame-pointer
16268491.62ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -O3 -fomit-frame-pointer
12374311.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
12491251.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
12691981.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
13174171.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
20564911.66ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
17105131.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer
10535611.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
10643731.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
10808581.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -O3 -fomit-frame-pointer
11231251.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
16677271.58ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
12317131.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
12434671.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
12621571.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
13046131.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
20420971.66ecfp256scrypto_dh/ecfp256s/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
42763171.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
47941051.12ed448goldilockscrypto_dh/ed448goldilocks/64gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
112622372.63ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
130791213.06ed448goldilockscrypto_dh/ed448goldilocks/32clang -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
10523941.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.6.3)
gls254crypto_dh/gls254/protgcc -m64 -O3 -fomit-frame-pointer
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
gls254protcrypto_dh/gls254prot/protgcc -m64 -O3 -fomit-frame-pointer
9917731.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
9927391.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9964591.00hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -fno-schedule-insns -O3 -fomit-frame-pointer
10073071.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
10288201.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
10729711.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
17489071.76hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
7874521.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer (4.6.3)
7888711.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -O3 -fomit-frame-pointer
7939291.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
8096311.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
8405281.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
9030181.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
12255091.56hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -march=k8 -O2 -fomit-frame-pointer
7836001.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3)
7866841.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
7930681.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
8074021.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8371621.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9002461.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
12206611.56hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3)
14886901.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3)
14914801.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
14977891.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
15132391.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
15455731.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -O2 -fomit-frame-pointer
16095211.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
26349691.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -funroll-loops -O2 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer
7981861.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
12802801.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -march=barcelona -O -fomit-frame-pointer (4.6.3)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
29544721.00kummercrypto_dh/kummer/refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
52956811.00nistp256crypto_dh/nistp256/refgcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
62597941.18nistp256crypto_dh/nistp256/wblclang -O3 -fomit-frame-pointer
28183891.00sclaus1024crypto_dh/sclaus1024/cryptoppclang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer
134430361.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ (4.6.3)
sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer
surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
14597521.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -march=k8 -O -fomit-frame-pointer
17744161.22curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
21402091.47curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -O3 -fomit-frame-pointer
27458941.88curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=nocona -O3 -fomit-frame-pointer
50571663.46curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -Os -fomit-frame-pointer
4229304028.97curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
29522701.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
30453031.03kummercrypto_scalarmult/kummer/ref5ugcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avxgcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2intgcc -m64 -O3 -fomit-frame-pointer
53073451.00nistp256crypto_scalarmult/nistp256/mj32gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3)