aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2013-04-26 15:14:55 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2013-04-26 15:14:55 +0200
commite7d764f367fdd7b0e9c96ae8c5d8503dbc90c05e (patch)
tree166638c2234eb83d2a4b427d3c801fe8c44a5067
parent41e106896a657b1a5276559f243c9cfe39c67f83 (diff)
downloadgcc-e7d764f367fdd7b0e9c96ae8c5d8503dbc90c05e.zip
gcc-e7d764f367fdd7b0e9c96ae8c5d8503dbc90c05e.tar.gz
gcc-e7d764f367fdd7b0e9c96ae8c5d8503dbc90c05e.tar.bz2
re PR go/57045 (Build failure in libgo/runtime/proc.c: error: ‘({anonymous})’ may be used uninitialized in this function)
PR go/57045 * tree-ssa-uninit.c (compute_uninit_opnds_pos): In functions with nonlocal goto receivers or returns twice calls, ignore unininitialized values from abnormal edges to nl goto receiver or returns twice call. * gcc.dg/setjmp-5.c: New test. From-SVN: r198340
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/setjmp-5.c22
-rw-r--r--gcc/tree-ssa-uninit.c16
4 files changed, 50 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index bd5c8f1..47d1bcc 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,13 @@
2013-04-26 Jakub Jelinek <jakub@redhat.com>
+ PR go/57045
+ * tree-ssa-uninit.c (compute_uninit_opnds_pos): In functions
+ with nonlocal goto receivers or returns twice calls, ignore
+ unininitialized values from abnormal edges to nl goto receiver
+ or returns twice call.
+
+2013-04-26 Jakub Jelinek <jakub@redhat.com>
+
PR tree-optimization/57051
* fold-const.c (const_binop): Handle VEC_LSHIFT_EXPR
and VEC_RSHIFT_EXPR if shift count is a multiple of element
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1081ef9..bbea9fa 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2013-04-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR go/57045
+ * gcc.dg/setjmp-5.c: New test.
+
2013-04-26 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/55708
diff --git a/gcc/testsuite/gcc.dg/setjmp-5.c b/gcc/testsuite/gcc.dg/setjmp-5.c
new file mode 100644
index 0000000..c6e5f93
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/setjmp-5.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -Wall" } */
+
+#include <setjmp.h>
+
+void bar (int);
+
+jmp_buf buf;
+int v;
+
+void
+foo (void)
+{
+ int i;
+ bar (0);
+ bar (1);
+ i = 5;
+ int j = setjmp (buf);
+ if (j == 0)
+ bar (2);
+ v = i; /* { dg-bogus "may be used uninitialized in this function" } */
+}
diff --git a/gcc/tree-ssa-uninit.c b/gcc/tree-ssa-uninit.c
index e8f3ff7..2cb22b7 100644
--- a/gcc/tree-ssa-uninit.c
+++ b/gcc/tree-ssa-uninit.c
@@ -151,7 +151,21 @@ compute_uninit_opnds_pos (gimple phi)
if (TREE_CODE (op) == SSA_NAME
&& ssa_undefined_value_p (op)
&& !can_skip_redundant_opnd (op, phi))
- MASK_SET_BIT (uninit_opnds, i);
+ {
+ /* Ignore SSA_NAMEs on abnormal edges to setjmp
+ or nonlocal goto receiver. */
+ if (cfun->has_nonlocal_label || cfun->calls_setjmp)
+ {
+ edge e = gimple_phi_arg_edge (phi, i);
+ if (e->flags & EDGE_ABNORMAL)
+ {
+ gimple last = last_stmt (e->src);
+ if (last && stmt_can_make_abnormal_goto (last))
+ continue;
+ }
+ }
+ MASK_SET_BIT (uninit_opnds, i);
+ }
}
return uninit_opnds;
}