Implementation notes: amd64, nmiv003, crypto_dh

Computer: nmiv003
Architecture: amd64
CPU ID: GenuineIntel-000006f8-0febfbff
CPU cycles/second: 2394063000...2394081000 (amd64cpuinfo)
SUPERCOP version: 20100926
Benchmark dates: 20100729...20100928

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
55891621.00clauscrypto_dh/claus/gmpg++ -m64 -march=k8 -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
66117511.18clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
306831605.49clauscrypto_dh/claus/opensslcc
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
17810461.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
7687261.00curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
10078741.31curve25519crypto_dh/curve25519/refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
7202431.00ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
7205311.00ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -O2 -fomit-frame-pointer
7228351.00ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=nocona -O2 -fomit-frame-pointer
7235731.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer
7237891.00ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8809921.00ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
8847721.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
8860951.01ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -funroll-loops -m64 -Os -fomit-frame-pointer
8925481.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
8951041.02ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
7469731.00ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -march=nocona -Os -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
7484041.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -march=nocona -Os -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
7497991.00ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer
7511131.01ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer
7520581.01ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer
7315561.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
7385311.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
7415011.01ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=nocona -Os -fomit-frame-pointer
7420681.01ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
7431481.02ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9076231.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
9144721.01ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=k8 -O2 -fomit-frame-pointer
9238231.02ecfp256scrypto_dh/ecfp256s/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
9272071.02ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9344071.03ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer
6635341.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
21822391.00hectorcrypto_dh/hector/refgcc -funroll-loops -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
9070201.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=k8 -O -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
12104731.33sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=nocona -O3 -fomit-frame-pointer
45627661.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O2 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
58067281.27sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=k8 -O2 -fomit-frame-pointer
8503741.00surf127epscrypto_dh/surf127eps/mpfqgcc -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
13770451.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
9831511.00curve25519crypto_scalarmult/curve25519/donna_c64gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.3.0 20080428 (Red Hat 4.3.0-8))
10037161.02curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -O3 -fomit-frame-pointer
9064570592.20curve25519crypto_scalarmult/curve25519/refcc
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer