Implementation notes: amd64, icelake, crypto_scalarmult/curve25519

Computer: icelake
Architecture: amd64
CPU ID: GenuineIntel-000706e5-bfebfbff
SUPERCOP version: 20200826
Operation: crypto_scalarmult
Primitive: curve25519
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
60586226725 0 057344 4096 0donna_c64opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
61645921763 0 049152 4096 0donna_c64opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
61764622383 0 049152 4096 0donna_c64opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
79827331584 0 061440 4096 0donna_c64clang_-march=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
80486831584 0 061440 4096 0donna_c64clang_-march=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
85178629393 0 053248 4096 0donna_c64clang_-march=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
12947347794 0 036864 4096 0ref10opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
13812868372 0 036864 4096 0ref10opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
14206337802 0 032768 4096 0ref10clang_-march=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
14216099221 0 036864 4096 0ref10clang_-march=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
14497278223 0 036864 4096 0ref10clang_-march=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
14717468259 0 032768 4096 0ref10opt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
164987235957 0 036864 4096 0refopt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
189590744166 0 032768 4096 0refopt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
202167602782 0 028672 4096 0refopt-local-bin-gcc_-march=icelake-client_-mtune=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-fPIC_-fPIE2020082620200826
2107617548296 0 077824 4096 0refclang_-march=icelake-client_-O2_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
2147834738155 0 065536 4096 0refclang_-march=icelake-client_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826
225095643326 0 028672 4096 0refclang_-march=icelake-client_-Os_-fomit-frame-pointer_-fwrapv_-Qunused-arguments_-fPIC_-fPIE2020082620200826

Compiler output

Implementation: amd64-51
Security model: constbranchindex
Compiler: clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
consts.S: consts.S:2:17: error: unexpected token in '.section' directive
consts.S: .section .rodata
consts.S: ^

Number of similar (compiler,implementation) pairs: 12, namely:
CompilerImplementations
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-51
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-51
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-51
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-51
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-51
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-51
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-64
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-64
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE amd64-64
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-64
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-64
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE amd64-64

Compiler output

Implementation: donna
Security model: constbranchindex
Compiler: clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
try.c: Undefined symbols for architecture x86_64:
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_cmult", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fcontract", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fdifference_backwards", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fexpand", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fmul", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_freduce_coefficients", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fscalar", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fsquare", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: ld: symbol(s) not found for architecture x86_64
try.c: clang: error: linker command failed with exit code 1 (use -v to see invocation)

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna

Compiler output

Implementation: donna
Security model: constbranchindex
Compiler: opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
try.c: Undefined symbols for architecture x86_64:
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_cmult", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fcontract", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fdifference_backwards", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fexpand", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fmul", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_freduce_coefficients", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fscalar", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: "_crypto_scalarmult_curve25519_donna_constbranchindex_fsquare", referenced from:
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex_fmonty in crypto_scalarmult_curve25519.a(smult.o)
try.c: _crypto_scalarmult_curve25519_donna_constbranchindex in crypto_scalarmult_curve25519.a(smult.o)
try.c: ld: symbol(s) not found for architecture x86_64
try.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE donna
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE donna
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE donna

Compiler output

Implementation: donna_c64
Security model: constbranchindex
Compiler: clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
measure.c: ld: warning: could not create compact unwind for _crypto_stream_aes256ctr_dolbeau_aesenc_int_constbranchindex_xor: register 3 saved somewhere other than in frame

Number of similar (compiler,implementation) pairs: 9, namely:
CompilerImplementations
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna_c64
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna_c64
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE donna_c64
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref10
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref10
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE ref10

Compiler output

Implementation: sandy2x
Security model: constbranchindex
Compiler: clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE
consts.S: consts.S:8:17: error: unexpected token in '.section' directive
consts.S: .section .rodata
consts.S: ^

Number of similar (compiler,implementation) pairs: 6, namely:
CompilerImplementations
clang -march=icelake-client -O2 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sandy2x
clang -march=icelake-client -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sandy2x
clang -march=icelake-client -Os -fomit-frame-pointer -fwrapv -Qunused-arguments -fPIC -fPIE sandy2x
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE sandy2x
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE sandy2x
opt-local-bin-gcc -march=icelake-client -mtune=icelake-client -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE sandy2x