From b067035bede9b58e4e17c9acb0f65ac1faad41a8 Mon Sep 17 00:00:00 2001
From: rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Date: Thu, 8 Oct 1998 17:01:01 +0000
Subject: [PATCH]         * flow.c (find_basic_blocks): Correctly determine
 when a call         is within an exception region.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@22928 138bc75d-0d04-0410-961f-82ee72b054a4
---
 gcc/ChangeLog | 5 +++++
 gcc/flow.c    | 7 ++++++-
 2 files changed, 11 insertions(+), 1 deletion(-)

diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 30e39a44b4f3..ecd9e053b848 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+Thu Oct  8 17:00:18 1998  Richard Henderson  <rth@cygnus.com>
+
+	* flow.c (find_basic_blocks): Correctly determine when a call
+	is within an exception region.
+
 Thu Oct  8 17:15:04 1998  Jeffrey A Law  (law@cygnus.com)
 
 	* Makefile.in (cpplib.o): Use unlibsubdir.
diff --git a/gcc/flow.c b/gcc/flow.c
index 773aaf2be969..bbf21f1584fc 100644
--- a/gcc/flow.c
+++ b/gcc/flow.c
@@ -314,6 +314,7 @@ find_basic_blocks (f, nregs, file, live_reachable_p)
     register RTX_CODE prev_code = JUMP_INSN;
     register RTX_CODE code;
     int eh_region = 0;
+    int call_had_abnormal_edge = 0;
 
     max_uid_for_flow = 0;
 
@@ -335,7 +336,7 @@ find_basic_blocks (f, nregs, file, live_reachable_p)
 	      i++;
 	    else if (prev_code == CALL_INSN)
 	      {
-		if (nonlocal_label_list != 0 || eh_region)
+		if (call_had_abnormal_edge)
 		  i++;
 		else
 		  {
@@ -360,6 +361,10 @@ find_basic_blocks (f, nregs, file, live_reachable_p)
 	if (code == CALL_INSN && in_libcall_block)
 	  code = INSN;
 
+        /* Record whether this call created an edge.  */
+        if (code == CALL_INSN)
+	  call_had_abnormal_edge = (nonlocal_label_list != 0 || eh_region);
+
 	if (code != NOTE)
 	  prev_code = code;
 	else if (NOTE_LINE_NUMBER (insn) == NOTE_INSN_EH_REGION_BEG)
-- 
GitLab