Implementation notes: amd64, jos, crypto_dh

Computer: jos
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2493332000...2493332000 (amd64cpuinfo)
SUPERCOP version: 20120414
Benchmark dates: 20111123...20120416

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
106960121.00clauscrypto_dh/claus/gmpg++ -march=nocona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
111338621.04clauscrypto_dh/claus/cryptoppg++ -march=k8 -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
13100021.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
34739622.65curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -O2 -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
12287701.00curve25519crypto_dh/curve25519/refgcc -m64 -O -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
16163621.32curve25519crypto_dh/curve25519/mpfqgcc -march=nocona -O3 -fomit-frame-pointer
8614651.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
8698571.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8859901.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
9248851.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
14351551.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
10502931.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
10570571.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
10771201.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
11186851.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
17899121.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -O3 -fomit-frame-pointer
9278771.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
9338181.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -O3 -fomit-frame-pointer
9446471.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
9792601.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
15071401.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
9121951.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
9156081.00ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9326321.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9732971.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O3 -fomit-frame-pointer
14818201.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -O3 -fomit-frame-pointer
10822121.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
10917001.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
11091981.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer
11501931.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
18462971.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
9049951.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
28706331.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
18204601.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
19831131.09sclaus1024crypto_dh/sclaus1024/cryptoppg++ -O3 -fomit-frame-pointer
87382801.00sclaus2048crypto_dh/sclaus2048/gmpg++ -fno-schedule-insns -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
97605821.12sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -Os -fomit-frame-pointer
17156401.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
26697451.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6020481.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
6127871.02curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
6649501.10curve25519crypto_scalarmult/curve25519/amd64-51gcc -march=k8 -O2 -fomit-frame-pointer
9894751.64curve25519crypto_scalarmult/curve25519/donnagcc -fno-schedule-insns -O3 -fomit-frame-pointer
13054202.17curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -O3 -fomit-frame-pointer
1971792032.75curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer