Hi!

As the following testcase shows, sometimes lp->landing_pad may be a
NOTE_DELETED_LABEL note and in that case
find_rarely_executed_basic_blocks_and_crossing_edges crashes.
for_each_eh_label in except.c does:
          rtx lab = lp->landing_pad;
          if (lab && LABEL_P (lab))
            (*callback) (lab);
so I think this isn't invalid and thus this patch does the same
during bb-reorder.  Bootstrapped/regtested on x86_64-linux and i686-linux,
ok for trunk?

2011-08-29  Jakub Jelinek  <ja...@redhat.com>

        PR rtl-optimization/50212
        * bb-reorder.c (find_rarely_executed_basic_blocks_and_crossing_edges):
        Skip also lps with NULL landing_pad or non-LABEL_P landing_pad.

        * g++.dg/other/pr50212.C: New test.

--- gcc/bb-reorder.c.jj 2011-07-25 11:28:32.000000000 +0200
+++ gcc/bb-reorder.c    2011-08-29 15:17:51.000000000 +0200
@@ -1,5 +1,5 @@
 /* Basic block reordering routines for the GNU compiler.
-   Copyright (C) 2000, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2010
+   Copyright (C) 2000, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2010, 2011
    Free Software Foundation, Inc.
 
    This file is part of GCC.
@@ -1315,7 +1315,9 @@ find_rarely_executed_basic_blocks_and_cr
        {
          bool all_same, all_diff;
 
-         if (lp == NULL)
+         if (lp == NULL
+             || lp->landing_pad == NULL_RTX
+             || !LABEL_P (lp->landing_pad))
            continue;
 
          all_same = all_diff = true;
--- gcc/testsuite/g++.dg/other/pr50212.C.jj     2011-08-29 15:24:02.000000000 
+0200
+++ gcc/testsuite/g++.dg/other/pr50212.C        2011-08-29 15:22:56.000000000 
+0200
@@ -0,0 +1,17 @@
+// PR rtl-optimization/50212
+// { dg-do compile }
+// { dg-require-effective-target freorder }
+// { dg-options "-O -fnon-call-exceptions -ftrapv 
-freorder-blocks-and-partition" }
+
+void
+foo (int n)
+{
+  try
+  {
+    int i = 0;
+    while (i++ < n);
+  }
+  catch (...)
+  {
+  }
+}

        Jakub

Reply via email to