diff options
author | Fabian Schriever <fabian.schriever@gtd-gmbh.de> | 2020-03-18 14:18:20 +0100 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2020-03-19 16:34:26 +0100 |
commit | 4ad9ba42fc3dd116bad8b9cb89d434256d3431fb (patch) | |
tree | 56f0cf51cfdcda5e013a88f1dcb0529cebb1bd29 | |
parent | 9e8da7bd2138aaefcb746be3bcce2787c75a5849 (diff) | |
download | newlib-4ad9ba42fc3dd116bad8b9cb89d434256d3431fb.zip newlib-4ad9ba42fc3dd116bad8b9cb89d434256d3431fb.tar.gz newlib-4ad9ba42fc3dd116bad8b9cb89d434256d3431fb.tar.bz2 |
Fix modf/f for NaN input
For NaN input the modf/f procedures should return NaN instead of zero
with the sign of the input.
-rw-r--r-- | newlib/libm/common/s_modf.c | 1 | ||||
-rw-r--r-- | newlib/libm/common/sf_modf.c | 1 |
2 files changed, 2 insertions, 0 deletions
diff --git a/newlib/libm/common/s_modf.c b/newlib/libm/common/s_modf.c index 8551a99..c948b85 100644 --- a/newlib/libm/common/s_modf.c +++ b/newlib/libm/common/s_modf.c @@ -100,6 +100,7 @@ static double one = 1.0; } else if (j0>51) { /* no fraction part */ __uint32_t high; *iptr = x*one; + if (__fpclassifyd(x) == FP_NAN) return x+x; /* x is NaN, return NaN */ GET_HIGH_WORD(high,x); INSERT_WORDS(x,high&0x80000000,0); /* return +-0 */ return x; diff --git a/newlib/libm/common/sf_modf.c b/newlib/libm/common/sf_modf.c index 6c64e3f..ae97076 100644 --- a/newlib/libm/common/sf_modf.c +++ b/newlib/libm/common/sf_modf.c @@ -52,6 +52,7 @@ static float one = 1.0; } else { /* no fraction part */ __uint32_t ix; *iptr = x*one; + if (__fpclassifyf(x) == FP_NAN) return x+x; /* x is NaN, return NaN */ GET_FLOAT_WORD(ix,x); SET_FLOAT_WORD(x,ix&0x80000000); /* return +-0 */ return x; |