Implementation notes: amd64, enigma, crypto_dh

Computer: enigma
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2400160000...2400160000 (amd64cpuinfo)
SUPERCOP version: 20120414
Benchmark dates: 20120415...20120418

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
106251301.00clauscrypto_dh/claus/gmpg++ -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.3)
111311101.05clauscrypto_dh/claus/cryptoppg++ -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.3)
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
13772791.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
43252923.14curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
12520891.00curve25519crypto_dh/curve25519/refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.3)
15546421.24curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
8686171.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.3)
8762851.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8946271.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9333721.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
14357251.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
10507861.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
10598671.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
10803871.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -O2 -fomit-frame-pointer
11205271.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
17740531.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -O2 -fomit-frame-pointer
9380521.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
9461881.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
9614971.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O2 -fomit-frame-pointer
9925201.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
15205141.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -march=k8 -Os -fomit-frame-pointer
9149311.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
9246511.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
9416971.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
9771841.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
14756941.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
10806391.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.3)
10926721.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
11105551.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
11495611.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
18352351.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
9525421.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
36879661.00hectorcrypto_dh/hector/refgcc -march=k8 -O2 -fomit-frame-pointer (4.4.3)
17811091.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.3)
19729081.11sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=k8 -O3 -fomit-frame-pointer
86904451.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
95012191.09sclaus2048crypto_dh/sclaus2048/cryptoppg++ -fno-schedule-insns -O3 -fomit-frame-pointer
17049511.00surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.3)
34427701.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6140791.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3)
6151051.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer
6605101.08curve25519crypto_scalarmult/curve25519/amd64-51gcc -fno-schedule-insns -O -fomit-frame-pointer
9877861.61curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
12762182.08curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
1863871230.35curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -O -fomit-frame-pointer