Implementation notes: amd64, pmnod076, crypto_aead/bleep64

Computer: pmnod076
Architecture: amd64
CPU ID: GenuineIntel-00050657-bfebfbff
SUPERCOP version: 20191017
Operation: crypto_aead
Primitive: bleep64

Test failure

Implementation: ref
Security model: unknown
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
error 111
crypto_aead_encrypt is nondeterministic

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE ref
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE ref
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE ref

Compiler output

Implementation: ref
Security model: unknown
Compiler: gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE
try.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/../../../../x86_64-pc-linux-gnu/bin/ld: crypto_aead_bleep64.a(encrypt.o): in function `crypto_aead_bleep64_ref_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `Bleep64'
try.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/../../../../x86_64-pc-linux-gnu/bin/ld: crypto_aead_bleep64.a(encrypt.o): in function `crypto_aead_bleep64_ref_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `Bleep64'
try.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE ref

Compiler output

Implementation: ref
Security model: unknown
Compiler: icc -march=broadwell -mtune=broadwell -O2 -fomit-frame-pointer
encrypt.c: encrypt.c(25): warning #2605: register variable used in nested function
encrypt.c: { t = (((uint64_t)x * y) >> 32) - (x * y); // filter LFSR, diffuse autokey
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(25): warning #2605: register variable used in nested function
encrypt.c: { t = (((uint64_t)x * y) >> 32) - (x * y); // filter LFSR, diffuse autokey
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(25): warning #2605: register variable used in nested function
encrypt.c: { t = (((uint64_t)x * y) >> 32) - (x * y); // filter LFSR, diffuse autokey
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(26): warning #2605: register variable used in nested function
encrypt.c: if (assoc) u = *ad++ ^ t;
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(27): warning #2605: register variable used in nested function
encrypt.c: else if (encrypt) u = *pt++ ^ t, *ct++ = u + (L0 >> 32*odd);
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(29): warning #2605: register variable used in nested function
encrypt.c: if (odd) OCS(y, u), OCS(x, L1 >> 32); // feedback from 1st half of loop
encrypt.c: ^
encrypt.c:
encrypt.c: encrypt.c(92): warning #180: argument is incompatible with formal parameter
encrypt.c: ...
try.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/../../../../x86_64-pc-linux-gnu/bin/ld: crypto_aead_bleep64.a(encrypt.o): in function `crypto_aead_bleep64_ref_encrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `Bleep64'
try.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/../../../../x86_64-pc-linux-gnu/bin/ld: crypto_aead_bleep64.a(encrypt.o): in function `crypto_aead_bleep64_ref_decrypt':
try.c: encrypt.c:(.text+0x...): undefined reference to `Bleep64'

Number of similar (compiler,implementation) pairs: 24, namely:
CompilerImplementations
icc -march=broadwell -mtune=broadwell -O2 -fomit-frame-pointer ref
icc -march=broadwell -mtune=broadwell -O3 -fomit-frame-pointer ref
icc -march=cannonlake -mtune=cannonlake -O2 -fomit-frame-pointer ref
icc -march=cannonlake -mtune=cannonlake -O3 -fomit-frame-pointer ref
icc -march=core-avx-i -mtune=core-avx-i -O2 -fomit-frame-pointer ref
icc -march=core-avx-i -mtune=core-avx-i -O3 -fomit-frame-pointer ref
icc -march=core-avx2 -mtune=core-avx2 -O2 -fomit-frame-pointer ref
icc -march=core-avx2 -mtune=core-avx2 -O3 -fomit-frame-pointer ref
icc -march=corei7-avx -mtune=corei7-avx -O2 -fomit-frame-pointer ref
icc -march=corei7-avx -mtune=corei7-avx -O3 -fomit-frame-pointer ref
icc -march=corei7 -mtune=corei7 -O2 -fomit-frame-pointer ref
icc -march=corei7 -mtune=corei7 -O3 -fomit-frame-pointer ref
icc -march=haswell -mtune=haswell -O2 -fomit-frame-pointer ref
icc -march=haswell -mtune=haswell -O3 -fomit-frame-pointer ref
icc -march=icelake-client -mtune=icelake-client -O2 -fomit-frame-pointer ref
icc -march=icelake-client -mtune=icelake-client -O3 -fomit-frame-pointer ref
icc -march=ivybridge -mtune=ivybridge -O2 -fomit-frame-pointer ref
icc -march=ivybridge -mtune=ivybridge -O3 -fomit-frame-pointer ref
icc -march=sandybridge -mtune=sandybridge -O2 -fomit-frame-pointer ref
icc -march=sandybridge -mtune=sandybridge -O3 -fomit-frame-pointer ref
icc -march=skylake-avx512 -mtune=skylake-avx512 -O2 -fomit-frame-pointer ref
icc -march=skylake-avx512 -mtune=skylake-avx512 -O3 -fomit-frame-pointer ref
icc -march=skylake -mtune=skylake -O2 -fomit-frame-pointer ref
icc -march=skylake -mtune=skylake -O3 -fomit-frame-pointer ref