OSDN Git Service

* bb-reorder.c (make_reorder_chain_1): Protect against
authordj <dj@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 22 Mar 2002 02:50:15 +0000 (02:50 +0000)
committerdj <dj@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 22 Mar 2002 02:50:15 +0000 (02:50 +0000)
when redundant edges are omitted.
* predict.c (dump_prediction): Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@51160 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/bb-reorder.c
gcc/predict.c

index bbdadd7..a975304 100644 (file)
@@ -1,3 +1,9 @@
+2002-03-21  DJ Delorie  <dj@redhat.com>
+
+       * bb-reorder.c (make_reorder_chain_1): Protect against
+       when redundant edges are omitted.
+       * predict.c (dump_prediction): Likewise.
+
 2002-03-21  Richard Henderson  <rth@redhat.com>
 
        PR target/5996
index 2578604..3647ad6 100644 (file)
@@ -205,7 +205,7 @@ make_reorder_chain_1 (bb, prev)
            e_taken = e;
        }
 
-      next = (taken ? e_taken : e_fall)->dest;
+      next = ((taken && e_taken) ? e_taken : e_fall)->dest;
     }
 
   /* In the absence of a prediction, disturb things as little as possible
index 61cfd63..56b0436 100644 (file)
@@ -194,7 +194,7 @@ dump_prediction (predictor, probability, bb, used)
   if (!rtl_dump_file)
     return;
 
-  while (e->flags & EDGE_FALLTHRU)
+  while (e && (e->flags & EDGE_FALLTHRU))
     e = e->succ_next;
 
   fprintf (rtl_dump_file, "  %s heuristics%s: %.1f%%",
@@ -205,9 +205,12 @@ dump_prediction (predictor, probability, bb, used)
     {
       fprintf (rtl_dump_file, "  exec ");
       fprintf (rtl_dump_file, HOST_WIDEST_INT_PRINT_DEC, bb->count);
-      fprintf (rtl_dump_file, " hit ");
-      fprintf (rtl_dump_file, HOST_WIDEST_INT_PRINT_DEC, e->count);
-      fprintf (rtl_dump_file, " (%.1f%%)", e->count * 100.0 / bb->count);
+      if (e)
+       {
+         fprintf (rtl_dump_file, " hit ");
+         fprintf (rtl_dump_file, HOST_WIDEST_INT_PRINT_DEC, e->count);
+         fprintf (rtl_dump_file, " (%.1f%%)", e->count * 100.0 / bb->count);
+       }
     }
 
   fprintf (rtl_dump_file, "\n");