This new pass will ICE if the target does not define the macro_fusion_pair_p
pass. The pass will not be useful in that case so it is best to return
early.

Pushed as obvious after a bootstrap on x86_64-linux-gnu.

        PR rtl-optimization/121835
gcc/ChangeLog:

        * dep-fusion.cc (pass_dep_fusion::execute): Return early if
        macro_fusion_pair_p is null.

Signed-off-by: Andrew Pinski <[email protected]>
CC: Artemiy Volkov <[email protected]>
CC: Jeff Law <[email protected]>
---
 gcc/dep-fusion.cc | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/gcc/dep-fusion.cc b/gcc/dep-fusion.cc
index 1e69e68dd87..d040af6991e 100644
--- a/gcc/dep-fusion.cc
+++ b/gcc/dep-fusion.cc
@@ -75,6 +75,10 @@ pass_dep_fusion::gate (function *)
 unsigned int
 pass_dep_fusion::execute (function *fn)
 {
+  // If the target has no macro fusion, there is nothing to be done.
+  if (!targetm.sched.macro_fusion_pair_p)
+    return 0;
+
   // Initialization.
   calculate_dominance_info (CDI_DOMINATORS);
   df_analyze ();
-- 
2.43.0

Reply via email to