Implementation notes: aarch64, supercoplxc, crypto_aead/schwaemm128128v1

Computer: supercoplxc
Architecture: aarch64
CPU ID: 410fd034
SUPERCOP version: 20190816
Operation: crypto_aead
Primitive: schwaemm128128v1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
44992016945 0 032320 936 880refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
45472016973 0 032336 936 880refgcc_-funroll-loops_-O3_-fomit-frame-pointer2019092420190816
4555209905 0 023912 936 880refgcc_-O3_-fomit-frame-pointer2019092420190816
4645609929 0 023960 936 880refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
4968004133 0 016856 928 864optgcc_-O2_-fomit-frame-pointer2019092420190816
5016805037 0 023064 928 880optgcc_-O3_-fomit-frame-pointer2019092420190816
5182407681 0 022440 928 864optgcc_-funroll-loops_-O2_-fomit-frame-pointer2019092420190816
5212008169 0 023448 928 880optgcc_-funroll-loops_-O3_-fomit-frame-pointer2019092420190816
5323208117 0 023408 928 880optgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
5343208037 0 022928 928 864optgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
5397605045 0 023096 928 880optgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
5404004253 0 016952 928 864optgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
58272012241 0 027224 936 864refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
6256004581 0 017488 928 864optgcc_-O_-fomit-frame-pointer2019092420190816
6256804581 0 017488 928 864optgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
62760011789 0 026624 936 864refgcc_-funroll-loops_-O2_-fomit-frame-pointer2019092420190816
6446408357 0 024488 928 864optgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
6452008357 0 024488 928 864optgcc_-funroll-loops_-O_-fomit-frame-pointer2019092420190816
6626404641 0 017456 936 864refgcc_-O2_-fomit-frame-pointer2019092420190816
6885604745 0 017536 936 864refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
74760012405 0 028624 936 864refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
74768012405 0 028624 936 864refgcc_-funroll-loops_-O_-fomit-frame-pointer2019092420190816
7881605133 0 018136 936 864refgcc_-O_-fomit-frame-pointer2019092420190816
7881605133 0 018136 936 864refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816

Compiler output

Implementation: opt
Security model: unknown
Compiler: cc
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_opt_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `initialize'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `encryptPT'
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_opt_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `initialize'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `decryptCT'
try.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 7, namely:
CompilerImplementations
cc opt
gcc opt
gcc -Os -fomit-frame-pointer opt
gcc -fno-schedule-insns -Os -fomit-frame-pointer opt
gcc -funroll-loops opt
gcc -funroll-loops -Os -fomit-frame-pointer opt
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer opt

Compiler output

Implementation: opt
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_opt_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `encryptPT'
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_opt_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `decryptCT'
try.c: clang: error: linker command failed with exit code 1 (use -v to see invocation)

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments opt
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments opt
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments opt

Compiler output

Implementation: ref
Security model: unknown
Compiler: cc
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_ref_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `initialize'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `encryptPT'
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_ref_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `initialize'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `decryptCT'
try.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 7, namely:
CompilerImplementations
cc ref
gcc ref
gcc -Os -fomit-frame-pointer ref
gcc -fno-schedule-insns -Os -fomit-frame-pointer ref
gcc -funroll-loops ref
gcc -funroll-loops -Os -fomit-frame-pointer ref
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref

Compiler output

Implementation: ref
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_ref_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `encryptPT'
try.c: /usr/bin/ld: crypto_aead_schwaemm128128v1.a(encrypt.o): in function `crypto_aead_schwaemm128128v1_ref_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `processAD'
try.c: /usr/bin/ld: encrypt.c:(.text+0x...): undefined reference to `decryptCT'
try.c: clang: error: linker command failed with exit code 1 (use -v to see invocation)

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments ref
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref