From b1762aa23a99a928306a7ec172f343ccfc71917c Mon Sep 17 00:00:00 2001 From: rth Date: Mon, 8 Sep 2003 16:54:13 +0000 Subject: * optimize.c (maybe_clone_body): Inc/dec function_depth. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@71210 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 4 ++++ gcc/cp/optimize.c | 7 +++++++ 2 files changed, 11 insertions(+) (limited to 'gcc/cp') diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index b3a27e89ef5..13a5c55a718 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -4,6 +4,10 @@ * pt.c (try_one_overload): Add addr_p parameter. (resolve_overloaded_unification): Pass it. +2003-09-08 Richard Henderson + + * optimize.c (maybe_clone_body): Inc/dec function_depth. + 2003-09-08 Richard Henderson * decl.c (finish_function): Clear current_function_decl. diff --git a/gcc/cp/optimize.c b/gcc/cp/optimize.c index bcb74e4917f..3204311ea7d 100644 --- a/gcc/cp/optimize.c +++ b/gcc/cp/optimize.c @@ -130,6 +130,11 @@ maybe_clone_body (tree fn) /* Emit the DWARF1 abstract instance. */ (*debug_hooks->deferred_inline_function) (fn); + /* Our caller does not expect collection to happen, which it might if + we decide to compile the function to rtl now. Arrange for a new + gc context to be created if so. */ + function_depth++; + /* We know that any clones immediately follow FN in the TYPE_METHODS list. */ for (clone = TREE_CHAIN (fn); @@ -253,6 +258,8 @@ maybe_clone_body (tree fn) pop_from_top_level (); } + function_depth--; + /* We don't need to process the original function any further. */ return 1; } -- cgit v1.2.1