Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/libm/src Appease static analyzers by making all code pat...



details:   https://anonhg.NetBSD.org/src/rev/9d2f204f43e4
branches:  trunk
changeset: 351325:9d2f204f43e4
user:      maya <maya%NetBSD.org@localhost>
date:      Thu Feb 09 21:23:11 2017 +0000

description:
Appease static analyzers by making all code paths which assign
values into p,q sane. Get rid of redundant assignment. Indent
for legibility. NFC.

This doesn't create a functional difference, as all callers
test number >= 0x40000000 anyway.

To see this, note the following:
- consistently, hx is the high bits of x, lx is the low bits,
  x is the float.
- & 0x7fffffff zeroes the sign bit, as does fabs.

A case where it isn't easy to see that there's no functional
change is y1, which does:

ix = hx & 0x7fffffff (zero signbit of high bits of x)
y = fabs(x) (this has a zeroed signbit but otherwise same as x)
ix >= 0x40000000
  pone(y); qone(y)

qone(x) (also pone) do:
  ix = hx & 0x7fffffff

ix in qone and in the calling function are the same number,
and the comparison applies for both, and ix < 0x40000000 isn't
possible.

(Also, no explosions seem to happen when I feed it random numbers)

diffstat:

 lib/libm/src/e_j0.c  |  20 +++++++++-----------
 lib/libm/src/e_j0f.c |  20 +++++++++-----------
 lib/libm/src/e_j1.c  |  20 +++++++++-----------
 lib/libm/src/e_j1f.c |  20 +++++++++-----------
 4 files changed, 36 insertions(+), 44 deletions(-)

diffs (196 lines):

diff -r a903ac534e65 -r 9d2f204f43e4 lib/libm/src/e_j0.c
--- a/lib/libm/src/e_j0.c       Thu Feb 09 20:42:30 2017 +0000
+++ b/lib/libm/src/e_j0.c       Thu Feb 09 21:23:11 2017 +0000
@@ -12,7 +12,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBM_SCCS) && !defined(lint)
-__RCSID("$NetBSD: e_j0.c,v 1.12 2007/08/20 16:01:38 drochner Exp $");
+__RCSID("$NetBSD: e_j0.c,v 1.13 2017/02/09 21:23:11 maya Exp $");
 #endif
 
 /* __ieee754_j0(x), __ieee754_y0(x)
@@ -277,13 +277,12 @@
        double z,r,s;
        int32_t ix;
 
-       p = q = 0;
        GET_HIGH_WORD(ix,x);
        ix &= 0x7fffffff;
-       if(ix>=0x40200000)     {p = pR8; q= pS8;}
-       else if(ix>=0x40122E8B){p = pR5; q= pS5;}
-       else if(ix>=0x4006DB6D){p = pR3; q= pS3;}
-       else if(ix>=0x40000000){p = pR2; q= pS2;}
+       if(ix>=0x40200000)         {p = pR8; q= pS8;}
+       else if(ix>=0x40122E8B)    {p = pR5; q= pS5;}
+       else if(ix>=0x4006DB6D)    {p = pR3; q= pS3;}
+       else /*if(ix>=0x40000000)*/{p = pR2; q= pS2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*q[4]))));
@@ -375,13 +374,12 @@
        double s,r,z;
        int32_t ix;
 
-       p = q = 0;
        GET_HIGH_WORD(ix,x);
        ix &= 0x7fffffff;
