aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr45083.c25
-rw-r--r--gcc/tree-inline.c19
4 files changed, 53 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6983da7..f9a1b2f 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2010-07-27 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/45083
+ * tree-inline.c (add_local_variables): Also remap DECL_DEBUG_EXPR.
+
2010-07-27 Bernd Schmidt <bernds@codesourcery.com>
* postreload.c (reload_combine_recognize_const_pattern): Move test
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 9ce3878..93bfc70 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-07-27 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/45083
+ * gcc.dg/pr45083.c: New test.
+
2010-07-26 Tobias Burnus <burnus@net-b.de>
PR fortran/40873
diff --git a/gcc/testsuite/gcc.dg/pr45083.c b/gcc/testsuite/gcc.dg/pr45083.c
new file mode 100644
index 0000000..c9a4dbf
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr45083.c
@@ -0,0 +1,25 @@
+/* PR tree-optimization/45083 */
+/* { dg-do compile } */
+/* { dg-options "-O2 -Wuninitialized" } */
+
+struct S { char *a; unsigned b; unsigned c; };
+extern int foo (const char *);
+extern void bar (int, int);
+
+static void
+baz (void)
+{
+ struct S cs[1]; /* { dg-message "was declared here" } */
+ switch (cs->b) /* { dg-warning "cs\[^\n\r\]*\\.b\[^\n\r\]*is used uninitialized" } */
+ {
+ case 101:
+ if (foo (cs->a)) /* { dg-warning "cs\[^\n\r\]*\\.a\[^\n\r\]*may be used uninitialized" } */
+ bar (cs->c, cs->b); /* { dg-warning "cs\[^\n\r\]*\\.c\[^\n\r\]*may be used uninitialized" } */
+ }
+}
+
+void
+test (void)
+{
+ baz ();
+}
diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c
index dc09c29..81d6cfb 100644
--- a/gcc/tree-inline.c
+++ b/gcc/tree-inline.c
@@ -3687,7 +3687,24 @@ add_local_variables (struct function *callee, struct function *caller,
add_local_decl (caller, var);
}
else if (!can_be_nonlocal (var, id))
- add_local_decl (caller, remap_decl (var, id));
+ {
+ tree new_var = remap_decl (var, id);
+
+ /* Remap debug-expressions. */
+ if (TREE_CODE (new_var) == VAR_DECL
+ && DECL_DEBUG_EXPR_IS_FROM (new_var)
+ && new_var != var)
+ {
+ tree tem = DECL_DEBUG_EXPR (var);
+ bool old_regimplify = id->regimplify;
+ id->remapping_type_depth++;
+ walk_tree (&tem, copy_tree_body_r, id, NULL);
+ id->remapping_type_depth--;
+ id->regimplify = old_regimplify;
+ SET_DECL_DEBUG_EXPR (new_var, tem);
+ }
+ add_local_decl (caller, new_var);
+ }
}
/* Fetch callee declaration from the call graph edge going from NODE and