Implementation notes: amd64, ranger, crypto_dh

Computer: ranger
Architecture: amd64
CPU ID: AuthenticAMD-00100f23-178bfbff
CPU cycles/second: 2200000000...2200000000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20100611...20120312

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
66525981.00clauscrypto_dh/claus/gmpg++ -m64 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
88200561.33clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
154092962.32clauscrypto_dh/claus/opensslgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
40744691.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
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
8685151.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
12015691.38curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
6849501.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
6875371.00ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
6993841.02ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -O2 -fomit-frame-pointer
7238551.06ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
10607011.55ecfp256ecrypto_dh/ecfp256e/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
8362241.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8414551.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
8554951.02ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=k8 -O2 -fomit-frame-pointer
8849801.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -O2 -fomit-frame-pointer
13591031.63ecfp256hcrypto_dh/ecfp256h/v01/vargcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7383191.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7387511.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -march=barcelona -O2 -fomit-frame-pointer
7466761.01ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7669111.04ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -O2 -fomit-frame-pointer
11229501.52ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
7112141.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7120801.00ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
7234741.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -fno-schedule-insns -O2 -fomit-frame-pointer
7474041.05ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
10921551.54ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8202181.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8241141.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
8358531.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
8631871.05ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
13263521.62ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
7924401.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
34416001.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
11338881.00sclaus1024crypto_dh/sclaus1024/gmpg++ -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
15792881.39sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
52414341.00sclaus2048crypto_dh/sclaus2048/gmpg++ -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
74296661.42sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=nocona -O -fomit-frame-pointer
12150181.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
33076541.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
4255921.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
5680401.33curve25519crypto_scalarmult/curve25519/donna_c64gcc -fno-schedule-insns -O3 -fomit-frame-pointer
6341041.49curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer
8403521.97curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
13558723.19curve25519crypto_scalarmult/curve25519/ref10gcc -O3 -fomit-frame-pointer
2415340356.75curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer