projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add legacy header values.h
[musl]
/
src
/
math
/
remquol.c
diff --git
a/src/math/remquol.c
b/src/math/remquol.c
index
dd18f35
..
a2e1172
100644
(file)
--- a/
src/math/remquol.c
+++ b/
src/math/remquol.c
@@
-48,7
+48,7
@@
typedef uint32_t manh_t;
#define MANL_SHIFT (LDBL_MANL_SIZE - 1)
#define MANL_SHIFT (LDBL_MANL_SIZE - 1)
-static const long double Zero[] = {0.0
L, -0.0L
};
+static const long double Zero[] = {0.0
, -0.0
};
/*
* Return the IEEE remainder and set *quo to the last n bits of the
/*
* Return the IEEE remainder and set *quo to the last n bits of the
@@
-94,7
+94,7
@@
long double remquol(long double x, long double y, int *quo)
goto fixup; /* |x|<|y| return x or x-y */
}
if (ux.bits.manh == uy.bits.manh && ux.bits.manl == uy.bits.manl) {
goto fixup; /* |x|<|y| return x or x-y */
}
if (ux.bits.manh == uy.bits.manh && ux.bits.manl == uy.bits.manl) {
- *quo = 1;
+ *quo =
sxy ? -1 :
1;
return Zero[sx]; /* |x|=|y| return x*0*/
}
}
return Zero[sx]; /* |x|=|y| return x*0*/
}
}
@@
-152,6
+152,7
@@
long double remquol(long double x, long double y, int *quo)
/* convert back to floating value and restore the sign */
if ((hx|lx) == 0) { /* return sign(x)*0 */
/* convert back to floating value and restore the sign */
if ((hx|lx) == 0) { /* return sign(x)*0 */
+ q &= 0x7fffffff;
*quo = sxy ? -q : q;
return Zero[sx];
}
*quo = sxy ? -q : q;
return Zero[sx];
}