Implementation notes: amd64, boing, crypto_dh

Computer: boing
Architecture: amd64
CPU ID: GenuineIntel-0001067a-bfebfbff
CPU cycles/second: 2999830000...3000300000 (amd64cpuinfo)
SUPERCOP version: 20120908
Benchmark dates: 20120528...20120917

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
106770691.00clauscrypto_dh/claus/gmpg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
111424411.04clauscrypto_dh/claus/cryptoppg++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
186319171.75clauscrypto_dh/claus/opensslgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
13199671.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
34772582.63curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
12516481.00curve25519crypto_dh/curve25519/refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
15673141.25curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
8514541.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
8593111.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
8772751.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer
9127171.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
14158351.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
10325251.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
10416871.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
10621801.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -fno-schedule-insns -O2 -fomit-frame-pointer
11042461.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
17609851.71ecfp256hcrypto_dh/ecfp256h/v01/vargcc -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
9208441.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
9276481.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
9424801.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -O2 -fomit-frame-pointer
9745111.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
15020461.63ecfp256icrypto_dh/ecfp256i/v01/vargcc -fno-schedule-insns -O2 -fomit-frame-pointer
8973811.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
9056881.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
9228241.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9565291.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
14573791.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
10617211.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
10712791.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
10894771.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer
11312461.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
18147151.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
9302131.00gls1271crypto_dh/gls1271/ref4gcc -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
28817731.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
17922691.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
19788301.10sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=nocona -O -fomit-frame-pointer
87088051.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=barcelona -Os -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
95104711.09sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
17111071.00surf127epscrypto_dh/surf127eps/mpfqgcc -march=nocona -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
26908381.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6140791.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -m64 -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
6141331.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -O3 -fomit-frame-pointer (4.4.5 20110214 (Red Hat 4.4.5-6))
6663961.09curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer
9909901.61curve25519crypto_scalarmult/curve25519/donnagcc -march=nocona -O3 -fomit-frame-pointer
12841562.09curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
1977418832.20curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer