Implementation notes: amd64, enigma, crypto_dh

Computer: enigma
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2399975000...2399975000 (amd64cpuinfo)
SUPERCOP version: 20140529
Benchmark dates: 20140530...20140606

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
104842351.00clauscrypto_dh/claus/gmpg++ -O3 -fomit-frame-pointer (4.4.3)
110436031.05clauscrypto_dh/claus/cryptoppg++ -m64 -march=k8 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
13500721.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.3)
42882033.18curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -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
12295261.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.4.3)
15261571.24curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.4.3)
8671771.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
8765641.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8947801.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9325261.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
14374171.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
10501111.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.3)
10601011.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer (4.4.3)
10804591.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -O2 -fomit-frame-pointer
11204911.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -fno-schedule-insns -O2 -fomit-frame-pointer
17787781.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -O2 -fomit-frame-pointer (4.4.3)
15211981.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer (4.4.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer
9155791.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.3)
9237961.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9403561.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9757081.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
14726611.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
10816291.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.3)
10921231.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
11096461.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
11491741.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
18351181.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -O2 -fomit-frame-pointer
9297091.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.3)
gls254crypto_dh/gls254/protgcc -m64 -O3 -fomit-frame-pointer
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
8739001.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.3)
8768521.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
8808661.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
8915401.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9106741.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9495181.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
15596551.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
8039611.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.4.3)
8077591.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8153101.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
8329951.04hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
8648281.08hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
9299971.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
12607561.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
8028361.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -march=k8 -O3 -fomit-frame-pointer (4.4.3)
8039701.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -march=nocona -O2 -fomit-frame-pointer
8143381.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
8303491.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -O3 -fomit-frame-pointer
8627491.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -march=nocona -O3 -fomit-frame-pointer
9261451.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=nocona -O3 -fomit-frame-pointer
12590281.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
15586111.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -m64 -O2 -fomit-frame-pointer (4.4.3)
15617701.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -fno-schedule-insns -O2 -fomit-frame-pointer
15714091.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -fno-schedule-insns -O2 -fomit-frame-pointer
15876631.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
16222411.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
16914241.09hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -march=barcelona -O3 -fomit-frame-pointer
27716491.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=nocona -Os -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
36695791.00hectorcrypto_dh/hector/refgcc -march=k8 -O2 -fomit-frame-pointer (4.4.3)
7194511.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.3)
12743191.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
21633391.00kummercrypto_dh/kummer/refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.3)
17657731.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.3)
19657711.11sclaus1024crypto_dh/sclaus1024/cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
86724271.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.3)
94600531.09sclaus2048crypto_dh/sclaus2048/cryptoppg++ -Os -fomit-frame-pointer
16786441.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.3)
34204681.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
12270781.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -O3 -fomit-frame-pointer (4.4.3)
12331711.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
13267081.08curve25519crypto_scalarmult/curve25519/amd64-51gcc -O -fomit-frame-pointer
19819261.62curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
25554962.08curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -O2 -fomit-frame-pointer
3764639730.68curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
21716461.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.3)
kummercrypto_scalarmult/kummer/avxgcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer