| /*---------------------------------------------------------------------------+ |
| | fpu_arith.c | |
| | | |
| | Code to implement the FPU register/register arithmetic instructions | |
| | | |
| | Copyright (C) 1992,1993,1997 | |
| | W. Metzenthen, 22 Parker St, Ormond, Vic 3163, Australia | |
| | E-mail billm@suburbia.net | |
| | | |
| | | |
| +---------------------------------------------------------------------------*/ |
| |
| #include "fpu_system.h" |
| #include "fpu_emu.h" |
| #include "control_w.h" |
| #include "status_w.h" |
| |
| |
| void fadd__(void) |
| { |
| /* fadd st,st(i) */ |
| int i = FPU_rm; |
| clear_C1(); |
| FPU_add(&st(i), FPU_gettagi(i), 0, control_word); |
| } |
| |
| |
| void fmul__(void) |
| { |
| /* fmul st,st(i) */ |
| int i = FPU_rm; |
| clear_C1(); |
| FPU_mul(&st(i), FPU_gettagi(i), 0, control_word); |
| } |
| |
| |
| |
| void fsub__(void) |
| { |
| /* fsub st,st(i) */ |
| clear_C1(); |
| FPU_sub(0, FPU_rm, control_word); |
| } |
| |
| |
| void fsubr_(void) |
| { |
| /* fsubr st,st(i) */ |
| clear_C1(); |
| FPU_sub(REV, FPU_rm, control_word); |
| } |
| |
| |
| void fdiv__(void) |
| { |
| /* fdiv st,st(i) */ |
| clear_C1(); |
| FPU_div(0, FPU_rm, control_word); |
| } |
| |
| |
| void fdivr_(void) |
| { |
| /* fdivr st,st(i) */ |
| clear_C1(); |
| FPU_div(REV, FPU_rm, control_word); |
| } |
| |
| |
| |
| void fadd_i(void) |
| { |
| /* fadd st(i),st */ |
| int i = FPU_rm; |
| clear_C1(); |
| FPU_add(&st(i), FPU_gettagi(i), i, control_word); |
| } |
| |
| |
| void fmul_i(void) |
| { |
| /* fmul st(i),st */ |
| clear_C1(); |
| FPU_mul(&st(0), FPU_gettag0(), FPU_rm, control_word); |
| } |
| |
| |
| void fsubri(void) |
| { |
| /* fsubr st(i),st */ |
| clear_C1(); |
| FPU_sub(DEST_RM, FPU_rm, control_word); |
| } |
| |
| |
| void fsub_i(void) |
| { |
| /* fsub st(i),st */ |
| clear_C1(); |
| FPU_sub(REV|DEST_RM, FPU_rm, control_word); |
| } |
| |
| |
| void fdivri(void) |
| { |
| /* fdivr st(i),st */ |
| clear_C1(); |
| FPU_div(DEST_RM, FPU_rm, control_word); |
| } |
| |
| |
| void fdiv_i(void) |
| { |
| /* fdiv st(i),st */ |
| clear_C1(); |
| FPU_div(REV|DEST_RM, FPU_rm, control_word); |
| } |
| |
| |
| |
| void faddp_(void) |
| { |
| /* faddp st(i),st */ |
| int i = FPU_rm; |
| clear_C1(); |
| if ( FPU_add(&st(i), FPU_gettagi(i), i, control_word) >= 0 ) |
| FPU_pop(); |
| } |
| |
| |
| void fmulp_(void) |
| { |
| /* fmulp st(i),st */ |
| clear_C1(); |
| if ( FPU_mul(&st(0), FPU_gettag0(), FPU_rm, control_word) >= 0 ) |
| FPU_pop(); |
| } |
| |
| |
| |
| void fsubrp(void) |
| { |
| /* fsubrp st(i),st */ |
| clear_C1(); |
| if ( FPU_sub(DEST_RM, FPU_rm, control_word) >= 0 ) |
| FPU_pop(); |
| } |
| |
| |
| void fsubp_(void) |
| { |
| /* fsubp st(i),st */ |
| clear_C1(); |
| if ( FPU_sub(REV|DEST_RM, FPU_rm, control_word) >= 0 ) |
| FPU_pop(); |
| } |
| |
| |
| void fdivrp(void) |
| { |
| /* fdivrp st(i),st */ |
| clear_C1(); |
| if ( FPU_div(DEST_RM, FPU_rm, control_word) >= 0 ) |
| FPU_pop(); |
| } |
| |
| |
| void fdivp_(void) |
| { |
| /* fdivp st(i),st */ |
| clear_C1(); |
| if ( FPU_div(REV|DEST_RM, FPU_rm, control_word) >= 0 ) |
| FPU_pop(); |
| } |