From a17097692bf3ee04a30b9f190c160e93160a7aa0 Mon Sep 17 00:00:00 2001
From: Kaz Kojima <kkojima@gcc.gnu.org>
Date: Sun, 14 May 2006 22:51:12 +0000
Subject: [PATCH] re PR rtl-optimization/27406
 (gcc.c-torture/execute/built-in-setjmp.c fails on sh64-*-linux-gnu with -O2)

	PR rtl-optimization/27406
	* bt-load.c (migrate_btr_def): Skip the block having abnormal
	edges.

From-SVN: r113766
---
 gcc/ChangeLog | 6 ++++++
 gcc/bt-load.c | 9 +++++++++
 2 files changed, 15 insertions(+)

diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c5ed8fc4ce5e..80a3571bc368 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2006-05-14  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+	PR rtl-optimization/27406
+	* bt-load.c (migrate_btr_def): Skip the block having abnormal
+	edges.
+
 2006-05-14  Roger Sayle  <roger@eyesopen.com>
 
 	PR rtl-optimization/27538
diff --git a/gcc/bt-load.c b/gcc/bt-load.c
index 70975e4318d7..88a680627ad7 100644
--- a/gcc/bt-load.c
+++ b/gcc/bt-load.c
@@ -1339,6 +1339,15 @@ migrate_btr_def (btr_def def, int min_cost)
       /* Try to move the instruction that sets the target register into
 	 basic block TRY.  */
       int try_freq = basic_block_freq (try);
+      edge_iterator ei;
+      edge e;
+
+      /* If TRY has abnormal edges, skip it.  */
+      FOR_EACH_EDGE (e, ei, try->succs)
+	if (e->flags & EDGE_COMPLEX)
+	  break;
+      if (e)
+	continue;
 
       if (dump_file)
 	fprintf (dump_file, "trying block %d ...", try->index);
-- 
GitLab