aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/decl2.c3
-rw-r--r--gcc/cp/tree.c9
3 files changed, 18 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 3c3112d..ca8ea06 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2003-09-02 Geoffrey Keating <geoffk@apple.com>
+
+ PR 12161
+ * decl2.c (mark_used): Use ggc_push_context/ggc_pop_context.
+ * tree.c (cp_cannot_inline_tree_fn): Likewise.
+
2003-09-04 Nathan Sidwell <nathan@codesourcery.com>
* cp-tree.h (finish_sizeof, finish_alignof): Remove.
diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c
index d74f290..7ca20c8 100644
--- a/gcc/cp/decl2.c
+++ b/gcc/cp/decl2.c
@@ -4226,7 +4226,10 @@ mark_used (tree decl)
information. */
|| cp_function_chain->can_throw);
+ /* Our caller is likely to have lots of data on the stack. */
+ ggc_push_context ();
instantiate_decl (decl, defer);
+ ggc_pop_context ();
}
}
diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c
index 71742a7..1dddad4 100644
--- a/gcc/cp/tree.c
+++ b/gcc/cp/tree.c
@@ -1992,7 +1992,16 @@ cp_cannot_inline_tree_fn (tree* fnp)
if (!DECL_INLINE (DECL_TEMPLATE_RESULT
(template_for_substitution (fn))))
return 1;
+
+ /* Our caller does not expect us to call ggc_collect, but
+ instantiate_decl can call rest_of_compilation so we must
+ protect our caller. */
+ ggc_push_context();
+
fn = *fnp = instantiate_decl (fn, /*defer_ok=*/0);
+
+ ggc_pop_context();
+
if (TI_PENDING_TEMPLATE_FLAG (DECL_TEMPLATE_INFO (fn)))
return 1;
}