Implementation notes: amd64, berlekamp, crypto_dh

Computer: berlekamp
Architecture: amd64
CPU ID: GenuineIntel-00010677-bfebfbff
CPU cycles/second: 2833000000...2833000000 (amd64cpuinfo)
SUPERCOP version: 20130419
Benchmark dates: 20120527...20130422

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
108859591.00clauscrypto_dh/claus/gmpg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
111974831.03clauscrypto_dh/claus/cryptoppg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer
186344901.71clauscrypto_dh/claus/opensslgcc -m64 -march=nocona -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
13098751.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
43131043.29curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -O3 -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
12602361.00curve25519crypto_dh/curve25519/refgcc -march=nocona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
15480371.23curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -O3 -fomit-frame-pointer
8532051.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8606081.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
8790281.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9153051.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
14218541.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
10343141.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
10438771.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
10640131.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=k8 -O2 -fomit-frame-pointer
11051281.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
17624831.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
9245791.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
9308261.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -O2 -fomit-frame-pointer
9465941.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O2 -fomit-frame-pointer
9774581.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
15043551.63ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer
9006431.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
9084031.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9255741.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
9609931.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
14615321.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
10649061.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
10750891.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
10950041.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer
11343081.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -O2 -fomit-frame-pointer
18236241.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
9270271.00gls1271crypto_dh/gls1271/ref4gcc -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
8775061.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8786621.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
8834471.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
8920751.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9125011.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -march=nocona -O3 -fomit-frame-pointer
9520421.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
15613651.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
8083841.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8138331.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8199861.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
8357711.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8677141.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
9335131.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
12663641.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8086561.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
8093951.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -march=barcelona -O2 -fomit-frame-pointer
8160431.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
8336211.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
8664221.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
9323901.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
12638991.56hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
15636851.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
15661931.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -fno-schedule-insns -O3 -fomit-frame-pointer
15756881.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
15913621.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
16259901.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
16945941.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
27774091.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -O2 -fomit-frame-pointer
37312021.00hectorcrypto_dh/hector/refgcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
7227211.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -march=barcelona -O -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
12836951.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
18326341.00sclaus1024crypto_dh/sclaus1024/gmpg++ -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
19841551.08sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -O -fomit-frame-pointer
87958941.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
95092141.08sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=barcelona -O -fomit-frame-pointer
17128441.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
34352411.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6131131.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -O3 -fomit-frame-pointer (4.4.1 20090725 (Red Hat 4.4.1-2))
6151031.00curve25519crypto_scalarmult/curve25519/donna_c64gcc -m64 -O3 -fomit-frame-pointer
6657541.09curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
9932251.62curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=barcelona -O3 -fomit-frame-pointer
12833302.09curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
1901885231.02curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/neon2gcc -m64 -O3 -fomit-frame-pointer