Implementation notes: amd64, hercules, crypto_dh

Computer: hercules
Architecture: amd64
CPU ID: GenuineIntel-000106a5-bfebfbff
CPU cycles/second: 2668000000...2668000000 (amd64cpuinfo)
SUPERCOP version: 20101029
Benchmark dates: 20101108...20101110

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
55266341.00clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.3.2)
clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/mpfqgcc -m64 -O3 -fomit-frame-pointer
7313231.00curve25519crypto_dh/curve25519/refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer (4.3.2)
curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
5683231.00ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -O3 -fomit-frame-pointer (4.3.2)
5704321.00ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -fno-schedule-insns -O3 -fomit-frame-pointer
5731041.01ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
5733381.01ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer
5739351.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6984551.00ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer (4.3.2)
7023361.01ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=nocona -O2 -fomit-frame-pointer
7088861.01ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
7091171.02ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
7091551.02ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
5972561.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.3.2)
5979441.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=core2 -Os -fomit-frame-pointer
5992561.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer
6020961.01ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -march=barcelona -O3 -fomit-frame-pointer
6034501.01ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
5868611.00ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.3.2)
5874061.00ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
5885971.00ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
5932801.01ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer
5956741.02ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
7523391.00ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.3.2)
7528651.00ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
7536651.00ecfp256scrypto_dh/ecfp256s/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
7540321.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
7553601.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
5284751.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.3.2)
hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
9974921.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=barcelona -O -fomit-frame-pointer (4.3.2)
sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer
48783811.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.3.2)
sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer
surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
7251171.00curve25519crypto_scalarmult/curve25519/donna_c64gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.3.2)
7687881.06curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=nocona -O2 -fomit-frame-pointer
1930783026.63curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer