]> sourceware.org Git - glibc.git/commitdiff
Optimize use of isnan, isinf, finite
authorUlrich Drepper <drepper@gmail.com>
Sat, 8 Oct 2011 14:18:26 +0000 (10:18 -0400)
committerUlrich Drepper <drepper@gmail.com>
Sat, 8 Oct 2011 14:18:26 +0000 (10:18 -0400)
35 files changed:
ChangeLog
include/math.h
math/Makefile
math/divtc3.c
math/multc3.c
math/s_casin.c
math/s_casinf.c
math/s_casinl.c
math/s_ccos.c
math/s_ccosf.c
math/s_ccosl.c
math/s_ctan.c
math/s_ctanf.c
math/s_ctanh.c
math/s_ctanhf.c
math/s_ctanhl.c
math/s_ctanl.c
math/w_fmod.c
math/w_fmodf.c
math/w_fmodl.c
math/w_remainder.c
math/w_remainderf.c
math/w_remainderl.c
sysdeps/ieee754/dbl-64/s_finite.c
sysdeps/ieee754/dbl-64/s_isinf_ns.c [new file with mode: 0644]
sysdeps/ieee754/dbl-64/s_isnan.c
sysdeps/ieee754/dbl-64/wordsize-64/s_finite.c
sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c [new file with mode: 0644]
sysdeps/ieee754/dbl-64/wordsize-64/s_isnan.c
sysdeps/ieee754/flt-32/s_finitef.c
sysdeps/ieee754/flt-32/s_isinf_nsf.c [new file with mode: 0644]
sysdeps/ieee754/flt-32/s_isnanf.c
sysdeps/ieee754/ldbl-128/s_isinf_nsl.c [new file with mode: 0644]
sysdeps/ieee754/ldbl-96/s_isinf_nsl.c [new file with mode: 0644]
sysdeps/x86_64/fpu/math_private.h

index db3a61bb083865ca084f8c840c376a1fd1d98656..57a72ca87df1aadbb12c059ba1cfe6ddb7ad8921 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,41 @@
 2011-10-08  Ulrich Drepper  <drepper@gmail.com>
 
+       * include/math.h: Declare __isinf_ns, __isinf_nsf, __isinf_nsl.
+       * sysdeps/ieee754/dbl-64/s_isinf_ns.c: New file.
+       * sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c: New file.
+       * sysdeps/ieee754/flt-32/s_isinf_nsf.c: New file.
+       * sysdeps/ieee754/ldbl-128/s_isinf_nsl.c: New file.
+       * sysdeps/ieee754/ldbl-96/s_isinf_nsl.c: New file.
+       * math/Makefile (libm-calls): Add s_isinf_ns.
+       * math/divtc3.c: Use __isinf_nsl instead of isinf.
+       * math/multc3.c: Likewise.
+       * math/s_casin.c: Likewise.
+       * math/s_casinf.c: Likewise.
+       * math/s_casinl.c: Likewise.
+       * math/s_ccos.c: Likewise.
+       * math/s_ccosf.c: Likewise.
+       * math/s_ccosl.c: Likewise.
+       * math/s_ctan.c: Likewise.
+       * math/s_ctanf.c: Likewise.
+       * math/s_ctanh.c: Likewise.
+       * math/s_ctanhf.c: Likewise.
+       * math/s_ctanhl.c: Likewise.
+       * math/s_ctanl.c: Likewise.
+       * math/w_fmod.c: Likewise.
+       * math/w_fmodf.c: Likewise.
+       * math/w_fmodl.c: Likewise.
+       * math/w_remainder.c: Likewise.
+       * math/w_remainderf.c: Likewise.
+       * math/w_remainderl.c: Likewise.
+       * sysdeps/ieee754/dbl-64/s_finite.c: Undefine __finite.
+       * sysdeps/ieee754/dbl-64/s_isnan.c: Undefine __isnan.
+       * sysdeps/ieee754/dbl-64/wordsize-64/s_finite.c: Undefine __finite.
+       * sysdeps/ieee754/dbl-64/wordsize-64/s_isnan.c: Undefine __nan.
+       * sysdeps/ieee754/flt-32/s_finitef.c: Undefine __finitef.
+       * sysdeps/ieee754/flt-32/s_isnanf.c: Undefine __nan.
+       * sysdeps/x86_64/fpu/math_private.h: Add optimized versions of __isnsn,
+       __isnanf, __isinf_ns, __isinf_nsf, __finite, and __finitef.
+
        * stdio-common/printf_fp.c: Use the fact that isinf returns the sign
        of the number.
        * stdio-common/printf_fphex.c: Likewise.
index eb29ef1a56808fc9b38600503289d1eb059f7fe3..393488017163f4120770e87a1ae299edea742eac 100644 (file)
@@ -31,4 +31,8 @@ libm_hidden_proto (__expl)
 libm_hidden_proto (__expm1l)
 # endif
 
+extern int __isinf_ns (double);
+extern int __isinf_nsf (float);
+extern int __isinf_nsl (long double);
+
 #endif
index 45954e2e87bff08a9530cf8a08bb80e7771ca75c..25cb5f6038277ec68847956e3d952ef791b3d1be 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1996-2001,2002,2003,2004,2005,2006
+# Copyright (C) 1996-2001,2002,2003,2004,2005,2006,2011
 #      Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
@@ -60,7 +60,7 @@ libm-calls = e_acos e_acosh e_asin e_atan2 e_atanh e_cosh e_exp e_fmod        \
             s_catan s_casin s_ccos s_csin s_ctan s_ctanh s_cacos       \
             s_casinh s_cacosh s_catanh s_csqrt s_cpow s_cproj s_clog10 \
             s_fma s_lrint s_llrint s_lround s_llround e_exp10 w_log2   \
-            $(calls:s_%=m_%)
+            s_isinf_ns $(calls:s_%=m_%)
 
 include ../Makeconfig
 
index d974ae6454bf7570218d3b40129fe38820701763..72bca66d4d85cc2ccc384ad06c603260f24e284d 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2005, 2006 Free Software Foundation, Inc.
+/* Copyright (C) 2005, 2006, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Richard Henderson <rth@redhat.com>, 2005.
 
@@ -55,17 +55,19 @@ __divtc3 (long double a, long double b, long double c, long double d)
          x = __copysignl (INFINITY, c) * a;
          y = __copysignl (INFINITY, c) * b;
        }
-      else if ((isinf (a) || isinf (b)) && isfinite (c) && isfinite (d))
+      else if ((__isinf_nsl (a) || __isinf_nsl (b))
+              && isfinite (c) && isfinite (d))
        {
-         a = __copysignl (isinf (a) ? 1 : 0, a);
-         b = __copysignl (isinf (b) ? 1 : 0, b);
+         a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
+         b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
          x = INFINITY * (a * c + b * d);
          y = INFINITY * (b * c - a * d);
        }
-      else if ((isinf (c) || isinf (d)) && isfinite (a) && isfinite (b))
+      else if ((__isinf_nsl (c) || __isinf_nsl (d))
+              && isfinite (a) && isfinite (b))
        {
-         c = __copysignl (isinf (c) ? 1 : 0, c);
-         d = __copysignl (isinf (d) ? 1 : 0, d);
+         c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
+         d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
          x = 0.0 * (a * c + b * d);
          y = 0.0 * (b * c - a * d);
        }
index 6369f48f247606e27a5b10236e4eec8c9e573726..351dccf807b06522f458481dc3502f04d0b9d91d 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2005, 2006 Free Software Foundation, Inc.
+/* Copyright (C) 2005, 2006, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Richard Henderson <rth@redhat.com>, 2005.
 
@@ -39,28 +39,29 @@ __multc3 (long double a, long double b, long double c, long double d)
     {
       /* Recover infinities that computed as NaN + iNaN.  */
       bool recalc = 0;
-      if (isinf (a) || isinf (b))
+      if (__isinf_nsl (a) || __isinf_nsl (b))
        {
          /* z is infinite.  "Box" the infinity and change NaNs in
             the other factor to 0.  */
-         a = __copysignl (isinf (a) ? 1 : 0, a);
-         b = __copysignl (isinf (b) ? 1 : 0, b);
+         a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
+         b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
          if (isnan (c)) c = __copysignl (0, c);
          if (isnan (d)) d = __copysignl (0, d);
          recalc = 1;
        }
-     if (isinf (c) || isinf (d))
+     if (__isinf_nsl (c) || __isinf_nsl (d))
        {
          /* w is infinite.  "Box" the infinity and change NaNs in
             the other factor to 0.  */
-         c = __copysignl (isinf (c) ? 1 : 0, c);
-         d = __copysignl (isinf (d) ? 1 : 0, d);
+         c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
+         d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
          if (isnan (a)) a = __copysignl (0, a);
          if (isnan (b)) b = __copysignl (0, b);
          recalc = 1;
        }
      if (!recalc
-         && (isinf (ac) || isinf (bd) || isinf (ad) || isinf (bc)))
+         && (__isinf_nsl (ac) || __isinf_nsl (bd)
+             || __isinf_nsl (ad) || __isinf_nsl (bc)))
        {
          /* Recover infinities from overflow by changing NaNs to 0.  */
          if (isnan (a)) a = __copysignl (0, a);
index 2d5b06cf7885073e2adb7a085b5b88f4db46253c..02a215ab503e242ff413f01875fdf752a210468c 100644 (file)
@@ -1,5 +1,5 @@
 /* Return arc sine of complex double value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -20,6 +20,7 @@
 
 #include <complex.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ double
@@ -33,7 +34,7 @@ __casin (__complex__ double x)
        {
          res = x;
        }
-      else if (__isinf (__real__ x) || __isinf (__imag__ x))
+      else if (__isinf_ns (__real__ x) || __isinf_ns (__imag__ x))
        {
          __real__ res = __nan ("");
          __imag__ res = __copysign (HUGE_VAL, __imag__ x);
index 5278dbbf7884087cdc07ac620084c8f45d90a4ca..56c618fcf1ad7601d84d3dff11908002cb6355d6 100644 (file)
@@ -1,5 +1,5 @@
 /* Return arc sine of complex float value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -20,6 +20,7 @@
 
 #include <complex.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ float
@@ -33,7 +34,7 @@ __casinf (__complex__ float x)
        {
          res = x;
        }
-      else if (__isinff (__real__ x) || __isinff (__imag__ x))
+      else if (__isinf_nsf (__real__ x) || __isinf_nsf (__imag__ x))
        {
          __real__ res = __nanf ("");
          __imag__ res = __copysignf (HUGE_VALF, __imag__ x);
index f303c05ae6baf35dc0fc2ed889885cda6f81f3d2..431e9a2413923640a7ffcd0e3b65ca4ab6a5c5b7 100644 (file)
@@ -1,5 +1,5 @@
 /* Return arc sine of complex long double value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -20,6 +20,7 @@
 
 #include <complex.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ long double
@@ -33,7 +34,7 @@ __casinl (__complex__ long double x)
        {
          res = x;
        }
-      else if (__isinfl (__real__ x) || __isinfl (__imag__ x))
+      else if (__isinf_nsl (__real__ x) || __isinf_nsl (__imag__ x))
        {
          __real__ res = __nanl ("");
          __imag__ res = __copysignl (HUGE_VALL, __imag__ x);
index 1b244d70790f80a5b2f99a5ee8d0c5761a6bf5dc..63851aab5488c700b082a995b66c9ed59b45916c 100644 (file)
@@ -1,5 +1,5 @@
 /* Return cosine of complex double value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -21,6 +21,7 @@
 #include <complex.h>
 #include <fenv.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ double
@@ -36,17 +37,17 @@ __ccos (__complex__ double x)
          __imag__ res = 0.0;
 
 #ifdef FE_INVALID
-         if (__isinf (__real__ x))
+         if (__isinf_ns (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
-      else if (__isinf (__imag__ x))
+      else if (__isinf_ns (__imag__ x))
        {
          __real__ res = HUGE_VAL;
          __imag__ res = __nan ("");
 
 #ifdef FE_INVALID
-         if (__isinf (__real__ x))
+         if (__isinf_ns (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 4b154deac5b897f5ad70f3d2015f21c766c8ecbe..f0e9c2ac9ef99195c96dc81f46e92206dd370360 100644 (file)
@@ -1,5 +1,5 @@
 /* Return cosine of complex float value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -21,6 +21,7 @@
 #include <complex.h>
 #include <fenv.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ float
@@ -36,17 +37,17 @@ __ccosf (__complex__ float x)
          __imag__ res = 0.0;
 
 #ifdef FE_INVALID
-         if (__isinff (__real__ x))
+         if (__isinf_nsf (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
-      else if (__isinff (__imag__ x))
+      else if (__isinf_nsf (__imag__ x))
        {
          __real__ res = HUGE_VALF;
          __imag__ res = __nanf ("");
 
 #ifdef FE_INVALID
-         if (__isinff (__real__ x))
+         if (__isinf_nsf (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 4ebe2c347dbe5946bec8bc58b1eb4fd9e843948d..9902a02edd2363dfee91c6a02b4e996d620d7606 100644 (file)
@@ -1,5 +1,5 @@
 /* Return cosine of complex long double value.
-   Copyright (C) 1997 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -21,6 +21,7 @@
 #include <complex.h>
 #include <fenv.h>
 #include <math.h>
+#include <math_private.h>
 
 
 __complex__ long double
@@ -36,17 +37,17 @@ __ccosl (__complex__ long double x)
          __imag__ res = 0.0;
 
 #ifdef FE_INVALID
-         if (__isinfl (__real__ x))
+         if (__isinf_nsl (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
-      else if (__isinfl (__imag__ x))
+      else if (__isinf_nsl (__imag__ x))
        {
          __real__ res = HUGE_VALL;
          __imag__ res = __nanl ("");
 
 #ifdef FE_INVALID
-         if (__isinfl (__real__ x))
+         if (__isinf_nsl (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 4cadad1dacbb169a8bbe35db22cde15910eefd97..0dd211e9076630db7b8ed20ecb709c3b4ba1a9bf 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex tangent function for double.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctan (__complex__ double x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinf (__imag__ x))
+      if (__isinf_ns (__imag__ x))
        {
          __real__ res = __copysign (0.0, __real__ x);
          __imag__ res = __copysign (1.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctan (__complex__ double x)
          __imag__ res = __nan ("");
 
 #ifdef FE_INVALID
-         if (__isinf (__real__ x))
+         if (__isinf_ns (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 7fa16200c5ff5e331f2a49182411a3c9e7699946..7236dc3e9dae77f68d5ea2db1582e1f2854b654c 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex tangent function for float.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctanf (__complex__ float x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinff (__imag__ x))
+      if (__isinf_nsf (__imag__ x))
        {
          __real__ res = __copysignf (0.0, __real__ x);
          __imag__ res = __copysignf (1.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctanf (__complex__ float x)
          __imag__ res = __nanf ("");
 
 #ifdef FE_INVALID
-         if (__isinff (__real__ x))
+         if (__isinf_nsf (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 60a52dbdb7abfcbfdb22f9a4b276329716400d82..f4a1d7e450dc70268b2527b37a4bac55abc9e907 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex hyperbole tangent for double.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctanh (__complex__ double x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinf (__real__ x))
+      if (__isinf_ns (__real__ x))
        {
          __real__ res = __copysign (1.0, __real__ x);
          __imag__ res = __copysign (0.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctanh (__complex__ double x)
          __imag__ res = __nan ("");
 
 #ifdef FE_INVALID
-         if (__isinf (__imag__ x))
+         if (__isinf_ns (__imag__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 1d62afc27bf9a0b3d3d221c33f81ac9196d4937b..cb65edb7fc1caf42731c5cc7bce6c53245a3b3bc 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex hyperbole tangent for float.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctanhf (__complex__ float x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinff (__real__ x))
+      if (__isinf_nsf (__real__ x))
        {
          __real__ res = __copysignf (1.0, __real__ x);
          __imag__ res = __copysignf (0.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctanhf (__complex__ float x)
          __imag__ res = __nanf ("");
 
 #ifdef FE_INVALID
-         if (__isinff (__imag__ x))
+         if (__isinf_nsf (__imag__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 99df2b06cd670f678f158e60b05266602e75e4d2..bee9e7601b54c690bdca86d87262282ab1a17d30 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex hyperbole tangent for long double.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctanhl (__complex__ long double x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinfl (__real__ x))
+      if (__isinf_nsl (__real__ x))
        {
          __real__ res = __copysignl (1.0, __real__ x);
          __imag__ res = __copysignl (0.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctanhl (__complex__ long double x)
          __imag__ res = __nanl ("");
 
 #ifdef FE_INVALID
-         if (__isinfl (__imag__ x))
+         if (__isinf_nsl (__imag__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 4a95c1df0690dac3c2c7c04ee6c18f4c05616dc4..fcc0da90d6f9f459adac522fda8802b9f81b33a0 100644 (file)
@@ -1,5 +1,5 @@
 /* Complex tangent function for long double.
-   Copyright (C) 1997, 2005 Free Software Foundation, Inc.
+   Copyright (C) 1997, 2005, 2011 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
 
@@ -32,7 +32,7 @@ __ctanl (__complex__ long double x)
 
   if (!isfinite (__real__ x) || !isfinite (__imag__ x))
     {
-      if (__isinfl (__imag__ x))
+      if (__isinf_nsl (__imag__ x))
        {
          __real__ res = __copysignl (0.0, __real__ x);
          __imag__ res = __copysignl (1.0, __imag__ x);
@@ -47,7 +47,7 @@ __ctanl (__complex__ long double x)
          __imag__ res = __nanl ("");
 
 #ifdef FE_INVALID
-         if (__isinfl (__real__ x))
+         if (__isinf_nsl (__real__ x))
            feraiseexcept (FE_INVALID);
 #endif
        }
index 69102de9c56f5c8886edb6148a9a66b4aa6f0538..b93ff8935e837116e431f307bb893e7e559a1669 100644 (file)
@@ -35,9 +35,9 @@ static char rcsid[] = "$NetBSD: w_fmod.c,v 1.6 1995/05/10 20:48:55 jtc Exp $";
        double z;
        z = __ieee754_fmod(x,y);
        if(_LIB_VERSION == _IEEE_ ||__isnan(y)||__isnan(x)) return z;
-       if(__isinf(x)||y==0.0) {
+       if(__isinf_ns(x)||y==0.0) {
                /* fmod(+-Inf,y) or fmod(x,0) */
-               return __kernel_standard(x,y,27);
+               return __kernel_standard(x,y,27);
        } else
            return z;
 #endif
index 55ec8737c87cad71c4b39eec321d08d683d82b4f..12e2fb3cf8627ccd76c728f7472d55c0336c6fcf 100644 (file)
@@ -38,9 +38,9 @@ static char rcsid[] = "$NetBSD: w_fmodf.c,v 1.3 1995/05/10 20:48:57 jtc Exp $";
        float z;
        z = __ieee754_fmodf(x,y);
        if(_LIB_VERSION == _IEEE_ ||__isnanf(y)||__isnanf(x)) return z;
-       if(__isinff(x)||y==(float)0.0) {
+       if(__isinf_nsf(x)||y==(float)0.0) {
                /* fmodf(+-Inf,y) or fmodf(x,0) */
-               return (float)__kernel_standard((double)x,(double)y,127);
+               return (float)__kernel_standard((double)x,(double)y,127);
        } else
            return z;
 #endif
index c95e23293bc550dd2ac3571612c5fee96588321f..ffc77adf090dbc2908af4e45a9ea766d8626d55d 100644 (file)
@@ -39,9 +39,9 @@ static char rcsid[] = "$NetBSD: $";
        long double z;
        z = __ieee754_fmodl(x,y);
        if(_LIB_VERSION == _IEEE_ ||__isnanl(y)||__isnanl(x)) return z;
-       if(__isinfl(x)||y==0.0) {
+       if(__isinf_nsl(x)||y==0.0) {
                /* fmodl(+-Inf,y) or fmodl(x,0) */
-               return __kernel_standard(x,y,227);
+               return __kernel_standard(x,y,227);
        } else
            return z;
 #endif
index 087bf2353bc1c7b039537ffd180285f9627c7f15..cf35ee24bd7829a209ab37aa1f050a9fcf6c8b48 100644 (file)
@@ -34,7 +34,7 @@ static char rcsid[] = "$NetBSD: w_remainder.c,v 1.6 1995/05/10 20:49:44 jtc Exp
        double z;
        z = __ieee754_remainder(x,y);
        if(_LIB_VERSION == _IEEE_ || __isnan(y) || __isnan(x)) return z;
-       if(y==0.0 || __isinf(x))
+       if(y==0.0 || __isinf_ns(x))
            return __kernel_standard(x,y,28); /* remainder(x,0) */
        else
            return z;
index 95e6d302b9fe0ce570a3dc3ea9cf2768c803ecb0..39d01b3fa0e6127602a20fe39411070217927ac8 100644 (file)
@@ -37,7 +37,7 @@ static char rcsid[] = "$NetBSD: w_remainderf.c,v 1.3 1995/05/10 20:49:46 jtc Exp
        float z;
        z = __ieee754_remainderf(x,y);
        if(_LIB_VERSION == _IEEE_ || __isnanf(y) || __isnanf(x)) return z;
-       if(y==(float)0.0 || __isinff(x))
+       if(y==(float)0.0 || __isinf_nsf(x))
            /* remainder(x,0) */
            return (float)__kernel_standard((double)x,(double)y,128);
        else
index 36050f0de20653b0a75a4c1f2a12381f069e86d1..dec70e50288d0694251f12530870d3002ac46207 100644 (file)
@@ -39,7 +39,7 @@ static char rcsid[] = "$NetBSD: $";
        long double z;
        z = __ieee754_remainderl(x,y);
        if(_LIB_VERSION == _IEEE_ || __isnanl(y) || __isnanl(x)) return z;
-       if(y==0.0 || __isinfl(x))
+       if(y==0.0 || __isinf_nsl(x))
            return __kernel_standard(x,y,228); /* remainder(x,0) */
        else
            return z;
index 90de0f9d11d9084ede0835549576c8aeb3144306..2ca3bf2454d79d9d26507fe8ebc8028c5baabe80 100644 (file)
@@ -22,6 +22,7 @@ static char rcsid[] = "$NetBSD: s_finite.c,v 1.8 1995/05/10 20:47:17 jtc Exp $";
 #include "math.h"
 #include "math_private.h"
 
+#undef __finite
 #ifdef __STDC__
        int __finite(double x)
 #else
diff --git a/sysdeps/ieee754/dbl-64/s_isinf_ns.c b/sysdeps/ieee754/dbl-64/s_isinf_ns.c
new file mode 100644 (file)
index 0000000..065522e
--- /dev/null
@@ -0,0 +1,20 @@
+/*
+ * Written by Ulrich Drepper <drepper@gmail.com>.
+ */
+
+/*
+ * __isinf_ns(x) returns != 0 if x is ±inf, else 0;
+ * no branching!
+ */
+
+#include "math.h"
+#include "math_private.h"
+
+#undef __isinf_ns
+int
+__isinf_ns (double x)
+{
+       int32_t hx,lx;
+       EXTRACT_WORDS(hx,lx,x);
+       return !(lx | ((hx & 0x7fffffff) ^ 0x7ff00000));
+}
index 3a089e99a853d380c954eac724835de6a74adafd..74e8291609f6018901e2c86887db25f26b9425db 100644 (file)
@@ -22,6 +22,7 @@ static char rcsid[] = "$NetBSD: s_isnan.c,v 1.8 1995/05/10 20:47:36 jtc Exp $";
 #include "math.h"
 #include "math_private.h"
 
+#undef __isnan
 #ifdef __STDC__
        int __isnan(double x)
 #else
index 585f63e571ce0dcb33e1304adf808ef58d1c1d41..93a39a68351beee77f8beff79eaf07deb2c562de 100644 (file)
@@ -17,6 +17,7 @@
 #include "math.h"
 #include "math_private.h"
 
+#undef __finite
 int
 __finite(double x)
 {
diff --git a/sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c b/sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c
new file mode 100644 (file)
index 0000000..09dcc94
--- /dev/null
@@ -0,0 +1,20 @@
+/*
+ * Written by Ulrich Drepper <drepper@gmail.com>.
+ */
+
+/*
+ * __isinf_ns(x) returns != 0 if x is ±inf, else 0;
+ * no branching!
+ */
+
+#include "math.h"
+#include "math_private.h"
+
+#undef __isinf_ns
+int
+__isinf_ns (double x)
+{
+       int64_t ix;
+       EXTRACT_WORDS64(ix,x);
+       return (ix & UINT64_C(0x7fffffffffffffff)) == UINT64_C(0x7ff0000000000000);
+}
index 3b08c54dd459cafa38c5375bffe2fc9a09b2ef4f..65dc8934f91c6243ca6139b82dd2c516b7753e39 100644 (file)
@@ -18,6 +18,7 @@
 #include "math.h"
 #include "math_private.h"
 
+#undef __isnan
 #ifdef __STDC__
        int __isnan(double x)
 #else
index 65767f8f9301ff67814678616f408ff8de80ffc0..2df513be75c5ee2f304f8aa6a5973bc7c3e224af 100644 (file)
@@ -25,6 +25,7 @@ static char rcsid[] = "$NetBSD: s_finitef.c,v 1.4 1995/05/10 20:47:18 jtc Exp $"
 #include "math.h"
 #include "math_private.h"
 
+#undef __finitef
 #ifdef __STDC__
        int __finitef(float x)
 #else
diff --git a/sysdeps/ieee754/flt-32/s_isinf_nsf.c b/sysdeps/ieee754/flt-32/s_isinf_nsf.c
new file mode 100644 (file)
index 0000000..bc37785
--- /dev/null
@@ -0,0 +1,20 @@
+/*
+ * Written by Ulrich Drepper <drepper@gmail.com>.
+ */
+
+/*
+ * __isinf_nsf(x) returns != 0 if x is ±inf, else 0;
+ * no branching!
+ */
+
+#include "math.h"
+#include "math_private.h"
+
+#undef __isinf_nsf
+int
+__isinf_nsf (float x)
+{
+       int32_t ix,t;
+       GET_FLOAT_WORD(ix,x);
+       return (ix & 0x7fffffff) == 0x7f800000;
+}
index 4ac16c2b5f11e5688f18ea345096925ed9bb406f..1b1b2475b9417d66eaa38e4ccbb630bf247f225c 100644 (file)
@@ -4,7 +4,7 @@
 
 /*
  * ====================================================
- * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
+ * Copyright (C) 1993, 2011 by Sun Microsystems, Inc. All rights reserved.
  *
  * Developed at SunPro, a Sun Microsystems, Inc. business.
  * Permission to use, copy, modify, and distribute this
@@ -25,6 +25,7 @@ static char rcsid[] = "$NetBSD: s_isnanf.c,v 1.4 1995/05/10 20:47:38 jtc Exp $";
 #include "math.h"
 #include "math_private.h"
 
+#undef __isnanf
 #ifdef __STDC__
        int __isnanf(float x)
 #else
diff --git a/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c b/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c
new file mode 100644 (file)
index 0000000..1ebc1ac
--- /dev/null
@@ -0,0 +1,19 @@
+/*
+ * Written by Ulrich Drepper <drepper@gmail.com>
+ */
+
+/*
+ * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
+ * no branching!
+ */
+
+#include "math.h"
+#include "math_private.h"
+
+int
+__isinf_nsl (long double x)
+{
+       int64_t hx,lx;
+       GET_LDOUBLE_WORDS64(hx,lx,x);
+       return !(lx | ((hx & 0x7fffffffffffffffLL) ^ 0x7fff000000000000LL));
+}
diff --git a/sysdeps/ieee754/ldbl-96/s_isinf_nsl.c b/sysdeps/ieee754/ldbl-96/s_isinf_nsl.c
new file mode 100644 (file)
index 0000000..aa59030
--- /dev/null
@@ -0,0 +1,18 @@
+/*
+ * Written by Ulrich Drepper <drepper@gmail.com>.
+ */
+
+/*
+ * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
+ */
+
+#include "math.h"
+#include "math_private.h"
+
+int
+__isinf_nsl (long double x)
+{
+       int32_t se,hx,lx;
+       GET_LDOUBLE_WORDS(se,hx,lx,x);
+       return !(((se & 0x7fff) ^ 0x7fff) | lx | (hx & 0x7fffffff));
+}
index 4be753654a52ef24e15cf549e7f6c0bb13f2811c..37357d317ac139913354ec7d1d3707ce1cbcc569 100644 (file)
@@ -56,3 +56,24 @@ do {                                                         \
 } while (0)
 
 #endif
+
+#define __isnan(d) \
+  ({ long int __di; EXTRACT_WORDS64 (__di, d);                               \
+     (__di & 0x7fffffffffffffffl) > 0x7ff0000000000000l; })
+#define __isnanf(d) \
+  ({ int __di; GET_FLOAT_WORD (__di, d);                                     \
+     (__di & 0x7fffffff) > 0x7f800000; })
+
+#define __isinf_ns(d) \
+  ({ long int __di; EXTRACT_WORDS64 (__di, d);                               \
+     (__di & 0x7fffffffffffffffl) == 0x7ff0000000000000l; })
+#define __isinf_nsf(d) \
+  ({ int __di; GET_FLOAT_WORD (__di, d);                                     \
+     (__di & 0x7fffffff) == 0x7f800000; })
+
+#define __finite(d) \
+  ({ long int __di; EXTRACT_WORDS64 (__di, d);                               \
+     (__di & 0x7fffffffffffffffl) < 0x7ff0000000000000l; })
+#define __finitef(d) \
+  ({ int __di; GET_FLOAT_WORD (__di, d);                                     \
+     (__di & 0x7fffffff) < 0x7f800000; })
This page took 0.091823 seconds and 5 git commands to generate.