]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix soft-fp fma for -Wuninitialized.
authorJoseph Myers <joseph@codesourcery.com>
Fri, 22 May 2015 20:28:50 +0000 (20:28 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Fri, 22 May 2015 20:28:50 +0000 (20:28 +0000)
The soft-fp implementations of fma produce -Wuninitialized warnings
because, in the cases where the result is not a nonzero finite value,
the soft-fp does not set the exponent of the result since the (cooked)
packing will do so, but the compiler does not then see that the
exponent is always set in packing before it's used if it wasn't set
earlier.  This patch uses DIAG_* macros to suppress those warnings.

Tested for mips64.  (In fact this allows the mips64 build to complete
with the -Wno-uninitialized removed from math/Makefile, but more
cleanups are still needed in the ldbl-128ibm code for uninitialized
warnings there.)

* soft-fp/fmadf4.c: Include <libc-internal.h>.
(__fma): Ignore uninitialized warnings around packing.
* soft-fp/fmasf4.c: Include <libc-internal.h>.
(__fmaf): Ignore uninitialized warnings around packing.
* soft-fp/fmatf4.c: Include <libc-internal.h>.
(__fmal): Ignore uninitialized warnings around packing.

ChangeLog
soft-fp/fmadf4.c
soft-fp/fmasf4.c
soft-fp/fmatf4.c

index 159eb4ab6fba5bce2e590493d386198bcb5008d3..94945920de5a1c67e6c36c56353dfc92ee222826 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
 2015-05-22  Joseph Myers  <joseph@codesourcery.com>
 
+       * soft-fp/fmadf4.c: Include <libc-internal.h>.
+       (__fma): Ignore uninitialized warnings around packing.
+       * soft-fp/fmasf4.c: Include <libc-internal.h>.
+       (__fmaf): Ignore uninitialized warnings around packing.
+       * soft-fp/fmatf4.c: Include <libc-internal.h>.
+       (__fmal): Ignore uninitialized warnings around packing.
+
        * sysdeps/ieee754/ldbl-128/k_tanl.c: Include <libc-internal.h>.
        (__kernel_tanl): Ignore uninitialized warnings around use of SIGN.
        * sysdeps/ieee754/ldbl-128ibm/k_tanl.c: Include <libc-internal.h>.
index 1a720ba0201eb5fab761b5f12c9edcfa1cf51aa2..da6749d0ece7fd9db57c58293acf941e991554fa 100644 (file)
@@ -25,6 +25,7 @@
    License along with the GNU C Library; if not, see
    <http://www.gnu.org/licenses/>.  */
 
+#include <libc-internal.h>
 #include <math.h>
 #include "soft-fp.h"
 #include "double.h"
@@ -44,7 +45,18 @@ __fma (double a, double b, double c)
   FP_UNPACK_D (B, b);
   FP_UNPACK_D (C, c);
   FP_FMA_D (R, A, B, C);
+  /* R_e is not set in cases where it is not used in packing, but the
+     compiler does not see that it is set in all cases where it is
+     used, resulting in warnings that it may be used
+     uninitialized.  */
+  DIAG_PUSH_NEEDS_COMMENT;
+#if __GNUC_PREREQ (4, 7)
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wmaybe-uninitialized");
+#else
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wuninitialized");
+#endif
   FP_PACK_D (r, R);
+  DIAG_POP_NEEDS_COMMENT;
   FP_HANDLE_EXCEPTIONS;
 
   return r;
index 03855a36ffe7964bcbddd8375293f66171395f96..b770a0719f3fcd398a890a8cc176bb01dbafb7f3 100644 (file)
@@ -25,6 +25,7 @@
    License along with the GNU C Library; if not, see
    <http://www.gnu.org/licenses/>.  */
 
+#include <libc-internal.h>
 #include <math.h>
 #include "soft-fp.h"
 #include "single.h"
@@ -44,7 +45,18 @@ __fmaf (float a, float b, float c)
   FP_UNPACK_S (B, b);
   FP_UNPACK_S (C, c);
   FP_FMA_S (R, A, B, C);
+  /* R_e is not set in cases where it is not used in packing, but the
+     compiler does not see that it is set in all cases where it is
+     used, resulting in warnings that it may be used
+     uninitialized.  */
+  DIAG_PUSH_NEEDS_COMMENT;
+#if __GNUC_PREREQ (4, 7)
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wmaybe-uninitialized");
+#else
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wuninitialized");
+#endif
   FP_PACK_S (r, R);
+  DIAG_POP_NEEDS_COMMENT;
   FP_HANDLE_EXCEPTIONS;
 
   return r;
index 16fd74c0467b12d2ba463ed31f1f38a03cde9a39..880961cfd1eedb41a38aa26b86b01487c894f6d3 100644 (file)
@@ -25,6 +25,7 @@
    License along with the GNU C Library; if not, see
    <http://www.gnu.org/licenses/>.  */
 
+#include <libc-internal.h>
 #include <math.h>
 #include "soft-fp.h"
 #include "quad.h"
@@ -44,7 +45,18 @@ __fmal (long double a, long double b, long double c)
   FP_UNPACK_Q (B, b);
   FP_UNPACK_Q (C, c);
   FP_FMA_Q (R, A, B, C);
+  /* R_e is not set in cases where it is not used in packing, but the
+     compiler does not see that it is set in all cases where it is
+     used, resulting in warnings that it may be used
+     uninitialized.  */
+  DIAG_PUSH_NEEDS_COMMENT;
+#if __GNUC_PREREQ (4, 7)
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wmaybe-uninitialized");
+#else
+  DIAG_IGNORE_NEEDS_COMMENT (4.9, "-Wuninitialized");
+#endif
   FP_PACK_Q (r, R);
+  DIAG_POP_NEEDS_COMMENT;
   FP_HANDLE_EXCEPTIONS;
 
   return r;