-       if(ix>=0x40200000)     {p = qR8; q= qS8;}
-       else if(ix>=0x40122E8B){p = qR5; q= qS5;}
-       else if(ix>=0x4006DB6D){p = qR3; q= qS3;}
-       else if(ix>=0x40000000){p = qR2; q= qS2;}
+       if(ix>=0x40200000)         {p = qR8; q= qS8;}
+       else if(ix>=0x40122E8B)    {p = qR5; q= qS5;}
+       else if(ix>=0x4006DB6D)    {p = qR3; q= qS3;}
+       else /*if(ix>=0x40000000)*/{p = qR2; q= qS2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*(q[4]+z*q[5])))));
diff -r a903ac534e65 -r 9d2f204f43e4 lib/libm/src/e_j0f.c
--- a/lib/libm/src/e_j0f.c      Thu Feb 09 20:42:30 2017 +0000
+++ b/lib/libm/src/e_j0f.c      Thu Feb 09 21:23:11 2017 +0000
@@ -15,7 +15,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBM_SCCS) && !defined(lint)
-__RCSID("$NetBSD: e_j0f.c,v 1.10 2007/08/20 16:01:38 drochner Exp $");
+__RCSID("$NetBSD: e_j0f.c,v 1.11 2017/02/09 21:23:11 maya Exp $");
 #endif
 
 #include "namespace.h"
@@ -240,13 +240,12 @@
        float z,r,s;
        int32_t ix;
 
-       p = q = 0;
        GET_FLOAT_WORD(ix,x);
        ix &= 0x7fffffff;
-       if(ix>=0x41000000)     {p = pR8; q= pS8;}
-       else if(ix>=0x40f71c58){p = pR5; q= pS5;}
-       else if(ix>=0x4036db68){p = pR3; q= pS3;}
-       else if(ix>=0x40000000){p = pR2; q= pS2;}
+       if(ix>=0x41000000)         {p = pR8; q= pS8;}
+       else if(ix>=0x40f71c58)    {p = pR5; q= pS5;}
+       else if(ix>=0x4036db68)    {p = pR3; q= pS3;}
+       else /*if(ix>=0x40000000)*/{p = pR2; q= pS2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*q[4]))));
@@ -338,13 +337,12 @@
        float s,r,z;
        int32_t ix;
 
-       p = q = 0;
        GET_FLOAT_WORD(ix,x);
        ix &= 0x7fffffff;
-       if(ix>=0x41000000)     {p = qR8; q= qS8;}
-       else if(ix>=0x40f71c58){p = qR5; q= qS5;}
-       else if(ix>=0x4036db68){p = qR3; q= qS3;}
-       else if(ix>=0x40000000){p = qR2; q= qS2;}
+       if(ix>=0x41000000)         {p = qR8; q= qS8;}
+       else if(ix>=0x40f71c58)    {p = qR5; q= qS5;}
+       else if(ix>=0x4036db68)    {p = qR3; q= qS3;}
+       else /*if(ix>=0x40000000)*/{p = qR2; q= qS2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*(q[4]+z*q[5])))));
diff -r a903ac534e65 -r 9d2f204f43e4 lib/libm/src/e_j1.c
--- a/lib/libm/src/e_j1.c       Thu Feb 09 20:42:30 2017 +0000
+++ b/lib/libm/src/e_j1.c       Thu Feb 09 21:23:11 2017 +0000
@@ -12,7 +12,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBM_SCCS) && !defined(lint)
-__RCSID("$NetBSD: e_j1.c,v 1.12 2007/08/20 16:01:38 drochner Exp $");
+__RCSID("$NetBSD: e_j1.c,v 1.13 2017/02/09 21:23:11 maya Exp $");
 #endif
 
 /* __ieee754_j1(x), __ieee754_y1(x)
@@ -271,13 +271,12 @@
        double z,r,s;
         int32_t ix;
 
-       p = q = 0;
        GET_HIGH_WORD(ix,x);
        ix &= 0x7fffffff;
-        if(ix>=0x40200000)     {p = pr8; q= ps8;}
-        else if(ix>=0x40122E8B){p = pr5; q= ps5;}
-        else if(ix>=0x4006DB6D){p = pr3; q= ps3;}
-        else if(ix>=0x40000000){p = pr2; q= ps2;}
+        if(ix>=0x40200000)         {p = pr8; q= ps8;}
+        else if(ix>=0x40122E8B)    {p = pr5; q= ps5;}
+        else if(ix>=0x4006DB6D)    {p = pr3; q= ps3;}
+        else /*if(ix>=0x40000000)*/{p = pr2; q= ps2;}
         z = one/(x*x);
         r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
         s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*q[4]))));
@@ -370,13 +369,12 @@
        double  s,r,z;
        int32_t ix;
 
-       p = q = 0;
        GET_HIGH_WORD(ix,x);
        ix &= 0x7fffffff;
-       if(ix>=0x40200000)     {p = qr8; q= qs8;}
-       else if(ix>=0x40122E8B){p = qr5; q= qs5;}
-       else if(ix>=0x4006DB6D){p = qr3; q= qs3;}
-       else if(ix>=0x40000000){p = qr2; q= qs2;}
+       if(ix>=0x40200000)         {p = qr8; q= qs8;}
+       else if(ix>=0x40122E8B)    {p = qr5; q= qs5;}
+       else if(ix>=0x4006DB6D)    {p = qr3; q= qs3;}
+       else /*if(ix>=0x40000000)*/{p = qr2; q= qs2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*(q[4]+z*q[5])))));
diff -r a903ac534e65 -r 9d2f204f43e4 lib/libm/src/e_j1f.c
--- a/lib/libm/src/e_j1f.c      Thu Feb 09 20:42:30 2017 +0000
+++ b/lib/libm/src/e_j1f.c      Thu Feb 09 21:23:11 2017 +0000
@@ -15,7 +15,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBM_SCCS) && !defined(lint)
-__RCSID("$NetBSD: e_j1f.c,v 1.11 2007/08/20 16:01:38 drochner Exp $");
+__RCSID("$NetBSD: e_j1f.c,v 1.12 2017/02/09 21:23:11 maya Exp $");
 #endif
 
 #include "namespace.h"
@@ -232,13 +232,12 @@
        float z,r,s;
         int32_t ix;
 
-       p = q = 0;
        GET_FLOAT_WORD(ix,x);
        ix &= 0x7fffffff;
-        if(ix>=0x41000000)     {p = pr8; q= ps8;}
-        else if(ix>=0x40f71c58){p = pr5; q= ps5;}
-        else if(ix>=0x4036db68){p = pr3; q= ps3;}
-        else if(ix>=0x40000000){p = pr2; q= ps2;}
+        if(ix>=0x41000000)         {p = pr8; q= ps8;}
+        else if(ix>=0x40f71c58)    {p = pr5; q= ps5;}
+        else if(ix>=0x4036db68)    {p = pr3; q= ps3;}
+        else /*if(ix>=0x40000000)*/{p = pr2; q= ps2;}
         z = one/(x*x);
         r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
         s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*q[4]))));
@@ -331,17 +330,16 @@
        float  s,r,z;
        int32_t ix;
 
-       p = q = 0;
        GET_FLOAT_WORD(ix,x);
        ix &= 0x7fffffff;
        /* [inf, 8]             (8      41000000) */
-       if(ix>=0x41000000)     {p = qr8; q= qs8;}
+       if(ix>=0x41000000)         {p = qr8; q= qs8;}
        /* [8, 4.5454]          (4.5454 409173eb) */
-       else if(ix>=0x409173eb){p = qr5; q= qs5;}
+       else if(ix>=0x409173eb)    {p = qr5; q= qs5;}
        /* [4.5454, 2.8570]     (2.8570 4036d917) */
-       else if(ix>=0x4036d917){p = qr3; q= qs3;}
+       else if(ix>=0x4036d917)    {p = qr3; q= qs3;}
        /* [2.8570, 2]          (2      40000000) */
-       else if(ix>=0x40000000){p = qr2; q= qs2;}
+       else /*if(ix>=0x40000000)*/{p = qr2; q= qs2;}
        z = one/(x*x);
        r = p[0]+z*(p[1]+z*(p[2]+z*(p[3]+z*(p[4]+z*p[5]))));
        s = one+z*(q[0]+z*(q[1]+z*(q[2]+z*(q[3]+z*(q[4]+z*q[5])))));



Home | Main Index | Thread Index | Old Index