Implementation notes: amd64, dragon, crypto_dh

Computer: dragon
Architecture: amd64
CPU ID: GenuineIntel-000106a5-bfebfbff
CPU cycles/second: 2000000000...2000000000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20100713...20120311

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
101737161.00clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
106218321.04clauscrypto_dh/claus/cryptoppg++ -m64 -march=k8 -O2 -fomit-frame-pointer
177849281.75clauscrypto_dh/claus/opensslgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
12809481.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
34521202.69curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -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
9413761.00curve25519crypto_dh/curve25519/refgcc -m64 -march=core2 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
14720081.56curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7503601.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7532881.00ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
7694881.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8006761.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
12359521.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
9034401.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
9042401.00ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -O2 -fomit-frame-pointer
9210561.02ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9585001.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
15208561.68ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
8052561.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=core2 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8128961.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -O2 -fomit-frame-pointer
8215561.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8463001.05ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -fno-schedule-insns -O3 -fomit-frame-pointer
12965481.61ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -O2 -fomit-frame-pointer
7891601.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7973281.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8128481.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8375201.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
12782081.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
9552121.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
9610201.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
9803441.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
10126641.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
16216321.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8162561.00gls1271crypto_dh/gls1271/ref4gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
29192121.00hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
17144601.00sclaus1024crypto_dh/sclaus1024/gmpg++ -march=nocona -O -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
18909281.10sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=k8 -O2 -fomit-frame-pointer
83154281.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=native -mtune=native -O -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
93203961.12sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=k8 -O2 -fomit-frame-pointer
15519481.00surf127epscrypto_dh/surf127eps/mpfqgcc -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
26448201.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
4571121.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
5332961.17curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -march=k8 -O2 -fomit-frame-pointer
5670041.24curve25519crypto_scalarmult/curve25519/donna_c64gcc -O3 -fomit-frame-pointer
8377441.83curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
9767162.14curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
1925842842.13curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer