Implementation notes: riscv64, hifiveunleashedriscv, crypto_dh/hecfp64e2i

Computer: hifiveunleashedriscv
Architecture: riscv64
CPU ID: unknown CPU ID
SUPERCOP version: 20191221
Operation: crypto_dh
Primitive: hecfp64e2i

Compiler output

Implementation: v01/var
Security model: unknown
Compiler: gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
divisor.c: In file included from divisor.c:12:
divisor.c: finite128.h:763:13: warning: inline function 'kum_fp_dbladd_2e064mce2_g_x8664_asm' declared but never defined
divisor.c: 763 | inline void kum_fp_dbladd_2e064mce2_g_x8664_asm(uni TMP, uni kn, uni_t i, uni d1, uni d2, uni CNS);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:762:13: warning: inline function 'kum_fp_dbl_2e064mce2_g_x8664_asm' declared but never defined
divisor.c: 762 | inline void kum_fp_dbl_2e064mce2_g_x8664_asm(uni TMP, void *NOPARAM1, void *NOPARAM2, uni d1, void *NOPARAM3, uni CNS);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:741:13: warning: inline function 'hec_fp_aadd_2e064mce2_g2i_x8664_asm' declared but never defined
divisor.c: 741 | inline void hec_fp_aadd_2e064mce2_g2i_x8664_asm(uni TMP, uni_t prm, void *NOPARAM, uni D3, uni d1, uni d2);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:740:13: warning: inline function 'hec_fp_madd_2e064mce2_g2i_x8664_asm' declared but never defined
divisor.c: 740 | inline void hec_fp_madd_2e064mce2_g2i_x8664_asm(uni TMP, uni_t prm, void *NOPARAM, uni D3, uni d1, uni d2);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:739:13: warning: inline function 'hec_fp_add_2e064mce2_g2i_x8664_asm' declared but never defined
divisor.c: 739 | inline void hec_fp_add_2e064mce2_g2i_x8664_asm(uni TMP, uni_t prm, void *NOPARAM, uni D3, uni d1, uni d2);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:738:13: warning: inline function 'hec_fp_dbl_2e064mce2_g2i_a2is0_a3is0_x8664_asm' declared but never defined
divisor.c: 738 | inline void hec_fp_dbl_2e064mce2_g2i_a2is0_a3is0_x8664_asm(uni TMP, uni_t prm, void *NOPARAM, uni D3, uni d1, uni CNS);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:737:13: warning: inline function 'hec_fp_dbl_2e064mce2_g2i_x8664_asm' declared but never defined
divisor.c: 737 | inline void hec_fp_dbl_2e064mce2_g2i_x8664_asm(uni TMP, uni_t prm, void *NOPARAM, uni D3, uni d1, uni CNS);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: finite128.h:512:13: warning: inline function 'kum_fp_dbladd_2e061m1e2_g_x8664_asm' declared but never defined
divisor.c: 512 | inline void kum_fp_dbladd_2e061m1e2_g_x8664_asm(uni TMP, uni kn, uni_t i, uni d1, uni d2, uni CNS);
divisor.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
divisor.c: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/var
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/var
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/var
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/var

Compiler output

Implementation: v01/w8s01
Security model: unknown
Compiler: gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE
array_lo.c: In file included from array_lo.c:24:
array_lo.c: array_lo.c: In function 'man_convert_word':
array_lo.c: kernel.h:123:41: error: impossible constraint in 'asm'
array_lo.c: 123 | #define km_mul_2_add_c(zH, zL, a, b, c) __asm__( \
array_lo.c: | ^~~~~~~
array_lo.c: multiprecision.h:696:4: note: in expansion of macro 'km_mul_2_add_c'
array_lo.c: 696 | km_mul_2_add_c(_t, (zn)[0], (an)[0], (b), _t); \
array_lo.c: | ^~~~~~~~~~~~~~
array_lo.c: array_lo.c:37:3: note: in expansion of macro 'mim_mul_1'
array_lo.c: 37 | mim_mul_1(an[al], an, an, al, base, buf[i]);
array_lo.c: | ^~~~~~~~~
array_lo.c: kernel.h:123:41: error: impossible constraint in 'asm'
array_lo.c: 123 | #define km_mul_2_add_c(zH, zL, a, b, c) __asm__( \
array_lo.c: | ^~~~~~~
array_lo.c: multiprecision.h:699:4: note: in expansion of macro 'km_mul_2_add_c'
array_lo.c: 699 | km_mul_2_add_c(_t, (zn)[0], (an)[0], (b), _t); \
array_lo.c: | ^~~~~~~~~~~~~~
array_lo.c: array_lo.c:37:3: note: in expansion of macro 'mim_mul_1'
array_lo.c: 37 | mim_mul_1(an[al], an, an, al, base, buf[i]);
array_lo.c: | ^~~~~~~~~
array_lo.c: kernel.h:123:41: error: impossible constraint in 'asm'
array_lo.c: 123 | #define km_mul_2_add_c(zH, zL, a, b, c) __asm__( \
array_lo.c: | ^~~~~~~
array_lo.c: multiprecision.h:700:4: note: in expansion of macro 'km_mul_2_add_c'
array_lo.c: 700 | km_mul_2_add_c(_t, (zn)[1], (an)[1], (b), _t); \
array_lo.c: ...

Number of similar (compiler,implementation) pairs: 24, namely:
CompilerImplementations
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s01
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s01
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s01
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s01
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s02
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s02
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s02
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s02
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s04
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s04
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s04
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s04
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s08
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s08
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s08
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s08
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s16
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s16
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s16
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s16
gcc -march=rv64gc -O2 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s32
gcc -march=rv64gc -O3 -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s32
gcc -march=rv64gc -O -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s32
gcc -march=rv64gc -Os -fomit-frame-pointer -fwrapv -fPIC -fPIE v01/w8s32