Implementation notes: amd64, jos, crypto_dh

Computer: jos
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2493927000...2493927000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140702...20141017

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
101584431.00clauscrypto_dh/claus/gmpg++ -m64 -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
109871401.08clauscrypto_dh/claus/cryptoppg++ -m64 -march=native -mtune=native -O -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
12830031.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
34490402.69curve2251crypto_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
12064951.00curve25519crypto_dh/curve25519/refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
15883651.32curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
8576401.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
8669701.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
8839281.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
9233771.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
14328301.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
10475171.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
10556621.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
10747881.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
11163751.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
17857421.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
15067051.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
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
9074021.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
9175351.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer
9328651.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
9711001.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
14829221.63ecfp256qcrypto_dh/ecfp256q/v01/vargcc -O3 -fomit-frame-pointer
10789501.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
10891871.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
11084181.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
11495701.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
18474221.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
30123371.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
33180831.10ed448goldilockscrypto_dh/ed448goldilocks/64gcc -m64 -O3 -fomit-frame-pointer
66717982.21ed448goldilockscrypto_dh/ed448goldilocks/32gcc -m64 -march=k8 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -m64 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
8837701.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
gls254crypto_dh/gls254/protgcc -m64 -O3 -fomit-frame-pointer
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
gls254protcrypto_dh/gls254prot/protgcc -m64 -O3 -fomit-frame-pointer
8752121.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
8769971.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -march=k8 -O3 -fomit-frame-pointer
8821731.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
8916821.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -march=k8 -O3 -fomit-frame-pointer
9129451.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -O3 -fomit-frame-pointer
9517271.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
15622871.79hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer
8058671.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
8103231.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8178301.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -march=nocona -O3 -fomit-frame-pointer
8346451.04hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8676451.08hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -O3 -fomit-frame-pointer
9317171.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
12632931.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -march=k8 -O -fomit-frame-pointer
8022301.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
8077871.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
8166151.02hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8317571.04hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8645481.08hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
9304721.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=nocona -O3 -fomit-frame-pointer
12583281.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
15609751.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
15638921.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -fno-schedule-insns -O3 -fomit-frame-pointer
15729151.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
15899931.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -m64 -O3 -fomit-frame-pointer
16239901.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
16937251.09hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -m64 -march=k8 -O3 -fomit-frame-pointer
27759821.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=k8 -O2 -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
28251681.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
7206451.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
12854851.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
16502171.00kummercrypto_dh/kummer/refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
46779831.00nistp256crypto_dh/nistp256/refgcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
54689021.17nistp256crypto_dh/nistp256/wblgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
17156021.00sclaus1024crypto_dh/sclaus1024/gmpg++ -march=k8 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
19637851.14sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
84952051.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
97014221.14sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
16898171.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
26495021.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
12045531.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
12482481.04curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -O2 -fomit-frame-pointer
13322551.11curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -march=core2 -Os -fomit-frame-pointer
19759121.64curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
25966132.16curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
3941685032.72curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer
16505401.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])
17529981.06kummercrypto_scalarmult/kummer/ref5ugcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avxgcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2intgcc -m64 -O3 -fomit-frame-pointer
46788001.00nistp256crypto_scalarmult/nistp256/mj32gcc -march=barcelona -O3 -fomit-frame-pointer (4.5.0 20100604 [gcc-4 5-branch revision 160292])