Implementation notes: amd64, phenom, crypto_dh

Computer: phenom
Architecture: amd64
CPU ID: AuthenticAMD-00100fa0-178bfbff
CPU cycles/second: 2800000000...2800000000 (amd64cpuinfo)
SUPERCOP version: 20120812
Benchmark dates: 20101112...20120814

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
57438681.00clauscrypto_dh/claus/gmpg++ -O2 -fomit-frame-pointer (4.6.3)
75132171.31clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -O -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
37755581.00curve2251crypto_dh/curve2251/mpfqgcc -m64 -march=core2 -O -fomit-frame-pointer (4.6.3)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer
7390421.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
10014071.36curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -O3 -fomit-frame-pointer
5985171.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
6026731.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
6120731.02ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
6409921.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
9510791.59ecfp256ecrypto_dh/ecfp256e/v01/vargcc -funroll-loops -O3 -fomit-frame-pointer
7482911.00ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3)
7506571.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
7608841.02ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
7890681.05ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -O3 -fomit-frame-pointer
12203341.63ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -O3 -fomit-frame-pointer
6433031.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
6438771.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
6495581.01ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=nocona -O3 -fomit-frame-pointer
6701781.04ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -O3 -fomit-frame-pointer
9931741.54ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer
6213971.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
6264691.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
6356181.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer
6594271.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
9788181.58ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=nocona -O3 -fomit-frame-pointer
7136541.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
7196471.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer
7305831.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
7599941.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
11663741.63ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -O3 -fomit-frame-pointer
6464721.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
35956561.00hectorcrypto_dh/hector/refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (4.6.3)
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
9637691.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer (4.6.3)
13411731.39sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -O3 -fomit-frame-pointer
45078621.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -Os -fomit-frame-pointer (4.6.3)
62625921.39sclaus2048crypto_dh/sclaus2048/cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
10443581.00surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3)
29761231.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=nocona -O -fomit-frame-pointer (4.6.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
3617131.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -march=nocona -O -fomit-frame-pointer (4.6.3)
4862531.34curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
5376281.49curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
7154621.98curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
11514813.18curve25519crypto_scalarmult/curve25519/ref10gcc -march=k8 -O2 -fomit-frame-pointer
2281550063.08curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer