Implementation notes: amd64, giant0, crypto_dh

Computer: giant0
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2666747000...2666751000 (amd64cpuinfo)
SUPERCOP version: 20120207
Benchmark dates: 20100904...20120208

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
107942081.00clauscrypto_dh/claus/gmpg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
127221041.18clauscrypto_dh/claus/cryptoppg++ -m64 -march=barcelona -O -fomit-frame-pointer
238930642.21clauscrypto_dh/claus/opensslgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
13031921.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -fno-schedule-insns -Os -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
34554722.65curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -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
12528801.00curve25519crypto_dh/curve25519/refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
15708321.25curve25519crypto_dh/curve25519/mpfqgcc -march=nocona -O3 -fomit-frame-pointer
8638321.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
8708881.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
8852401.02ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
9225521.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
14397121.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
10440241.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
10512161.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -march=barcelona -Os -fomit-frame-pointer
10688641.02ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
11112881.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
17718641.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=barcelona -O2 -fomit-frame-pointer
9217201.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -Os -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
9277281.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer
9430881.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=core2 -Os -fomit-frame-pointer
9755841.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer
14980561.63ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=barcelona -Os -fomit-frame-pointer
9105601.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
9163681.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9345921.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -O2 -fomit-frame-pointer
9701601.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O2 -fomit-frame-pointer
14767281.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
10776401.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
10823841.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
11014561.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
11396401.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
18286801.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
9334081.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
28371601.00hectorcrypto_dh/hector/refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
18203121.00sclaus1024crypto_dh/sclaus1024/gmpg++ -march=nocona -O -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
22639121.24sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=barcelona -O3 -fomit-frame-pointer
87626481.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -Os -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
110920081.27sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=barcelona -Os -fomit-frame-pointer
16939601.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
25977761.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6154961.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -funroll-loops -O2 -fomit-frame-pointer (4.3.2 20081105 (Red Hat 4.3.2-7))
6159761.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
6554321.06curve25519crypto_scalarmult/curve25519/amd64-51gcc -O3 -fomit-frame-pointer
9894801.61curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=k8 -O2 -fomit-frame-pointer
13087682.13curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer
1881210430.56curve25519crypto_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