Implementation notes: amd64, ares, crypto_dh

Computer: ares
Architecture: amd64
CPU ID: GenuineIntel-000306a9-bfebfbff
CPU cycles/second: 3392342000...3392342000 (amd64cpuinfo)
SUPERCOP version: 20130419
Benchmark dates: 20140123...20140127

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
6237281.00curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
11486321.84curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/mpfqgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
7469081.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
5526201.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
5589121.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
5692241.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -O3 -fomit-frame-pointer
5934881.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
9159161.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
6533721.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
6590041.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6705641.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
6968201.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
11039961.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
5955561.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
6008761.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
6098761.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
6305321.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
9647801.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=corei7 -O3 -fomit-frame-pointer
5839521.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
5887641.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
5990041.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
6230081.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O3 -fomit-frame-pointer
9406521.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
7025161.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
7094841.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
7216601.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -O3 -fomit-frame-pointer
7481481.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
11938641.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6971961.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
5622201.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
5624641.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -march=k8 -O3 -fomit-frame-pointer
5645721.00hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -m64 -march=nocona -O3 -fomit-frame-pointer
5700801.01hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
5824201.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
6071721.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
9929681.77hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
4298961.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -march=barcelona -O3 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
4309521.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4330441.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
4422441.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4584441.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
4928161.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
6669721.55hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
4293641.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
4299401.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -march=k8 -O2 -fomit-frame-pointer
4325361.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -march=barcelona -O3 -fomit-frame-pointer
4397641.02hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -march=k8 -O2 -fomit-frame-pointer
4574761.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -march=k8 -O2 -fomit-frame-pointer
4927561.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
6676321.55hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
8306041.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
8322761.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
8349761.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
8439881.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -march=barcelona -O2 -fomit-frame-pointer
8618081.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -march=barcelona -O2 -fomit-frame-pointer
8978241.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
14737761.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer
4614121.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
6696841.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
3647321.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.6.3 20120306 (Red Hat 4.6.3-2))
3713561.02curve25519crypto_scalarmult/curve25519/amd64-64gcc -O -fomit-frame-pointer
4093841.12curve25519crypto_scalarmult/curve25519/donna_c64gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
6120161.68curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=core2 -O3 -fomit-frame-pointer
8429202.31curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -Os -fomit-frame-pointer
1233184033.81curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer