summaryrefslogtreecommitdiff
path: root/src/math/nexttowardf.c
diff options
context:
space:
mode:
authorSzabolcs Nagy <nsz@port70.net>2012-11-13 10:12:07 +0100
committerSzabolcs Nagy <nsz@port70.net>2012-11-13 10:12:07 +0100
commit662ed2006568f953290f5e0b40cce38252db78f4 (patch)
tree723999263be1ccb50d7d312f1d050c24a7659e47 /src/math/nexttowardf.c
parentcfbaba79a2dd380e580a247b8fd36af60c878e8f (diff)
downloadmusl-662ed2006568f953290f5e0b40cce38252db78f4.tar.gz
musl-662ed2006568f953290f5e0b40cce38252db78f4.tar.bz2
musl-662ed2006568f953290f5e0b40cce38252db78f4.tar.xz
musl-662ed2006568f953290f5e0b40cce38252db78f4.zip
math: fix nextafter and nexttoward on maxdbl and maxflt input
old code (return x+x;) returns correct value and raises correct flags only if the result is stored as double (or float)
Diffstat (limited to 'src/math/nexttowardf.c')
-rw-r--r--src/math/nexttowardf.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/math/nexttowardf.c b/src/math/nexttowardf.c
index 8648be6a..9a693b1a 100644
--- a/src/math/nexttowardf.c
+++ b/src/math/nexttowardf.c
@@ -28,7 +28,7 @@ float nexttowardf(float x, long double y)
e = ux.bits & 0x7f800000;
/* raise overflow if ux.value is infinite and x is finite */
if (e == 0x7f800000)
- return x + x;
+ FORCE_EVAL(x+x);
/* raise underflow if ux.value is subnormal or zero */
if (e == 0)
FORCE_EVAL(x*x + ux.value*ux.value);