Implementation notes: amd64, skylake, crypto_sign

Computer: skylake
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
CPU cycles/second: 3300000000...3300000000 (amd64cpuinfo)
SUPERCOP version: 20161026
Benchmark dates: 20161215...20161217

crypto_sign

TimeRelative timePrimitiveImplementationCompiler
2741801.003icpcrypto_sign/3icp/refg++ -m64 -O2 -fomit-frame-pointer (6.2.1 20160830)
blscrypto_sign/bls/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
5868121.00donald1024crypto_sign/donald1024/opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer (6.2.1 20160830)
15459441.00donald2048crypto_sign/donald2048/opensslclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
donald2048crypto_sign/donald2048/cryptoppg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
3199381.00donald512crypto_sign/donald512/opensslgcc -m64 -march=nocona -O3 -fomit-frame-pointer (6.2.1 20160830)
20396301.00ecdonaldb163crypto_sign/ecdonaldb163/opensslgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer (6.2.1 20160830)
26257281.00ecdonaldb233crypto_sign/ecdonaldb233/opensslclang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
46179541.00ecdonaldb283crypto_sign/ecdonaldb283/opensslgcc -m64 -march=nocona -Os -fomit-frame-pointer (6.2.1 20160830)
73491201.00ecdonaldb409crypto_sign/ecdonaldb409/opensslgcc -m64 -march=corei7-avx -Os -fomit-frame-pointer (6.2.1 20160830)
172018261.00ecdonaldb571crypto_sign/ecdonaldb571/opensslgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (6.2.1 20160830)
19619061.00ecdonaldk163crypto_sign/ecdonaldk163/opensslgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv (6.2.1 20160830)
25226641.00ecdonaldk233crypto_sign/ecdonaldk233/opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer (6.2.1 20160830)
43580481.00ecdonaldk283crypto_sign/ecdonaldk283/opensslgcc -m64 -march=k8 -Os -fomit-frame-pointer (6.2.1 20160830)
69146801.00ecdonaldk409crypto_sign/ecdonaldk409/opensslgcc -funroll-loops -m64 -Os -fomit-frame-pointer (6.2.1 20160830)
159424621.00ecdonaldk571crypto_sign/ecdonaldk571/opensslgcc -m64 -march=core-avx2 -Os -fomit-frame-pointer (6.2.1 20160830)
13317501.00ecdonaldp160crypto_sign/ecdonaldp160/opensslgcc -m64 -march=barcelona -Os -fomit-frame-pointer (6.2.1 20160830)
15717361.00ecdonaldp192crypto_sign/ecdonaldp192/opensslgcc -m64 -march=k8 -Os -fomit-frame-pointer (6.2.1 20160830)
6684961.00ecdonaldp224crypto_sign/ecdonaldp224/opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer (6.2.1 20160830)
5315901.00ecdonaldp256crypto_sign/ecdonaldp256/opensslgcc -fno-schedule-insns -Os -fomit-frame-pointer (6.2.1 20160830)
47427101.00ecdonaldp384crypto_sign/ecdonaldp384/opensslgcc -m64 -march=barcelona -O -fomit-frame-pointer (6.2.1 20160830)
28089081.00ecdonaldp521crypto_sign/ecdonaldp521/opensslclang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
2353261.00ed25519crypto_sign/ed25519/amd64-64-24kgcc -m64 -march=corei7-avx -O -fomit-frame-pointer (6.2.1 20160830)
2420121.03ed25519crypto_sign/ed25519/amd64-51-30kclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
5644082.40ed25519crypto_sign/ed25519/ref10gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
533670022.68ed25519crypto_sign/ed25519/refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
7134681.00ed448goldilockscrypto_sign/ed448goldilocks/amd64 (2014-10-12)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
8458201.19ed448goldilockscrypto_sign/ed448goldilocks/64clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
16603042.33ed448goldilockscrypto_sign/ed448goldilocks/arm32clang -O3 -fomit-frame-pointer -Qunused-arguments
22619803.17ed448goldilockscrypto_sign/ed448goldilocks/32gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
ed448goldilockscrypto_sign/ed448goldilocks/neongcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe25crypto_sign/fslwe25/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe37crypto_sign/fslwe37/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe47crypto_sign/fslwe47/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe69crypto_sign/fslwe69/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hectorcrypto_sign/hector/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
3307741.00lattisigns512crypto_sign/lattisigns512/avxgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (6.2.1 20160830)
399181.00mqqsig160crypto_sign/mqqsig160/ref (1.00)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
561601.00mqqsig192crypto_sign/mqqsig192/ref (1.00)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
733341.00mqqsig224crypto_sign/mqqsig224/ref (1.00)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
813641.00mqqsig256crypto_sign/mqqsig256/ref (1.00)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
9692721.00ntrumls401xcrypto_sign/ntrumls401x/ref (1.0)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
7083121.00ntrumls439xcrypto_sign/ntrumls439x/ref (1.0)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
15625401.00ntrumls593xcrypto_sign/ntrumls593x/ref (1.0)clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
15165381.00ntrumls743xcrypto_sign/ntrumls743x/ref (1.0)clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
7968561.00pass769crypto_sign/pass769/ref-karatsuba (1.0k)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
13039361.00pass863crypto_sign/pass863/ref-karatsuba (1.0k)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
pflash1crypto_sign/pflash1/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
rainbowcrypto_sign/rainbow/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
874901.00rainbow5640crypto_sign/rainbow5640/refclang++ -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
1178681.00rainbow6440crypto_sign/rainbow6440/refclang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
672801.00rainbowbinary16242020crypto_sign/rainbowbinary16242020/refclang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
554121.00rainbowbinary256181212crypto_sign/rainbowbinary256181212/refg++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer (6.2.1 20160830)
9300601.00ronald1024crypto_sign/ronald1024/opensslgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (6.2.1 20160830)
24161201.00ronald1536crypto_sign/ronald1536/opensslclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))
35439921.00ronald2048crypto_sign/ronald2048/opensslgcc -m64 -march=core-avx-i -Os -fomit-frame-pointer (6.2.1 20160830)
88178361.00ronald3072crypto_sign/ronald3072/opensslgcc -m64 -march=nocona -Os -fomit-frame-pointer (6.2.1 20160830)
179079121.00ronald4096crypto_sign/ronald4096/opensslgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (6.2.1 20160830)
4555441.00ronald512crypto_sign/ronald512/opensslgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (6.2.1 20160830)
7569021.00ronald768crypto_sign/ronald768/opensslgcc -Os -fomit-frame-pointer (6.2.1 20160830)
8497641.00rwb0fuz1024crypto_sign/rwb0fuz1024/gmpgcc -funroll-loops -march=k8 -O -fomit-frame-pointer (6.2.1 20160830)
1741761.00sflashv2crypto_sign/sflashv2/refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (6.2.1 20160830)
447733501.00sphincs256crypto_sign/sphincs256/avx2gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (6.2.1 20160830)
2412246585.39sphincs256crypto_sign/sphincs256/refgcc -m64 -march=core2 -O3 -fomit-frame-pointer
752561.00tts6440crypto_sign/tts6440/refclang++ -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.9.0 (tags/RELEASE 390/final))