Implementation notes: amd64, nmih002, crypto_dh

Computer: nmih002
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2394024000...2394082000 (amd64cpuinfo)
SUPERCOP version: 20101204
Benchmark dates: 20100829...20101205

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
52917301.00clauscrypto_dh/claus/gmpg++ -march=k8 -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
61422121.16clauscrypto_dh/claus/cryptoppg++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
118598582.24clauscrypto_dh/claus/opensslgcc -m64 -march=nocona -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
17697781.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
7728661.00curve25519crypto_dh/curve25519/mpfqgcc -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
9938881.29curve25519crypto_dh/curve25519/refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
7113871.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
7190641.01ecfp256ecrypto_dh/ecfp256e/v01/vargcc -Os -fomit-frame-pointer
7193881.01ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -funroll-loops -m64 -Os -fomit-frame-pointer
7197211.01ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
7215751.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer
8794801.00ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -march=nocona -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
8831611.00ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -O3 -fomit-frame-pointer
8843311.01ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=nocona -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
8894971.01ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer
8895691.01ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -Os -fomit-frame-pointer
7515901.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=nocona -Os -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
7540471.00ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=nocona -Os -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
7548121.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -march=k8 -Os -fomit-frame-pointer
7552171.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -march=nocona -Os -fomit-frame-pointer
7590871.01ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -Os -fomit-frame-pointer
7384231.00ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
7386301.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=nocona -Os -fomit-frame-pointer
7430671.01ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -fno-schedule-insns -Os -fomit-frame-pointer
7448941.01ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -fno-schedule-insns -Os -fomit-frame-pointer
7459831.01ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -Os -fomit-frame-pointer
9007741.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
9020161.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
9070831.01ecfp256scrypto_dh/ecfp256s/v01/vargcc -O3 -fomit-frame-pointer
9088021.01ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
9122221.01ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
6758911.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
21799801.00hectorcrypto_dh/hector/refgcc -funroll-loops -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
8781751.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=k8 -Os -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
11083051.26sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=k8 -O2 -fomit-frame-pointer
43726951.00sclaus2048crypto_dh/sclaus2048/gmpg++ -O2 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
52157971.19sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=nocona -O3 -fomit-frame-pointer
8317801.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
13779811.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -O2 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
9913771.00curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.1.2 20080704 (Red Hat 4.1.2-44))
28396172.86curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops
1873628118.90curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer