]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Ignore -Wmaybe-uninitialized in stdlib/bug-getcontext.c.
authorJoseph Myers <joseph@codesourcery.com>
Fri, 11 Nov 2016 21:05:51 +0000 (21:05 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Fri, 11 Nov 2016 21:05:51 +0000 (21:05 +0000)
Doing all-ABIs compile testing produces a compiler warning in
stdlib/bug-getcontext.c on nios2 and tilepro (with GCC 5 branch):

bug-getcontext.c: In function 'do_test':
bug-getcontext.c:53:6: error: 'except_mask' may be used uninitialized in this function [-Werror=maybe-uninitialized]
   if (mask != except_mask)
      ^

This warning appears nonsensical; except_mask is initialized where
it's declared.  I think what must be happening here is that the
compiler is confused by the returns-twice nature of getcontext: if
there were a call to setcontext, local variables could indeed have
lost their values on the second return from getcontext.  This patch
duly uses the DIAG_* macros to disable the warning here.

Tested for nios2 and tilepro (compilation only; after this patch all
the tests compile, though there are other failures) and x86_64 (full
testsuite run).

* stdlib/bug-getcontext.c: Include <libc-internal.h>.
(do_test): Disable -Wmaybe-uninitialized around uses of
except_mask.

ChangeLog
stdlib/bug-getcontext.c

index 7c725856d899c43220d6b8a6e22e851a348a5d08..95f983ff49a5fa27dc1e94e1e6f1d55e6ea46d74 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 2016-11-11  Joseph Myers  <joseph@codesourcery.com>
 
+       * stdlib/bug-getcontext.c: Include <libc-internal.h>.
+       (do_test): Disable -Wmaybe-uninitialized around uses of
+       except_mask.
+
        * sysdeps/unix/sysv/linux/sh/sys/user.h: Include <stddef.h>.
 
 2016-11-10  Chris Metcalf  <cmetcalf@mellanox.com>
index 133ee91eff8e27846d32df1a95624eedbf94eaeb..c4072129a6828143888437fb835d9b2f21f2d73c 100644 (file)
@@ -5,6 +5,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <ucontext.h>
+#include <libc-internal.h>
 
 static int
 do_test (void)
@@ -49,6 +50,13 @@ do_test (void)
   printf ("\nDone with getcontext()!\n");
   fflush (NULL);
 
+  /* On nios2 and tilepro, GCC 5 warns that except_mask may be used
+     uninitialized.  Because it is always initialized and nothing in
+     this test ever calls setcontext (a setcontext call could result
+     in local variables being clobbered on the second return from
+     getcontext), in fact an uninitialized use is not possible.  */
+  DIAG_PUSH_NEEDS_COMMENT;
+  DIAG_IGNORE_NEEDS_COMMENT (5, "-Wmaybe-uninitialized");
   int mask = fegetexcept ();
   if (mask != except_mask)
     {
@@ -59,6 +67,7 @@ do_test (void)
 
   printf("\nAt end fegetexcept() returned %d, expected: %d.\n",
         mask, except_mask);
+  DIAG_POP_NEEDS_COMMENT;
 
   return 0;
 }