summaryrefslogtreecommitdiff
path: root/gcc/tree-inline.c
diff options
context:
space:
mode:
authorAlexandre Oliva <aoliva@redhat.com>2001-10-26 08:05:08 +0000
committerAlexandre Oliva <aoliva@gcc.gnu.org>2001-10-26 08:05:08 +0000
commit350ebd54938a632a703636bbb323f62e51471f18 (patch)
treecfe07bea6bb16ce7c1fb93015c4dcaee7c859776 /gcc/tree-inline.c
parentb73c0bc87d961344377a72a3ddfdadf5695eae66 (diff)
downloadgcc-350ebd54938a632a703636bbb323f62e51471f18.tar.gz
tree-inline.c (remap_decl): Don't copy size and size_unit here.
* tree-inline.c (remap_decl): Don't copy size and size_unit here. (remap_save_expr): Map a remapped SAVE_EXPR to error_mark_node. From-SVN: r46536
Diffstat (limited to 'gcc/tree-inline.c')
-rw-r--r--gcc/tree-inline.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c
index 5e2c3c47f24..25d0964ec02 100644
--- a/gcc/tree-inline.c
+++ b/gcc/tree-inline.c
@@ -147,8 +147,6 @@ remap_decl (decl, id)
/* The decl T could be a dynamic array or other variable size type,
in which case some fields need to be remapped because they may
contain SAVE_EXPRs. */
- walk_tree (&DECL_SIZE (t), copy_body_r, id, NULL);
- walk_tree (&DECL_SIZE_UNIT (t), copy_body_r, id, NULL);
if (TREE_TYPE (t) && TREE_CODE (TREE_TYPE (t)) == ARRAY_TYPE
&& TYPE_DOMAIN (TREE_TYPE (t)))
{
@@ -1373,6 +1371,9 @@ remap_save_expr (tp, st_, fn, walk_subtrees)
n = splay_tree_insert (st,
(splay_tree_key) *tp,
(splay_tree_value) t);
+ /* Make sure we don't remap an already-remapped SAVE_EXPR. */
+ splay_tree_insert (st, (splay_tree_key) t,
+ (splay_tree_value) error_mark_node);
}
else
/* We've already walked into this SAVE_EXPR, so we needn't do it