diff options
author | Ian Moffett <ian@osmora.org> | 2025-07-14 22:39:34 -0400 |
---|---|---|
committer | Ian Moffett <ian@osmora.org> | 2025-07-14 22:39:34 -0400 |
commit | 7450f4f2bd19b1c6de0218a44aaba53639985768 (patch) | |
tree | 8b63e43a8a64810154b05c1176bd547a20e99d60 /lib/libc/src/musl-math/modf.c | |
parent | 83acdbef7ae961c2ae296835df3f368573c89eeb (diff) |
usr: libc: Add math.h + musl math impl port
Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'lib/libc/src/musl-math/modf.c')
-rw-r--r-- | lib/libc/src/musl-math/modf.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/libc/src/musl-math/modf.c b/lib/libc/src/musl-math/modf.c new file mode 100644 index 0000000..1c8a1db --- /dev/null +++ b/lib/libc/src/musl-math/modf.c @@ -0,0 +1,34 @@ +#include "libm.h" + +double modf(double x, double *iptr) +{ + union {double f; uint64_t i;} u = {x}; + uint64_t mask; + int e = (int)(u.i>>52 & 0x7ff) - 0x3ff; + + /* no fractional part */ + if (e >= 52) { + *iptr = x; + if (e == 0x400 && u.i<<12 != 0) /* nan */ + return x; + u.i &= 1ULL<<63; + return u.f; + } + + /* no integral part*/ + if (e < 0) { + u.i &= 1ULL<<63; + *iptr = u.f; + return x; + } + + mask = -1ULL>>12>>e; + if ((u.i & mask) == 0) { + *iptr = x; + u.i &= 1ULL<<63; + return u.f; + } + u.i &= ~mask; + *iptr = u.f; + return x - u.f; +} |