Implementation notes: amd64, morningstar, crypto_dh

Computer: morningstar
Architecture: amd64
CPU ID: AuthenticAMD-00100f42-178bfbff
CPU cycles/second: 3211011000...3211117000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140426...20141014

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
63069151.00clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer (4.4.7)
86310321.37clauscrypto_dh/claus/cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
92535671.47clauscrypto_dh/claus/opensslgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer (4.4.7)
37292211.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.7)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer
8781191.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.7)
11730531.34curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
6733901.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.7)
6792511.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
6918961.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -O2 -fomit-frame-pointer
7186341.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
10528481.56ecfp256ecrypto_dh/ecfp256e/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
8274991.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
8336561.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
8493481.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
8787461.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
13489401.63ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
11153201.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.7)
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
6999071.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
7048561.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
7178311.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
7419421.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O2 -fomit-frame-pointer
10851181.55ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O2 -fomit-frame-pointer (4.4.7)
8090601.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.7)
8158561.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8283981.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8544961.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
13156611.63ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
27694621.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.7)
30539731.10ed448goldilockscrypto_dh/ed448goldilocks/64gcc -fno-schedule-insns -O3 -fomit-frame-pointer
91211223.29ed448goldilockscrypto_dh/ed448goldilocks/32gcc -m64 -march=nocona -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -m64 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
7664211.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.7)
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
6364051.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.7)
6378951.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
6407281.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
6484661.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
6620941.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
6903281.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -O2 -fomit-frame-pointer
11289741.77hecfp127icrypto_dh/hecfp127i/v02/vargcc -O3 -fomit-frame-pointer
5402461.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.7)
5425421.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.7)
5481231.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -O2 -fomit-frame-pointer
5578991.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.7)
5795011.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.7)
6228611.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
8488181.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -O3 -fomit-frame-pointer
5378751.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.7)
5389231.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
5449401.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
5557331.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
5775011.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
6190021.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
8454701.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -funroll-loops -O2 -fomit-frame-pointer
10244561.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -m64 -O3 -fomit-frame-pointer (4.4.7)
10269451.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
10323251.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
10424131.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
10656911.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
11102461.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
18161601.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=native -mtune=native -O3 -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
30681831.00hectorcrypto_dh/hector/refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.7)
5230211.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -march=k8 -O -fomit-frame-pointer (4.4.7)
9071261.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer (4.4.7)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
17046131.00kummercrypto_dh/kummer/refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.7)
46557061.00nistp256crypto_dh/nistp256/wbl (0.0.1)gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.7)
66304941.42nistp256crypto_dh/nistp256/refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
10768991.00sclaus1024crypto_dh/sclaus1024/gmpg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.7)
15491571.44sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
51461811.00sclaus2048crypto_dh/sclaus2048/gmpg++ -O3 -fomit-frame-pointer (4.4.7)
73122241.42sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
11823781.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.7)
29682961.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.4.7)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
8765721.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.7)
11365071.30curve25519crypto_scalarmult/curve25519/donna_c64gcc -O3 -fomit-frame-pointer
12645441.44curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=nocona -O -fomit-frame-pointer
16786541.92curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
26886773.07curve25519crypto_scalarmult/curve25519/ref10gcc -m64 -O3 -fomit-frame-pointer
4742453454.10curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
17030101.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.7)
18132071.06kummercrypto_scalarmult/kummer/ref5ugcc -funroll-loops -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
66400761.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.7)