1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
#include "soft-fp.h" #include "double.h" #include "single.h" int FSMULD(void *rd, void *rs2, void *rs1) { FP_DECL_S(IN); FP_DECL_D(A); FP_DECL_D(B); FP_DECL_D(R); __FP_UNPACK_S(IN, rs1); FP_CONV(D,S,1,1,A,IN); __FP_UNPACK_S(IN, rs2); FP_CONV(D,S,1,1,B,IN); FP_MUL_D(R, A, B); return __FP_PACK_D(rd, R); }