Implementation notes: amd64, gcc14, crypto_dh

Computer: gcc14
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2992540000...2992540000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20100918...20120311

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
127134811.00clauscrypto_dh/claus/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.3.2)
239733001.89clauscrypto_dh/claus/opensslgcc -funroll-loops -O -fomit-frame-pointer
clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/mpfqgcc -m64 -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
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer
12568861.00curve25519crypto_dh/curve25519/refgcc -fno-schedule-insns -Os -fomit-frame-pointer (4.3.2)
curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
8581051.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.3.2)
8643961.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8832781.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9193321.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
14316751.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -O2 -fomit-frame-pointer
10356121.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.3.2)
10472581.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
10636741.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
11057221.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
17630371.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
9210061.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -fno-schedule-insns -Os -fomit-frame-pointer (4.3.2)
9250021.00ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer
9387541.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=core2 -Os -fomit-frame-pointer
9713611.05ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer
14935591.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer
9040321.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.3.2)
9102961.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
9292861.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=k8 -O2 -fomit-frame-pointer
9629281.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
14712211.63ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
10697761.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.3.2)
10773091.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
10975861.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer (4.3.2)
11378341.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
18276121.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
9277561.00gls1271crypto_dh/gls1271/ref4gcc -march=k8 -O3 -fomit-frame-pointer (4.3.2)
hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
22706641.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.3.2)
sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer
111300931.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -O -fomit-frame-pointer (4.3.2)
sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer
surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6175441.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (4.3.2)
6316201.02curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
6634261.07curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
9881551.60curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
13178882.13curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m64 -Os -fomit-frame-pointer
1840115729.80curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer