xref: /haiku/src/system/libroot/posix/musl/math/modf.c (revision f504f61099b010fbfa94b1cc63d2e9072c7f7185)
1 #include "libm.h"
2 
modf(double x,double * iptr)3 double modf(double x, double *iptr)
4 {
5 	union {double f; uint64_t i;} u = {x};
6 	uint64_t mask;
7 	int e = (int)(u.i>>52 & 0x7ff) - 0x3ff;
8 
9 	/* no fractional part */
10 	if (e >= 52) {
11 		*iptr = x;
12 		if (e == 0x400 && u.i<<12 != 0) /* nan */
13 			return x;
14 		u.i &= 1ULL<<63;
15 		return u.f;
16 	}
17 
18 	/* no integral part*/
19 	if (e < 0) {
20 		u.i &= 1ULL<<63;
21 		*iptr = u.f;
22 		return x;
23 	}
24 
25 	mask = -1ULL>>12>>e;
26 	if ((u.i & mask) == 0) {
27 		*iptr = x;
28 		u.i &= 1ULL<<63;
29 		return u.f;
30 	}
31 	u.i &= ~mask;
32 	*iptr = u.f;
33 	return x - u.f;
34 }
35