Implementation notes: amd64, bigmem, crypto_dh

Computer: bigmem
Architecture: amd64
CPU ID: GenuineIntel-000206e6-bfebfbff
CPU cycles/second: 2261133000...2261133000 (amd64cpuinfo)
SUPERCOP version: 20141124
Benchmark dates: 20110814...20150216

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
80265931.00clauscrypto_dh/claus/gmpg++ -march=barcelona -O3 -fomit-frame-pointer (4.4.3)
88929951.11clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
150608151.88clauscrypto_dh/claus/opensslgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
10647441.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.3)
28901812.71curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -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
7771471.00curve25519crypto_dh/curve25519/refgcc -O3 -fomit-frame-pointer (4.4.3)
12197421.57curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -O3 -fomit-frame-pointer
6293371.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.3)
6357611.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
6471671.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
6738861.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
10430011.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
7579401.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
7643121.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
7784731.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8085911.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
12860671.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
10970521.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -march=k8 -O3 -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
6677541.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
6725911.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
6836011.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
7086871.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
10801881.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
8033411.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
8111011.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8256681.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
8583191.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
13742371.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
20868781.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.3)
24877401.19ed448goldilockscrypto_dh/ed448goldilocks/64gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
56652842.71ed448goldilockscrypto_dh/ed448goldilocks/32gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -m64 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
6728941.00gls1271crypto_dh/gls1271/ref4gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3)
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
6499411.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.3)
6507601.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
6529221.00hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -m64 -march=k8 -O3 -fomit-frame-pointer
6597611.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
6746901.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
7044661.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -march=k8 -O3 -fomit-frame-pointer
11558811.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -march=k8 -O3 -fomit-frame-pointer
5822071.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -march=barcelona -O3 -fomit-frame-pointer (4.4.3)
5844911.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
5897161.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
6009211.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -march=barcelona -O2 -fomit-frame-pointer
6246771.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
6729341.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
9147191.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
5819951.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -funroll-loops -O2 -fomit-frame-pointer (4.4.3)
5830071.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
5888401.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -march=k8 -O2 -fomit-frame-pointer
6002311.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
6232431.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6715961.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -march=barcelona -O2 -fomit-frame-pointer
9114461.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
11338691.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.3)
11358241.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -m64 -march=k8 -O2 -fomit-frame-pointer
11412581.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -march=nocona -O2 -fomit-frame-pointer
11539121.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -m64 -march=k8 -O2 -fomit-frame-pointer
11789301.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -march=nocona -O2 -fomit-frame-pointer
12295561.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -march=k8 -O2 -fomit-frame-pointer
20159621.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=native -mtune=native -O -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
23283831.00hectorcrypto_dh/hector/refgcc -funroll-loops -O2 -fomit-frame-pointer (4.4.3)
5668821.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer (4.4.3)
9435431.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=core2 -msse4.1 -O -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
11888781.00kummercrypto_dh/kummer/refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer
53281801.00nistp256crypto_dh/nistp256/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
nistp256crypto_dh/nistp256/wblgcc -m64 -O3 -fomit-frame-pointer
13560131.00sclaus1024crypto_dh/sclaus1024/gmpg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3)
15778241.16sclaus1024crypto_dh/sclaus1024/cryptoppg++ -fno-schedule-insns -O3 -fomit-frame-pointer
68423331.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.3)
78443181.15sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=k8 -O3 -fomit-frame-pointer
12905661.00surf127epscrypto_dh/surf127eps/mpfqgcc -march=k8 -O3 -fomit-frame-pointer (4.4.3)
22203391.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
7759511.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer (4.4.3)
9032101.16curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer
9533571.23curve25519crypto_scalarmult/curve25519/donna_c64gcc -O3 -fomit-frame-pointer
14171941.83curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=barcelona -O -fomit-frame-pointer
16601092.14curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
3299285242.52curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
11876821.00kummercrypto_scalarmult/kummer/ref5gcc -march=nocona -O3 -fomit-frame-pointer (4.4.3)
12548971.06kummercrypto_scalarmult/kummer/ref5ugcc -march=nocona -O3 -fomit-frame-pointer (4.4.3)
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
53272141.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (4.4.3)