Implementation notes: x86, gcc47, crypto_dh

Computer: gcc47
Architecture: x86
CPU ID: GenuineIntel-000106ca-bfebfbff
CPU cycles/second: 1666674999...1666868999 (x86cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20110426...20120311

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
422879501.00clauscrypto_dh/claus/cryptoppg++ -m32 -march=pentium-m -O -fomit-frame-pointer (4.4.5)
1467488903.47clauscrypto_dh/claus/gmpg++ -m32 -march=i386 -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m32 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m32 -O3 -fomit-frame-pointer
161617301.00curve2251crypto_dh/curve2251/mpfqgcc -m32 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
99789901.00curve25519crypto_dh/curve25519/refgcc -m32 -march=athlon -O -fomit-frame-pointer (4.4.5)
138280701.39curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -m32 -march=pentium3 -O2 -fomit-frame-pointer
ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m32 -O3 -fomit-frame-pointer
ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m32 -O3 -fomit-frame-pointer
ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m32 -O3 -fomit-frame-pointer
ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m32 -O3 -fomit-frame-pointer
ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m32 -O3 -fomit-frame-pointer
ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m32 -O3 -fomit-frame-pointer
ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m32 -O3 -fomit-frame-pointer
ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m32 -O3 -fomit-frame-pointer
ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m32 -O3 -fomit-frame-pointer
ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m32 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/vargcc -m32 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m32 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m32 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m32 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m32 -O3 -fomit-frame-pointer
ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m32 -O3 -fomit-frame-pointer
ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m32 -O3 -fomit-frame-pointer
ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m32 -O3 -fomit-frame-pointer
ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m32 -O3 -fomit-frame-pointer
ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m32 -O3 -fomit-frame-pointer
ecfp256scrypto_dh/ecfp256s/v01/vargcc -m32 -O3 -fomit-frame-pointer
ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m32 -O3 -fomit-frame-pointer
ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m32 -O3 -fomit-frame-pointer
ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m32 -O3 -fomit-frame-pointer
ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m32 -O3 -fomit-frame-pointer
gls1271crypto_dh/gls1271/ref4gcc -m32 -O3 -fomit-frame-pointer
104423401.00hectorcrypto_dh/hector/refgcc -funroll-loops -m32 -march=pentium4 -O3 -fomit-frame-pointer (4.4.5)
nistp256crypto_dh/nistp256/nawazgcc -m32 -O3 -fomit-frame-pointer
75876701.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m32 -march=nocona -O2 -fomit-frame-pointer (4.4.5)
238220803.14sclaus1024crypto_dh/sclaus1024/gmpg++ -m32 -march=i386 -Os -fomit-frame-pointer
374432001.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m32 -march=pentium-m -O3 -fomit-frame-pointer (4.4.5)
1231195603.29sclaus2048crypto_dh/sclaus2048/gmpg++ -m32 -march=i386 -Os -fomit-frame-pointer
144131601.00surf127epscrypto_dh/surf127eps/mpfqgcc -m32 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.5)
128657301.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m32 -march=k8 -O3 -fomit-frame-pointer (4.4.5)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
49766501.00curve25519crypto_scalarmult/curve25519/athlongcc -funroll-loops -m32 -march=athlon -O3 -fomit-frame-pointer (4.4.5)
133269002.68curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m32 -march=k6-2 -O3 -fomit-frame-pointer
5429882010.91curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m32 -march=barcelona -O2 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/amd64-51gcc -m32 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/amd64-64gcc -m32 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m32 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/donnagcc -m32 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/donna_c64gcc -m32 -O3 -fomit-frame-pointer