aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-inline.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2010-07-27 11:43:59 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2010-07-27 11:43:59 +0200
commit42694189bdade115459859e898e0b78d1cdb033c (patch)
treed49c593577aa11f679a1d71ee4a109af2cc62c65 /gcc/tree-inline.c
parent2b0cb007fa96ea4ea95de5505cfe481b2aedcf80 (diff)
downloadgcc-42694189bdade115459859e898e0b78d1cdb033c.zip
gcc-42694189bdade115459859e898e0b78d1cdb033c.tar.gz
gcc-42694189bdade115459859e898e0b78d1cdb033c.tar.bz2
re PR tree-optimization/45083 (strange warning text from gcc)
PR tree-optimization/45083 * tree-inline.c (add_local_variables): Also remap DECL_DEBUG_EXPR. * gcc.dg/pr45083.c: New test. From-SVN: r162559
Diffstat (limited to 'gcc/tree-inline.c')
-rw-r--r--gcc/tree-inline.c19
1 files changed, 18 insertions, 1 deletions
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