Implementation notes: amd64, sto02, crypto_dh

Computer: sto02
Architecture: amd64
CPU ID: GenuineIntel-000106a5-bfebfbff
CPU cycles/second: 1995302000...1995302000 (amd64cpuinfo)
SUPERCOP version: 20111120
Benchmark dates: 20120113...20120117

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
102744361.00clauscrypto_dh/claus/gmpg++ -march=k8 -O2 -fomit-frame-pointer (4.4.5)
105559361.03clauscrypto_dh/claus/cryptoppg++ -march=k8 -O3 -fomit-frame-pointer
176855281.72clauscrypto_dh/claus/opensslgcc
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
12791521.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5)
34597122.70curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
11697401.00curve25519crypto_dh/curve25519/refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5)
14626001.25curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7425321.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5)
7480521.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
7619081.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7941121.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5)
12275601.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8931001.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5)
9013721.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9174481.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer
9533481.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
15157401.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
7979681.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.5)
8033281.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
8170841.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8422041.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
12953881.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
7877321.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5)
7923681.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
8054681.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -O3 -fomit-frame-pointer
8343441.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
12709041.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -O3 -fomit-frame-pointer
9487721.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5)
9553681.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
9725321.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
10098121.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
16215641.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer
8149241.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5)
28824521.00hectorcrypto_dh/hector/refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5)
17085281.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.5)
18787561.10sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=k8 -O3 -fomit-frame-pointer
84429161.00sclaus2048crypto_dh/sclaus2048/gmpg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5)
92661401.10sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -O3 -fomit-frame-pointer
15520161.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
26343921.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
5268841.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
5664481.08curve25519crypto_scalarmult/curve25519/donna_c64gcc -m64 -march=k8 -O3 -fomit-frame-pointer
6156441.17curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
9000601.71curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
1967838037.35curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer