Implementation notes: x86, gcc14, crypto_dh

Computer: gcc14
Architecture: x86
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2992516999...2992516999 (x86cpuinfo)
SUPERCOP version: 20170105
Benchmark dates: 20161010...20170107

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
170814961.00clauscrypto_dh/claus/cryptoppg++ -m32 -march=k6 -O2 -fomit-frame-pointer (4.3.2)
329125321.93clauscrypto_dh/claus/gmpg++ -m32 -march=pentium-mmx -O3 -fomit-frame-pointer
532061463.11clauscrypto_dh/claus/opensslgcc -m32 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m32 -O3 -fomit-frame-pointer
55775971.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m32 -march=nocona -O -fomit-frame-pointer (4.3.2)
24342391.00curve25519crypto_dh/curve25519/refgcc -m32 -march=pentium3 -O2 -fomit-frame-pointer (4.3.2)
54329942.23curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -m32 -march=pentiumpro -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/32gcc -m32 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/64gcc -m32 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/amd64gcc -m32 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -m32 -O3 -fomit-frame-pointer
ed521gscrypto_dh/ed521gs/refgcc -m32 -O3 -fomit-frame-pointer
gls254crypto_dh/gls254/optgcc -m32 -O3 -fomit-frame-pointer
gls254protcrypto_dh/gls254prot/optgcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -m32 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -m32 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -m32 -O3 -fomit-frame-pointer
38891611.00hectorcrypto_dh/hector/refgcc -funroll-loops -m32 -march=nocona -O -fomit-frame-pointer (4.3.2)
jacfp127icrypto_dh/jacfp127i/v01/vargcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s01gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s02gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s04gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s08gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s16gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w4s32gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s01gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s02gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s04gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s08gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s16gcc -m32 -O3 -fomit-frame-pointer
jacfp127icrypto_dh/jacfp127i/v01/w8s32gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/varglv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s01glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s02glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s04glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s08glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s16glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w4s32glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s01glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s02glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s04glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s08glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s16glv4gcc -m32 -O3 -fomit-frame-pointer
jacfp128bkcrypto_dh/jacfp128bk/v01/w8s32glv4gcc -m32 -O3 -fomit-frame-pointer
k277moncrypto_dh/k277mon/refgcc -m32 -O3 -fomit-frame-pointer
k277taacrypto_dh/k277taa/refgcc -m32 -O3 -fomit-frame-pointer
k298crypto_dh/k298/refgcc -m32 -O3 -fomit-frame-pointer
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m32 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/vargcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s01gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s02gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s04gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s08gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s16gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s32gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s01gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s02gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s04gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s08gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s16gcc -m32 -O3 -fomit-frame-pointer
kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s32gcc -m32 -O3 -fomit-frame-pointer
36792361.00kummercrypto_dh/kummer/refgcc -funroll-loops -m32 -march=barcelona -O3 -fomit-frame-pointer (4.3.2)
nist521gscrypto_dh/nist521gs/refgcc -m32 -O3 -fomit-frame-pointer
130443841.00nistp256crypto_dh/nistp256/refgcc -funroll-loops -m32 -O -fomit-frame-pointer (4.3.2)
nistp256crypto_dh/nistp256/wblgcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/vargcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s01gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s02gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s04gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s08gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s16gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w4s32gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s01gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s02gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s04gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s08gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s16gcc -m32 -O3 -fomit-frame-pointer
prjfp127icrypto_dh/prjfp127i/v01/w8s32gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/varglv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s01glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s02glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s04glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s08glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s16glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w4s32glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s01glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s02glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s04glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s08glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s16glv4gcc -m32 -O3 -fomit-frame-pointer
prjfp128bkcrypto_dh/prjfp128bk/v01/w8s32glv4gcc -m32 -O3 -fomit-frame-pointer
30872251.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m32 -march=nocona -Os -fomit-frame-pointer (4.3.2)
55014031.78sclaus1024crypto_dh/sclaus1024/gmpg++ -m32 -march=barcelona -O2 -fomit-frame-pointer
147546271.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m32 -march=pentiumpro -O2 -fomit-frame-pointer (4.3.2)
266518171.81sclaus2048crypto_dh/sclaus2048/gmpg++ -m32 -march=k8 -O -fomit-frame-pointer
61101721.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m32 -march=pentiumpro -O3 -fomit-frame-pointer (4.3.2)
40656421.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m32 -march=prescott -O -fomit-frame-pointer (4.3.2)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
24277321.00curve25519crypto_scalarmult/curve25519/athlongcc -m32 -march=pentium-mmx -O2 -fomit-frame-pointer (4.3.2)
104466244.30curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m32 -march=pentium-m -O -fomit-frame-pointer
3450100514.21curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m32 -march=pentium-mmx -Os -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/donna_c64gcc -m32 -O3 -fomit-frame-pointer
37335601.00kummercrypto_scalarmult/kummer/ref5ugcc -m32 -march=native -mtune=native -O3 -fomit-frame-pointer (4.3.2)
59351041.59kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -m32 -O -fomit-frame-pointer
130498111.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -m32 -march=pentium2 -O3 -fomit-frame-pointer (4.3.2)