Implementation notes: x86, fireball, crypto_dh

Computer: fireball
Architecture: x86
CPU ID: GenuineIntel-00000f12-3febfbff
CPU cycles/second: 1894275000...1894305000 (x86cpuinfo)
SUPERCOP version: 20130419
Benchmark dates: 20100610...20130422

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
462153521.00clauscrypto_dh/claus/cryptoppg++ -m32 -march=pentium3 -Os -fomit-frame-pointer (4.6.3)
463711241.00clauscrypto_dh/claus/gmpg++ -march=pentiumpro -O -fomit-frame-pointer
672936801.46clauscrypto_dh/claus/opensslgcc -march=barcelona -O -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m32 -O3 -fomit-frame-pointer
132573161.00curve2251crypto_dh/curve2251/mpfqclang -O3 (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
36494681.00curve25519crypto_dh/curve25519/refclang -O3 (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
112557803.08curve25519crypto_dh/curve25519/mpfqgcc -march=pentium-mmx -O3 -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
gls254crypto_dh/gls254/refgcc -m32 -O3 -fomit-frame-pointer
112213441.00hectorcrypto_dh/hector/refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer (4.6.3)
nistp256crypto_dh/nistp256/nawazgcc -m32 -O3 -fomit-frame-pointer
79061721.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m32 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
82389801.04sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m32 -march=i486 -O2 -fomit-frame-pointer
386010201.00sclaus2048crypto_dh/sclaus2048/gmpg++ -march=k6-2 -O2 -fomit-frame-pointer (4.6.3)
400946241.04sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=athlon -O2 -fomit-frame-pointer
131027561.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=pentium -O3 -fomit-frame-pointer (4.6.3)
104336401.00surf2113crypto_dh/surf2113/mpfqclang -O3 (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
17985201.00curve25519crypto_scalarmult/curve25519/athlongcc -funroll-loops -m32 -march=pentium3 -O3 -fomit-frame-pointer (4.6.3)
93674965.21curve25519crypto_scalarmult/curve25519/ref10clang -O3
3359970818.68curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=pentium4 -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
curve25519crypto_scalarmult/curve25519/neon2gcc -m32 -O3 -fomit-frame-pointer