Implementation notes: amd64, colossus5, crypto_sign/edons128ref

Computer: colossus5
Architecture: amd64
CPU ID: AuthenticAMD-00800f12-178bfbff
SUPERCOP version: 20210125
Operation: crypto_sign
Primitive: edons128ref

Compiler output

Implementation: T:ref
Security model: timingleaks
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks':
sign.c: sign.c:815:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks_open':
sign.c: sign.c:975:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
try.c: crypto_sign_edons128ref.a(sign.o): In function `randomOrthogonalBinMatrix':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_xor'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_swap'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: crypto_sign_edons128ref.a(sign.o):sign.c:(.text+0x...): more undefined references to `__gmpz_init2' follow
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpn_popcount'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clrbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_mul_2exp'
try.c: ...

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

Compiler output

Implementation: T:ref
Security model: timingleaks
Compiler: gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks':
sign.c: sign.c:815:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks_open':
sign.c: sign.c:975:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
try.c: crypto_sign_edons128ref.a(sign.o): In function `randomOrthogonalBinMatrix.constprop.12':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_xor'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_swap'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: crypto_sign_edons128ref.a(sign.o): In function `randomOrthogonalBinMatrix.constprop.11':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_xor'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_swap'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: ...

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

Compiler output

Implementation: T:ref
Security model: timingleaks
Compiler: gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv -fPIC -fPIE
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks':
sign.c: sign.c:815:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks_open':
sign.c: sign.c:975:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
try.c: crypto_sign_edons128ref.a(sign.o): In function `randomOrthogonalBinMatrix':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_xor'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_swap'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: crypto_sign_edons128ref.a(sign.o):sign.c:(.text+0x...): more undefined references to `__gmpz_init2' follow
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpn_popcount'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: ...

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

Compiler output

Implementation: T:ref
Security model: timingleaks
Compiler: gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks':
sign.c: sign.c:815:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
sign.c: sign.c: In function 'crypto_sign_edons128ref_ref_timingleaks_open':
sign.c: sign.c:975:63: warning: passing argument 4 of 'qsort' from incompatible pointer type [-Wincompatible-pointer-types]
sign.c: qsort(allcandidates, NumberOfAllCandidates, sizeof(Kelt), compare);
sign.c: ^~~~~~~
sign.c: In file included from sign.c:2:0:
sign.c: /usr/include/stdlib.h:827:13: note: expected '__compar_fn_t {aka int (*)(const void *, const void *)}' but argument is of type 'int (*)(const long unsigned int *, const long unsigned int *)'
sign.c: extern void qsort (void *__base, size_t __nmemb, size_t __size,
sign.c: ^~~~~
try.c: crypto_sign_edons128ref.a(sign.o): In function `randomOrthogonalBinMatrix':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_xor'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_swap'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clear'
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_init2'
try.c: crypto_sign_edons128ref.a(sign.o):sign.c:(.text+0x...): more undefined references to `__gmpz_init2' follow
try.c: crypto_sign_edons128ref.a(sign.o): In function `crypto_sign_edons128ref_ref_timingleaks_keypair':
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_set_ui'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpn_popcount'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_tstbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_clrbit'
try.c: sign.c:(.text+0x...): undefined reference to `__gmpz_setbit'
try.c: ...

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