2
NetWinder Floating Point Emulator
3
(c) Rebel.COM, 1998,1999
5
Direct questions, comments to Scott Bambrough <scottb@netwinder.org>
7
This program is free software; you can redistribute it and/or modify
8
it under the terms of the GNU General Public License as published by
9
the Free Software Foundation; either version 2 of the License, or
10
(at your option) any later version.
12
This program is distributed in the hope that it will be useful,
13
but WITHOUT ANY WARRANTY; without even the implied warranty of
14
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
GNU General Public License for more details.
17
You should have received a copy of the GNU General Public License
18
along with this program; if not, write to the Free Software
19
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23
#include "softfloat.h"
26
float32 float32_exp(float32 Fm);
27
float32 float32_ln(float32 Fm);
28
float32 float32_sin(float32 rFm);
29
float32 float32_cos(float32 rFm);
30
float32 float32_arcsin(float32 rFm);
31
float32 float32_arctan(float32 rFm);
32
float32 float32_log(float32 rFm);
33
float32 float32_tan(float32 rFm);
34
float32 float32_arccos(float32 rFm);
35
float32 float32_pow(float32 rFn,float32 rFm);
36
float32 float32_pol(float32 rFn,float32 rFm);
38
unsigned int SingleCPDO(const unsigned int opcode)
40
FPA11 *fpa11 = GET_FPA11();
41
float32 rFm, rFn = float32_zero;
42
unsigned int Fd, Fm, Fn, nRc = 1;
45
if (CONSTANT_FM(opcode))
47
rFm = getSingleConstant(Fm);
51
switch (fpa11->fType[Fm])
54
rFm = fpa11->fpreg[Fm].fSingle;
61
if (!MONADIC_INSTRUCTION(opcode))
64
switch (fpa11->fType[Fn])
67
rFn = fpa11->fpreg[Fn].fSingle;
75
switch (opcode & MASK_ARITHMETIC_OPCODE)
79
fpa11->fpreg[Fd].fSingle = float32_add(rFn,rFm, &fpa11->fp_status);
84
fpa11->fpreg[Fd].fSingle = float32_mul(rFn,rFm, &fpa11->fp_status);
88
fpa11->fpreg[Fd].fSingle = float32_sub(rFn,rFm, &fpa11->fp_status);
92
fpa11->fpreg[Fd].fSingle = float32_sub(rFm,rFn, &fpa11->fp_status);
97
fpa11->fpreg[Fd].fSingle = float32_div(rFn,rFm, &fpa11->fp_status);
102
fpa11->fpreg[Fd].fSingle = float32_div(rFm,rFn, &fpa11->fp_status);
107
fpa11->fpreg[Fd].fSingle = float32_pow(rFn,rFm);
111
fpa11->fpreg[Fd].fSingle = float32_pow(rFm,rFn);
116
fpa11->fpreg[Fd].fSingle = float32_rem(rFn,rFm, &fpa11->fp_status);
121
fpa11->fpreg[Fd].fSingle = float32_pol(rFn,rFm);
125
/* monadic opcodes */
127
fpa11->fpreg[Fd].fSingle = rFm;
131
fpa11->fpreg[Fd].fSingle = float32_chs(rFm);
135
fpa11->fpreg[Fd].fSingle = float32_abs(rFm);
140
fpa11->fpreg[Fd].fSingle = float32_round_to_int(rFm, &fpa11->fp_status);
144
fpa11->fpreg[Fd].fSingle = float32_sqrt(rFm, &fpa11->fp_status);
149
fpa11->fpreg[Fd].fSingle = float32_log(rFm);
153
fpa11->fpreg[Fd].fSingle = float32_ln(rFm);
157
fpa11->fpreg[Fd].fSingle = float32_exp(rFm);
161
fpa11->fpreg[Fd].fSingle = float32_sin(rFm);
165
fpa11->fpreg[Fd].fSingle = float32_cos(rFm);
169
fpa11->fpreg[Fd].fSingle = float32_tan(rFm);
173
fpa11->fpreg[Fd].fSingle = float32_arcsin(rFm);
177
fpa11->fpreg[Fd].fSingle = float32_arccos(rFm);
181
fpa11->fpreg[Fd].fSingle = float32_arctan(rFm);
194
if (0 != nRc) fpa11->fType[Fd] = typeSingle;
199
float32 float32_exp(float32 Fm)
204
float32 float32_ln(float32 Fm)
209
float32 float32_sin(float32 rFm)
214
float32 float32_cos(float32 rFm)
219
float32 float32_arcsin(float32 rFm)
224
float32 float32_arctan(float32 rFm)
229
float32 float32_arccos(float32 rFm)
231
//return float32_sub(halfPi,float32_arcsin(rFm));
234
float32 float32_log(float32 rFm)
236
return float32_div(float32_ln(rFm),getSingleConstant(7));
239
float32 float32_tan(float32 rFm)
241
return float32_div(float32_sin(rFm),float32_cos(rFm));
244
float32 float32_pow(float32 rFn,float32 rFm)
246
return float32_exp(float32_mul(rFm,float32_ln(rFn)));
249
float32 float32_pol(float32 rFn,float32 rFm)
251
return float32_arctan(float32_div(rFn,rFm));