summaryrefslogtreecommitdiff
path: root/gcc/except.c
diff options
context:
space:
mode:
authorkenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4>2001-11-17 17:33:57 +0000
committerkenner <kenner@138bc75d-0d04-0410-961f-82ee72b054a4>2001-11-17 17:33:57 +0000
commit5461f9e4411aa74f3018cba2e648258d6c7dcca8 (patch)
treee261e44560d70ac49d4a875324ea54d394781d6a /gcc/except.c
parent3880bb1e0365ee4820d29af6c00bfa1b03f50cb1 (diff)
downloadgcc-5461f9e4411aa74f3018cba2e648258d6c7dcca8.tar.gz
* except.c (enum eh_region_type): Add ERT_UNKNOWN.
(mark_eh_region, case ERT_UKNONW): New case. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@47123 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/except.c')
-rw-r--r--gcc/except.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/gcc/except.c b/gcc/except.c
index 7ddb80734e8..ad9b9f57644 100644
--- a/gcc/except.c
+++ b/gcc/except.c
@@ -128,7 +128,8 @@ struct eh_region
/* Each region does exactly one thing. */
enum eh_region_type
{
- ERT_CLEANUP = 1,
+ ERT_UNKNOWN = 0,
+ ERT_CLEANUP,
ERT_TRY,
ERT_CATCH,
ERT_ALLOWED_EXCEPTIONS,
@@ -478,6 +479,10 @@ mark_eh_region (region)
switch (region->type)
{
+ case ERT_UNKNOWN:
+ /* This can happen if a nested function is inside the body of a region
+ and we do a GC as part of processing it. */
+ break;
case ERT_CLEANUP:
ggc_mark_tree (region->u.cleanup.exp);
break;