tree.h (BLOCK_DEAD): New macro.
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>
Sat, 24 Feb 2001 13:15:55 +0000 (13:15 +0000)
committerRichard Kenner <kenner@gcc.gnu.org>
Sat, 24 Feb 2001 13:15:55 +0000 (08:15 -0500)
* tree.h (BLOCK_DEAD): New macro.
(struct tree_block): New flag, dead_flag.
* print-tree.c (print_node, case 'b'): Print missing fields.
* emit-rtl.c (remove_unnecessary_notes): Set BLOCK_DEAD.
* function.c (identify_blocks): Enable test for misplaced notes.
(all_blocks): Skip BLOCK_DEAD blocks.
* integrate.c (integrate_decl_tree): Likewise.

From-SVN: r40039

gcc/ChangeLog
gcc/emit-rtl.c
gcc/function.c
gcc/integrate.c
gcc/print-tree.c
gcc/tree.h

index eb5f49f294cf316b81872b04dfcb19a90fabf78d..00ce4bd434847b63978d9e57c24d9e20efa596c2 100644 (file)
@@ -1,5 +1,13 @@
 Sat Feb 24 06:45:21 2001  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
 
+       * tree.h (BLOCK_DEAD): New macro.
+       (struct tree_block): New flag, dead_flag.
+       * print-tree.c (print_node, case 'b'): Print missing fields.
+       * emit-rtl.c (remove_unnecessary_notes): Set BLOCK_DEAD.
+       * function.c (identify_blocks): Enable test for misplaced notes.
+       (all_blocks): Skip BLOCK_DEAD blocks.
+       * integrate.c (integrate_decl_tree): Likewise.
+
        * errors.c (internal_error, trim_filename): New functions.
        (fancy_abort): Call internal_error.
        * errors.h (internal_error, trim_filename): New declarations.
index 96fea2ccf27e2fa4e05e6d10e8eb19554e8a45d3..a7a9115325d89836f8b07a92ad62c0c2c10ed820 100644 (file)
@@ -2881,6 +2881,7 @@ remove_unnecessary_notes ()
 
                  if (debug_ignore_block (NOTE_BLOCK (insn)))
                    {
+                     BLOCK_DEAD (NOTE_BLOCK (insn)) = 1;
                      remove_insn (prev);
                      remove_insn (insn);
                    }
index a1c2d3389d0e59b11f78b379a41d2d5f4e4b25e5..58f3f6d374d3f750ccccae3de692fd0d9ea15d53 100644 (file)
@@ -5740,8 +5740,7 @@ identify_blocks ()
                                         block_stack);
 
   /* If we didn't use all of the subblocks, we've misplaced block notes.  */
-  /* ??? This appears to happen all the time.  Latent bugs elsewhere?  */
-  if (0 && last_block_vector != block_vector + n_blocks)
+  if (last_block_vector != block_vector + n_blocks)
     abort ();
 
   free (block_vector);
@@ -5947,27 +5946,28 @@ blocks_nreverse (t)
    blocks.  */
 
 static int
-all_blocks (block, vector)
-     tree block;
+all_blocks (blocks, vector)
+     tree blocks;
      tree *vector;
 {
   int n_blocks = 0;
+  tree block;
 
-  while (block)
-    {
-      TREE_ASM_WRITTEN (block) = 0;
+  for (block = blocks; block != 0; block = TREE_CHAIN (block))
+    if (!BLOCK_DEAD (block))
+      {
+       TREE_ASM_WRITTEN (block) = 0;
 
-      /* Record this block.  */
-      if (vector)
-       vector[n_blocks] = block;
+       /* Record this block.  */
+       if (vector)
+         vector[n_blocks] = block;
 
-      ++n_blocks;
+       ++n_blocks;
 
-      /* Record the subblocks, and their subblocks...  */
-      n_blocks += all_blocks (BLOCK_SUBBLOCKS (block),
-                             vector ? vector + n_blocks : 0);
-      block = BLOCK_CHAIN (block);
-    }
+       /* Record the subblocks, and their subblocks...  */
+       n_blocks += all_blocks (BLOCK_SUBBLOCKS (block),
+                               vector ? vector + n_blocks : 0);
+      }
 
   return n_blocks;
 }
index 270a9c5a115317e75491ab391c6e85fa46fb6a97..23f3590b4f37b695cd7c16572a82eaa37b36feda 100644 (file)
@@ -1684,11 +1684,12 @@ integrate_decl_tree (let, map)
 
   next = &BLOCK_SUBBLOCKS (new_block);
   for (t = BLOCK_SUBBLOCKS (let); t; t = BLOCK_CHAIN (t))
-    {
-      *next = integrate_decl_tree (t, map);
-      BLOCK_SUPERCONTEXT (*next) = new_block;
-      next = &BLOCK_CHAIN (*next);
-    }
+    if (!BLOCK_DEAD (t))
+      {
+       *next = integrate_decl_tree (t, map);
+       BLOCK_SUPERCONTEXT (*next) = new_block;
+       next = &BLOCK_CHAIN (*next);
+      }
 
   TREE_USED (new_block) = TREE_USED (let);
   BLOCK_ABSTRACT_ORIGIN (new_block) = let;
index 3bbea3f52f0aa7b85c8dff92cf428eac851cc36c..7e49ee0f949bd986cb27ab43681f18101cf3198b 100644 (file)
@@ -584,6 +584,14 @@ print_node (file, prefix, node, indent)
       break;
 
     case 'b':
+      if (BLOCK_ABSTRACT (node))
+       fprintf (file, " abstract");
+      if (BLOCK_HANDLER_BLOCK (node))
+       fprintf (file, " handler-block");
+      if (BLOCK_DEAD (node))
+       fprintf (file, " dead");
+      fprintf (file, " block-number %d", BLOCK_NUMBER (node));
+
       print_node (file, "vars", BLOCK_VARS (node), indent + 4);
       print_node (file, "supercontext", BLOCK_SUPERCONTEXT (node), indent + 4);
       print_node (file, "subblocks", BLOCK_SUBBLOCKS (node), indent + 4);
index 3d2e38416f1b521a4e33bbb4f6dc828d4d86868f..45252ddc5619553d986a176e8ec28c0293f06cd4 100644 (file)
@@ -829,6 +829,10 @@ struct tree_exp
    listed in the BLOCK_VARS slot.  */
 #define BLOCK_HANDLER_BLOCK(NODE) (BLOCK_CHECK (NODE)->block.handler_block_flag)
 
+/* Nonzero means the block was deleted as dead and should not be copied
+   when a function is inlined.  */
+#define BLOCK_DEAD(NODE) (BLOCK_CHECK (NODE)->block.dead_flag)
+
 /* An index number for this block.  These values are not guaranteed to
    be unique across functions -- whether or not they are depends on
    the debugging output format in use.  */
@@ -840,7 +844,8 @@ struct tree_block
 
   unsigned handler_block_flag : 1;
   unsigned abstract_flag : 1;
-  unsigned block_num : 30;
+  unsigned dead_flag : 1;
+  unsigned block_num : 29;
 
   union tree_node *vars;
   union tree_node *subblocks;