Split update_cfg_for_uncondjump out of combine
authorRichard Sandiford <richard.sandiford@arm.com>
Thu, 17 Dec 2020 00:15:03 +0000 (00:15 +0000)
committerRichard Sandiford <richard.sandiford@arm.com>
Thu, 17 Dec 2020 00:15:03 +0000 (00:15 +0000)
Later patches want to reuse combine's update_cfg_for_uncondjump,
so this patch makes it a public cfgrtl.c function.

gcc/
* cfgrtl.h (update_cfg_for_uncondjump): Declare.
* combine.c (update_cfg_for_uncondjump): Move to...
* cfgrtl.c: ...here.

gcc/cfgrtl.c
gcc/cfgrtl.h
gcc/combine.c

index 4d0249513132f034db969d9440084d53405f8c87..79f38b7aa88b086502fc4059230f48dfa13531a5 100644 (file)
@@ -3419,6 +3419,53 @@ fixup_abnormal_edges (void)
   return inserted;
 }
 \f
+/* Delete the unconditional jump INSN and adjust the CFG correspondingly.
+   Note that the INSN should be deleted *after* removing dead edges, so
+   that the kept edge is the fallthrough edge for a (set (pc) (pc))
+   but not for a (set (pc) (label_ref FOO)).  */
+
+void
+update_cfg_for_uncondjump (rtx_insn *insn)
+{
+  basic_block bb = BLOCK_FOR_INSN (insn);
+  gcc_assert (BB_END (bb) == insn);
+
+  purge_dead_edges (bb);
+
+  if (current_ir_type () != IR_RTL_CFGLAYOUT)
+    {
+      if (!find_fallthru_edge (bb->succs))
+       {
+         auto barrier = next_nonnote_nondebug_insn (insn);
+         if (!barrier || !BARRIER_P (barrier))
+           emit_barrier_after (insn);
+       }
+      return;
+    }
+
+  delete_insn (insn);
+  if (EDGE_COUNT (bb->succs) == 1)
+    {
+      rtx_insn *insn;
+
+      single_succ_edge (bb)->flags |= EDGE_FALLTHRU;
+
+      /* Remove barriers from the footer if there are any.  */
+      for (insn = BB_FOOTER (bb); insn; insn = NEXT_INSN (insn))
+       if (BARRIER_P (insn))
+         {
+           if (PREV_INSN (insn))
+             SET_NEXT_INSN (PREV_INSN (insn)) = NEXT_INSN (insn);
+           else
+             BB_FOOTER (bb) = NEXT_INSN (insn);
+           if (NEXT_INSN (insn))
+             SET_PREV_INSN (NEXT_INSN (insn)) = PREV_INSN (insn);
+         }
+       else if (LABEL_P (insn))
+         break;
+    }
+}
+\f
 /* Cut the insns from FIRST to LAST out of the insns stream.  */
 
 rtx_insn *
index ae62d6cf05ca7e90e6f5e483be2b5127ce66ed88..1c177d3a7e3f06d8cf2c72415346e97e9698a857 100644 (file)
@@ -47,6 +47,7 @@ extern void fixup_partitions (void);
 extern bool purge_dead_edges (basic_block);
 extern bool purge_all_dead_edges (void);
 extern bool fixup_abnormal_edges (void);
+extern void update_cfg_for_uncondjump (rtx_insn *);
 extern rtx_insn *unlink_insn_chain (rtx_insn *, rtx_insn *);
 extern void relink_block_chain (bool);
 extern rtx_insn *duplicate_insn_chain (rtx_insn *, rtx_insn *,
index ed1ad45de838436d580a8efe11c7e56f17fe9557..5864474e720c475003021c4b84f6b4487446edfa 100644 (file)
@@ -2531,42 +2531,6 @@ reg_subword_p (rtx x, rtx reg)
         && GET_MODE_CLASS (GET_MODE (x)) == MODE_INT;
 }
 
-/* Delete the unconditional jump INSN and adjust the CFG correspondingly.
-   Note that the INSN should be deleted *after* removing dead edges, so
-   that the kept edge is the fallthrough edge for a (set (pc) (pc))
-   but not for a (set (pc) (label_ref FOO)).  */
-
-static void
-update_cfg_for_uncondjump (rtx_insn *insn)
-{
-  basic_block bb = BLOCK_FOR_INSN (insn);
-  gcc_assert (BB_END (bb) == insn);
-
-  purge_dead_edges (bb);
-
-  delete_insn (insn);
-  if (EDGE_COUNT (bb->succs) == 1)
-    {
-      rtx_insn *insn;
-
-      single_succ_edge (bb)->flags |= EDGE_FALLTHRU;
-
-      /* Remove barriers from the footer if there are any.  */
-      for (insn = BB_FOOTER (bb); insn; insn = NEXT_INSN (insn))
-       if (BARRIER_P (insn))
-         {
-           if (PREV_INSN (insn))
-             SET_NEXT_INSN (PREV_INSN (insn)) = NEXT_INSN (insn);
-           else
-             BB_FOOTER (bb) = NEXT_INSN (insn);
-           if (NEXT_INSN (insn))
-             SET_PREV_INSN (NEXT_INSN (insn)) = PREV_INSN (insn);
-         }
-       else if (LABEL_P (insn))
-         break;
-    }
-}
-
 /* Return whether PAT is a PARALLEL of exactly N register SETs followed
    by an arbitrary number of CLOBBERs.  */
 static bool