-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathfrexp-sparc.c
79 lines (71 loc) · 1 KB
/
frexp-sparc.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include <lib9.h>
#define MASK 0x7ffL
#define SHIFT 20
#define BIAS 1022L
typedef union
{
double d;
struct
{
long ms;
long ls;
};
} Cheat;
double
frexp(double d, int *ep)
{
Cheat x;
if(d == 0) {
*ep = 0;
return 0;
}
x.d = d;
*ep = ((x.ms >> SHIFT) & MASK) - BIAS;
x.ms &= ~(MASK << SHIFT);
x.ms |= BIAS << SHIFT;
return x.d;
}
double
ldexp(double d, int e)
{
Cheat x;
if(d == 0)
return 0;
x.d = d;
e += (x.ms >> SHIFT) & MASK;
if(e <= 0)
return 0; /* underflow */
if(e >= MASK){ /* overflow */
if(d < 0)
return Inf(-1);
return Inf(1);
}
x.ms &= ~(MASK << SHIFT);
x.ms |= (long)e << SHIFT;
return x.d;
}
double
modf(double d, double *ip)
{
Cheat x;
int e;
if(d < 1) {
if(d < 0) {
x.d = modf(-d, ip);
*ip = -*ip;
return -x.d;
}
*ip = 0;
return d;
}
x.d = d;
e = ((x.ms >> SHIFT) & MASK) - BIAS;
if(e <= SHIFT+1) {
x.ms &= ~(0x1fffffL >> e);
x.ls = 0;
} else
if(e <= SHIFT+33)
x.ls &= ~(0x7fffffffL >> (e-SHIFT-2));
*ip = x.d;
return d - x.d;
}