From: Kyrylo Tkachov <[email protected]>
pass_split_paths duplicates the join block of an IF-THEN-ELSE that feeds a
loop latch, splitting the two paths to the backedge. It runs only at -O3.
In practice it interacts badly with later optimizations: it duplicates the
loop body before loads have been commoned and before if-conversion runs, so
it can block both loop unrolling (PR120892) and if-conversion of the
duplicated diamond, while its own heuristic already declines about half of
all candidate blocks, most often to avoid spoiling if-conversion.
Remove the pass and deprecate the -fsplit-paths option. The option is kept
accepted for backward compatibility via the Ignore flag and now does nothing,
matching how other optimization options have been retired (for example
-ftree-lrs). param_max_jump_thread_duplication_stmts is retained as it is
shared with the jump-threading passes.
Statistics from the pass on SPEC CPU 2026 (intrate + fprate, counted from the
split-paths dump):
candidates splits declined to protect if-conversion
-O3 122894 62050 60844 37166
-O3 -flto=auto 52423 21257 31166 21822
The pass splits about half of the blocks it considers and declines the rest,
most often to avoid spoiling if-conversion. The duplication grows .text by
0.32% at -O3 and 0.24% at -O3 -flto=auto.
Andrea and Jeff indicated in PR120892 that removing -fsplit-paths may be
the way to go there.
-fsplit-paths also complicates the control-flow and defeats the
load-commoning necessary to get good if-conversion of the hot loop from
Snappy from https://gcc.gnu.org/bugzilla/show_bug.cgi?id=125557#c13 .
Bootstrapped and tested on aarch64-none-linux-gnu and x86_64-linux.
gcc/ChangeLog:
PR tree-optimization/120892
* gimple-ssa-split-paths.cc: Remove.
* passes.def (pass_split_paths): Remove.
* tree-pass.h (make_pass_split_paths): Remove.
* Makefile.in (OBJS): Remove gimple-ssa-split-paths.o.
* timevar.def (TV_SPLIT_PATHS): Remove.
* opts.cc (default_options_table): Remove the OPT_LEVELS_3_PLUS entry
for OPT_fsplit_paths.
* common.opt (fsplit-paths): Make it a deprecated no-op using Ignore.
* doc/invoke.texi (-fsplit-paths): Document as deprecated and remove it
from the option summary and the -O3 list.
gcc/testsuite/ChangeLog:
PR tree-optimization/120892
* gcc.dg/tree-ssa/split-path-1.c: Move to...
* gcc.c-torture/execute/split-path-1.c: ...here. Adjust to a plain
compile and run test without the split-paths dump scan.
* gcc.dg/tree-ssa/split-path-2.c: Move to...
* gcc.c-torture/compile/split-path-2.c: ...here. Adjust to a
compile-only test without the split-paths dump scan.
* gcc.dg/tree-ssa/split-path-3.c: Move to...
* gcc.c-torture/compile/split-path-3.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-4.c: Move to...
* gcc.c-torture/compile/split-path-4.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-5.c: Move to...
* gcc.c-torture/compile/split-path-5.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-6.c: Move to...
* gcc.c-torture/compile/split-path-6.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-7.c: Move to...
* gcc.c-torture/compile/split-path-7.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-8.c: Move to...
* gcc.c-torture/compile/split-path-8.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-9.c: Move to...
* gcc.c-torture/compile/split-path-9.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-10.c: Move to...
* gcc.c-torture/compile/split-path-10.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-11.c: Move to...
* gcc.c-torture/compile/split-path-11.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-12.c: Move to...
* gcc.c-torture/compile/split-path-12.c: ...here. Likewise.
* gcc.dg/tree-ssa/split-path-13.c: Move to...
* gcc.c-torture/compile/split-path-13.c: ...here. Likewise.
* gcc.dg/tree-ssa/pr69270.c: Move to...
* gcc.c-torture/compile/pr69270.c: ...here. Likewise.
* g++.dg/tree-ssa/pr88797.C: Move to...
* g++.dg/torture/pr88797.C: ...here. Adjust to a compile-only test.
* gcc.target/i386/pr106450.c: Remove -fsplit-paths from dg-options.
Signed-off-by: Kyrylo Tkachov <[email protected]>
---
gcc/Makefile.in | 1 -
gcc/common.opt | 4 +-
gcc/doc/invoke.texi | 8 +-
gcc/gimple-ssa-split-paths.cc | 545 ------------------
gcc/opts.cc | 1 -
gcc/passes.def | 1 -
gcc/testsuite/g++.dg/torture/pr88797.C | 13 +
gcc/testsuite/g++.dg/tree-ssa/pr88797.C | 16 -
.../compile}/pr69270.c | 7 -
.../compile}/split-path-10.c | 3 -
.../compile}/split-path-11.c | 3 -
.../compile}/split-path-12.c | 3 -
.../compile}/split-path-13.c | 3 -
.../gcc.c-torture/compile/split-path-2.c | 18 +
.../compile}/split-path-3.c | 3 -
.../compile}/split-path-4.c | 3 -
.../compile}/split-path-5.c | 3 -
.../compile}/split-path-6.c | 3 -
.../compile}/split-path-7.c | 3 -
.../gcc.c-torture/compile/split-path-8.c | 11 +
.../gcc.c-torture/compile/split-path-9.c | 14 +
.../execute}/split-path-1.c | 3 -
gcc/testsuite/gcc.dg/tree-ssa/split-path-2.c | 21 -
gcc/testsuite/gcc.dg/tree-ssa/split-path-8.c | 14 -
gcc/testsuite/gcc.dg/tree-ssa/split-path-9.c | 17 -
gcc/testsuite/gcc.target/i386/pr106450.c | 2 +-
gcc/timevar.def | 1 -
gcc/tree-pass.h | 1 -
28 files changed, 62 insertions(+), 663 deletions(-)
delete mode 100644 gcc/gimple-ssa-split-paths.cc
create mode 100644 gcc/testsuite/g++.dg/torture/pr88797.C
delete mode 100644 gcc/testsuite/g++.dg/tree-ssa/pr88797.C
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/pr69270.c (57%)
rename gcc/testsuite/{gcc.dg/tree-ssa =>
gcc.c-torture/compile}/split-path-10.c (81%)
rename gcc/testsuite/{gcc.dg/tree-ssa =>
gcc.c-torture/compile}/split-path-11.c (55%)
rename gcc/testsuite/{gcc.dg/tree-ssa =>
gcc.c-torture/compile}/split-path-12.c (70%)
rename gcc/testsuite/{gcc.dg/tree-ssa =>
gcc.c-torture/compile}/split-path-13.c (62%)
create mode 100644 gcc/testsuite/gcc.c-torture/compile/split-path-2.c
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/split-path-3.c
(93%)
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/split-path-4.c
(62%)
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/split-path-5.c
(84%)
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/split-path-6.c
(82%)
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/compile}/split-path-7.c
(87%)
create mode 100644 gcc/testsuite/gcc.c-torture/compile/split-path-8.c
create mode 100644 gcc/testsuite/gcc.c-torture/compile/split-path-9.c
rename gcc/testsuite/{gcc.dg/tree-ssa => gcc.c-torture/execute}/split-path-1.c
(83%)
delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/split-path-2.c
delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/split-path-8.c
delete mode 100644 gcc/testsuite/gcc.dg/tree-ssa/split-path-9.c
diff --git a/gcc/Makefile.in b/gcc/Makefile.in
index 536e2faaaf8..06e711094ef 100644
--- a/gcc/Makefile.in
+++ b/gcc/Makefile.in
@@ -1542,7 +1542,6 @@ OBJS = \
gimple-ssa-isolate-paths.o \
gimple-ssa-nonnull-compare.o \
gimple-ssa-sccopy.o \
- gimple-ssa-split-paths.o \
gimple-ssa-store-merging.o \
gimple-ssa-strength-reduction.o \
gimple-ssa-sprintf.o \
diff --git a/gcc/common.opt b/gcc/common.opt
index 218dddf5dfe..0055578ccf6 100644
--- a/gcc/common.opt
+++ b/gcc/common.opt
@@ -3388,8 +3388,8 @@ Common Var(flag_tree_vrp) Init(0) Optimization
Perform Value Range Propagation on trees.
fsplit-paths
-Common Var(flag_split_paths) Init(0) Optimization
-Split paths leading to loop backedges.
+Common Ignore
+Does nothing. Preserved for backward compatibility.
funconstrained-commons
Common Var(flag_unconstrained_commons) Optimization
diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
index 8da5f03ccbd..932def96d8f 100644
--- a/gcc/doc/invoke.texi
+++ b/gcc/doc/invoke.texi
@@ -676,7 +676,7 @@ Objective-C and Objective-C++ Dialects}.
-fsemantic-interposition -fshrink-wrap -fshrink-wrap-separate
-fsignaling-nans
-fsingle-precision-constant -fsplit-ivs-in-unroller -fsplit-loops
--fspeculatively-call-stored-functions -fsplit-paths
+-fspeculatively-call-stored-functions
-fsplit-wide-types -fsplit-wide-types-early -fssa-backprop -fssa-phiopt
-fstdarg-opt -fstore-merging -fstrict-aliasing -fipa-strict-aliasing
-fthread-jumps -ftracer -ftree-bit-ccp
@@ -13619,7 +13619,6 @@ by @option{-O2} and also turns on the following
optimization flags:
-fpeel-loops
-fpredictive-commoning
-fsplit-loops
--fsplit-paths
-ftree-loop-distribution
-ftree-partial-pre
-funswitch-loops
@@ -15462,9 +15461,8 @@ enabled.
@opindex fsplit-paths
@opindex fno-split-paths
@item -fsplit-paths
-Split paths leading to loop backedges. This can improve dead code
-elimination and common subexpression elimination. This is enabled by
-default at @option{-O3} and above.
+This option is deprecated and does nothing. It is accepted only for
+backward compatibility.
@opindex fsplit-ivs-in-unroller
@opindex fno-split-ivs-in-unroller
diff --git a/gcc/gimple-ssa-split-paths.cc b/gcc/gimple-ssa-split-paths.cc
deleted file mode 100644
index 171a581e8f8..00000000000
--- a/gcc/gimple-ssa-split-paths.cc
+++ /dev/null
@@ -1,545 +0,0 @@
-/* Support routines for Splitting Paths to loop backedges
- Copyright (C) 2015-2026 Free Software Foundation, Inc.
- Contributed by Ajit Kumar Agarwal <[email protected]>.
-
- This file is part of GCC.
-
- GCC is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 3, or (at your option)
- any later version.
-
-GCC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with GCC; see the file COPYING3. If not see
-<http://www.gnu.org/licenses/>. */
-
-#include "config.h"
-#include "system.h"
-#include "coretypes.h"
-#include "backend.h"
-#include "tree.h"
-#include "gimple.h"
-#include "tree-pass.h"
-#include "tree-cfg.h"
-#include "cfganal.h"
-#include "cfgloop.h"
-#include "gimple-iterator.h"
-#include "tracer.h"
-#include "predict.h"
-#include "gimple-ssa.h"
-#include "tree-phinodes.h"
-#include "ssa-iterators.h"
-#include "fold-const.h"
-#include "cfghooks.h"
-
-/* Given LATCH, the latch block in a loop, see if the shape of the
- path reaching LATCH is suitable for being split by duplication.
- If so, return the block that will be duplicated into its predecessor
- paths. Else return NULL. */
-
-static basic_block
-find_block_to_duplicate_for_splitting_paths (basic_block latch)
-{
- /* We should have simple latches at this point. So the latch should
- have a single successor. This implies the predecessor of the latch
- likely has the loop exit. And it's that predecessor we're most
- interested in. To keep things simple, we're going to require that
- the latch have a single predecessor too. */
- if (single_succ_p (latch) && single_pred_p (latch))
- {
- basic_block bb = get_immediate_dominator (CDI_DOMINATORS, latch);
- gcc_assert (single_pred_edge (latch)->src == bb);
-
- /* If BB has been marked as not to be duplicated, then honor that
- request. */
- if (ignore_bb_p (bb))
- return NULL;
-
- gimple *last = gsi_stmt (gsi_last_nondebug_bb (bb));
- /* The immediate dominator of the latch must end in a conditional. */
- if (!last || gimple_code (last) != GIMPLE_COND)
- return NULL;
-
- /* We're hoping that BB is a join point for an IF-THEN-ELSE diamond
- region. Verify that it is.
-
- First, verify that BB has two predecessors (each arm of the
- IF-THEN-ELSE) and two successors (the latch and exit) and that
- all edges are normal. */
- if (EDGE_COUNT (bb->preds) == 2
- && !(EDGE_PRED (bb, 0)->flags & EDGE_COMPLEX)
- && !(EDGE_PRED (bb, 1)->flags & EDGE_COMPLEX)
- && EDGE_COUNT (bb->succs) == 2
- && !(EDGE_SUCC (bb, 0)->flags & EDGE_COMPLEX)
- && !(EDGE_SUCC (bb, 1)->flags & EDGE_COMPLEX))
- {
- /* Now verify that BB's immediate dominator ends in a
- conditional as well. */
- basic_block bb_idom = get_immediate_dominator (CDI_DOMINATORS, bb);
- gimple *last = gsi_stmt (gsi_last_nondebug_bb (bb_idom));
- if (!last || gimple_code (last) != GIMPLE_COND)
- return NULL;
-
- /* And that BB's immediate dominator's successors are the
- predecessors of BB or BB itself. */
- if (!(EDGE_PRED (bb, 0)->src == bb_idom
- || find_edge (bb_idom, EDGE_PRED (bb, 0)->src))
- || !(EDGE_PRED (bb, 1)->src == bb_idom
- || find_edge (bb_idom, EDGE_PRED (bb, 1)->src)))
- return NULL;
-
- /* And that the predecessors of BB each have a single successor
- or are BB's immediate domiator itself. */
- if (!(EDGE_PRED (bb, 0)->src == bb_idom
- || single_succ_p (EDGE_PRED (bb, 0)->src))
- || !(EDGE_PRED (bb, 1)->src == bb_idom
- || single_succ_p (EDGE_PRED (bb, 1)->src)))
- return NULL;
-
- /* So at this point we have a simple diamond for an IF-THEN-ELSE
- construct starting at BB_IDOM, with a join point at BB. BB
- pass control outside the loop or to the loop latch.
-
- We're going to want to create two duplicates of BB, one for
- each successor of BB_IDOM. */
- return bb;
- }
- }
- return NULL;
-}
-
-/* Return the number of non-debug statements in a block. */
-static unsigned int
-count_stmts_in_block (basic_block bb)
-{
- gimple_stmt_iterator gsi;
- unsigned int num_stmts = 0;
-
- for (gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi))
- {
- gimple *stmt = gsi_stmt (gsi);
- if (!is_gimple_debug (stmt))
- num_stmts++;
- }
- return num_stmts;
-}
-
-/* Return TRUE if CODE represents a tree code that is not likely to
- be easily if-convertible because it likely expands into multiple
- insns, FALSE otherwise. */
-static bool
-poor_ifcvt_candidate_code (enum tree_code code)
-{
- return (code == MIN_EXPR
- || code == MAX_EXPR
- || code == ABS_EXPR
- || code == COND_EXPR);
-}
-
-/* Return TRUE if PRED of BB is an poor ifcvt candidate. */
-static bool
-poor_ifcvt_pred (basic_block pred, basic_block bb)
-{
- /* If the edge count of the pred is not 1, then
- this is the predecessor from the if rather
- than middle one. */
- if (EDGE_COUNT (pred->succs) != 1)
- return false;
-
- /* Empty middle bb are never a poor ifcvt candidate. */
- if (empty_block_p (pred))
- return false;
- /* If BB's predecessors are single statement blocks where
- the output of that statement feed the same PHI in BB,
- it an ifcvt candidate. */
- gimple *stmt = last_and_only_stmt (pred);
- if (!stmt || gimple_code (stmt) != GIMPLE_ASSIGN)
- return true;
-
- /* If the statement could trap, then this is a poor ifcvt candidate. */
- if (gimple_could_trap_p (stmt))
- return true;
-
- tree_code code = gimple_assign_rhs_code (stmt);
- if (poor_ifcvt_candidate_code (code))
- return true;
- tree lhs = gimple_assign_lhs (stmt);
- gimple_stmt_iterator gsi;
- for (gsi = gsi_start_phis (bb); !gsi_end_p (gsi); gsi_next (&gsi))
- {
- gimple *phi = gsi_stmt (gsi);
- if (gimple_phi_arg_def (phi, 0) == lhs
- || gimple_phi_arg_def (phi, 1) == lhs)
- return false;
- }
- return true;
-}
-
-/* Return TRUE if BB is a reasonable block to duplicate by examining
- its size, false otherwise. BB will always be a loop latch block.
-
- Things to consider:
-
- We do not want to spoil if-conversion if at all possible.
-
- Most of the benefit seems to be from eliminating the unconditional
- jump rather than CSE/DCE opportunities. So favor duplicating
- small latches. A latch with just a conditional branch is ideal.
-
- CSE/DCE opportunities crop up when statements from the predecessors
- feed statements in the latch and allow statements in the latch to
- simplify. */
-
-static bool
-is_feasible_trace (basic_block bb)
-{
- basic_block pred1 = EDGE_PRED (bb, 0)->src;
- basic_block pred2 = EDGE_PRED (bb, 1)->src;
- int num_stmts_in_join = count_stmts_in_block (bb);
- int num_stmts_in_pred1
- = EDGE_COUNT (pred1->succs) == 1 ? count_stmts_in_block (pred1) : 0;
- int num_stmts_in_pred2
- = EDGE_COUNT (pred2->succs) == 1 ? count_stmts_in_block (pred2) : 0;
-
- /* Upper Hard limit on the number statements to copy. */
- if (num_stmts_in_join
- >= param_max_jump_thread_duplication_stmts)
- {
- if (dump_file && (dump_flags & TDF_DETAILS))
- fprintf (dump_file,
- "Duplicating block %d would duplicate "
- "too many statements: %d >= %d\n",
- bb->index, num_stmts_in_join,
- param_max_jump_thread_duplication_stmts);
- return false;
- }
-
- /* This is meant to catch cases that are likely opportunities for
- if-conversion. */
- if (num_stmts_in_pred1 <= 1 && num_stmts_in_pred2 <= 1)
- {
- int num_phis = 0;
- /* The max number of PHIs that should be considered for an ifcvt
- candidate. */
- const int max_num_phis = 3;
- for (gphi_iterator si = gsi_start_phis (bb); ! gsi_end_p (si);
- gsi_next (&si))
- {
- num_phis++;
- if (num_phis > max_num_phis)
- break;
- }
- if (num_phis <= max_num_phis
- && !poor_ifcvt_pred (pred1, bb)
- && !poor_ifcvt_pred (pred2, bb))
- {
- if (dump_file && (dump_flags & TDF_DETAILS))
- fprintf (dump_file,
- "Block %d appears to be a join point for "
- "if-convertible bbs.\n",
- bb->index);
- return false;
- }
- }
-
- /* If the joiner has no PHIs with useful uses there is zero chance
- of CSE/DCE/jump-threading possibilities exposed by duplicating it. */
- bool found_useful_phi = false;
- for (gphi_iterator si = gsi_start_phis (bb); ! gsi_end_p (si);
- gsi_next (&si))
- {
- gphi *phi = si.phi ();
- use_operand_p use_p;
- imm_use_iterator iter;
- FOR_EACH_IMM_USE_FAST (use_p, iter, gimple_phi_result (phi))
- {
- gimple *stmt = USE_STMT (use_p);
- if (is_gimple_debug (stmt))
- continue;
- /* If there's a use in the joiner this might be a CSE/DCE
- opportunity, but not if the use is in a conditional
- which makes this a likely if-conversion candidate. */
- if (gimple_bb (stmt) == bb
- && (!is_gimple_assign (stmt)
- || (TREE_CODE_CLASS (gimple_assign_rhs_code (stmt))
- != tcc_comparison)))
- {
- found_useful_phi = true;
- break;
- }
- /* If the use is on a loop header PHI and on one path the
- value is unchanged this might expose a jump threading
- opportunity. */
- if (gimple_code (stmt) == GIMPLE_PHI
- && gimple_bb (stmt) == bb->loop_father->header
- /* But for memory the PHI alone isn't good enough. */
- && ! virtual_operand_p (gimple_phi_result (stmt)))
- {
- bool found_unchanged_path = false;
- for (unsigned i = 0; i < gimple_phi_num_args (phi); ++i)
- if (gimple_phi_arg_def (phi, i) == gimple_phi_result (stmt))
- {
- found_unchanged_path = true;
- break;
- }
- /* If we found an unchanged path this can only be a threading
- opportunity if we have uses of the loop header PHI result
- in a stmt dominating the merge block. Otherwise the
- splitting may prevent if-conversion. */
- if (found_unchanged_path)
- {
- use_operand_p use2_p;
- imm_use_iterator iter2;
- FOR_EACH_IMM_USE_FAST (use2_p, iter2, gimple_phi_result
(stmt))
- {
- gimple *use_stmt = USE_STMT (use2_p);
- if (is_gimple_debug (use_stmt))
- continue;
- basic_block use_bb = gimple_bb (use_stmt);
- if (use_bb != bb
- && dominated_by_p (CDI_DOMINATORS, bb, use_bb))
- {
- if (gcond *cond = dyn_cast <gcond *> (use_stmt))
- if (gimple_cond_code (cond) == EQ_EXPR
- || gimple_cond_code (cond) == NE_EXPR)
- found_useful_phi = true;
- break;
- }
- }
- }
- if (found_useful_phi)
- break;
- }
- }
- if (found_useful_phi)
- break;
- }
- /* There is one exception namely a controlling condition we can propagate
- an equivalence from to the joiner. */
- bool found_cprop_opportunity = false;
- basic_block dom = get_immediate_dominator (CDI_DOMINATORS, bb);
- gcond *cond = as_a <gcond *> (*gsi_last_bb (dom));
- if (gimple_cond_code (cond) == EQ_EXPR
- || gimple_cond_code (cond) == NE_EXPR)
- for (unsigned i = 0; i < 2; ++i)
- {
- tree op = gimple_op (cond, i);
- if (TREE_CODE (op) == SSA_NAME)
- {
- use_operand_p use_p;
- imm_use_iterator iter;
- FOR_EACH_IMM_USE_FAST (use_p, iter, op)
- {
- if (is_gimple_debug (USE_STMT (use_p)))
- continue;
- if (gimple_bb (USE_STMT (use_p)) == bb)
- {
- found_cprop_opportunity = true;
- break;
- }
- }
- }
- if (found_cprop_opportunity)
- break;
- }
-
- if (! found_useful_phi && ! found_cprop_opportunity)
- {
- if (dump_file && (dump_flags & TDF_DETAILS))
- fprintf (dump_file,
- "Block %d is a join that does not expose CSE/DCE/jump-thread "
- "opportunities when duplicated.\n",
- bb->index);
- return false;
- }
-
- /* We may want something here which looks at dataflow and tries
- to guess if duplication of BB is likely to result in simplification
- of instructions in BB in either the original or the duplicate. */
- return true;
-}
-
-/* If the immediate dominator of the latch of the loop is
- block with conditional branch, then the loop latch is
- duplicated to its predecessors path preserving the SSA
- semantics.
-
- CFG before transformation.
-
- 2
- |
- |
- +---->3
- | / \
- | / \
- | 4 5
- | \ /
- | \ /
- | 6
- | / \
- | / \
- | 8 7
- | | |
- ---+ E
-
-
-
- Block 8 is the latch. We're going to make copies of block 6 (9 & 10)
- and wire things up so they look like this:
-
- 2
- |
- |
- +---->3
- | / \
- | / \
- | 4 5
- | | |
- | | |
- | 9 10
- | |\ /|
- | | \ / |
- | | 7 |
- | | | |
- | | E |
- | | |
- | \ /
- | \ /
- +-----8
-
-
- Blocks 9 and 10 will get merged into blocks 4 & 5 respectively which
- enables CSE, DCE and other optimizations to occur on a larger block
- of code. */
-
-static bool
-split_paths ()
-{
- bool changed = false;
-
- loop_optimizer_init (LOOPS_NORMAL | LOOPS_HAVE_RECORDED_EXITS);
- initialize_original_copy_tables ();
- calculate_dominance_info (CDI_DOMINATORS);
-
- for (auto loop : loops_list (cfun, LI_FROM_INNERMOST))
- {
- /* Only split paths if we are optimizing this loop for speed. */
- if (!optimize_loop_for_speed_p (loop))
- continue;
-
- /* See if there is a block that we can duplicate to split the
- path to the loop latch. */
- basic_block bb
- = find_block_to_duplicate_for_splitting_paths (loop->latch);
-
- /* BB is the merge point for an IF-THEN-ELSE we want to transform.
-
- Essentially we want to create a duplicate of bb and redirect the
- first predecessor of BB to the duplicate (leaving the second
- predecessor as is. This will split the path leading to the latch
- re-using BB to avoid useless copying. */
- if (bb && is_feasible_trace (bb))
- {
- if (dump_file && (dump_flags & TDF_DETAILS))
- fprintf (dump_file,
- "Duplicating join block %d into predecessor paths\n",
- bb->index);
- basic_block pred0 = EDGE_PRED (bb, 0)->src;
- if (EDGE_COUNT (pred0->succs) != 1)
- pred0 = EDGE_PRED (bb, 1)->src;
- transform_duplicate (pred0, bb);
- changed = true;
-
- /* If BB has an outgoing edge marked as IRREDUCIBLE, then
- duplicating BB may result in an irreducible region turning
- into a natural loop.
-
- Long term we might want to hook this into the block
- duplication code, but as we've seen with similar changes
- for edge removal, that can be somewhat risky. */
- if (EDGE_SUCC (bb, 0)->flags & EDGE_IRREDUCIBLE_LOOP
- || EDGE_SUCC (bb, 1)->flags & EDGE_IRREDUCIBLE_LOOP)
- {
- if (dump_file && (dump_flags & TDF_DETAILS))
- fprintf (dump_file,
- "Join block %d has EDGE_IRREDUCIBLE_LOOP set. "
- "Scheduling loop fixups.\n",
- bb->index);
- loops_state_set (LOOPS_NEED_FIXUP);
- }
- }
- }
-
- loop_optimizer_finalize ();
- free_original_copy_tables ();
- return changed;
-}
-
-/* Main entry point for splitting paths. Returns TODO_cleanup_cfg if any
- paths where split, otherwise return zero. */
-
-static unsigned int
-execute_split_paths ()
-{
- /* If we don't have at least 2 real blocks and backedges in the
- CFG, then there's no point in trying to perform path splitting. */
- if (n_basic_blocks_for_fn (cfun) <= NUM_FIXED_BLOCKS + 1
- || !mark_dfs_back_edges ())
- return 0;
-
- bool changed = split_paths();
- if (changed)
- free_dominance_info (CDI_DOMINATORS);
-
- return changed ? TODO_cleanup_cfg : 0;
-}
-
-static bool
-gate_split_paths ()
-{
- return flag_split_paths;
-}
-
-namespace {
-
-const pass_data pass_data_split_paths =
-{
- GIMPLE_PASS, /* type */
- "split-paths", /* name */
- OPTGROUP_NONE, /* optinfo_flags */
- TV_SPLIT_PATHS, /* tv_id */
- PROP_ssa, /* properties_required */
- 0, /* properties_provided */
- 0, /* properties_destroyed */
- 0, /* todo_flags_start */
- TODO_update_ssa, /* todo_flags_finish */
-};
-
-class pass_split_paths : public gimple_opt_pass
-{
- public:
- pass_split_paths (gcc::context *ctxt)
- : gimple_opt_pass (pass_data_split_paths, ctxt)
- {}
- /* opt_pass methods: */
- opt_pass * clone () final override { return new pass_split_paths (m_ctxt); }
- bool gate (function *) final override { return gate_split_paths (); }
- unsigned int execute (function *) final override
- {
- return execute_split_paths ();
- }
-
-}; // class pass_split_paths
-
-} // anon namespace
-
-gimple_opt_pass *
-make_pass_split_paths (gcc::context *ctxt)
-{
- return new pass_split_paths (ctxt);
-}
diff --git a/gcc/opts.cc b/gcc/opts.cc
index 342517528e8..5522f41f906 100644
--- a/gcc/opts.cc
+++ b/gcc/opts.cc
@@ -707,7 +707,6 @@ static const struct default_options default_options_table[]
=
{ OPT_LEVELS_3_PLUS, OPT_fpeel_loops, NULL, 1 },
{ OPT_LEVELS_3_PLUS, OPT_fpredictive_commoning, NULL, 1 },
{ OPT_LEVELS_3_PLUS, OPT_fsplit_loops, NULL, 1 },
- { OPT_LEVELS_3_PLUS, OPT_fsplit_paths, NULL, 1 },
{ OPT_LEVELS_3_PLUS, OPT_ftree_loop_distribution, NULL, 1 },
{ OPT_LEVELS_3_PLUS, OPT_ftree_partial_pre, NULL, 1 },
{ OPT_LEVELS_3_PLUS, OPT_funswitch_loops, NULL, 1 },
diff --git a/gcc/passes.def b/gcc/passes.def
index 1fc867fae51..9095c134f49 100644
--- a/gcc/passes.def
+++ b/gcc/passes.def
@@ -351,7 +351,6 @@ along with GCC; see the file COPYING3. If not see
NEXT_PASS (pass_cse_reciprocals);
NEXT_PASS (pass_reassoc, false /* early_p */);
NEXT_PASS (pass_strength_reduction);
- NEXT_PASS (pass_split_paths);
NEXT_PASS (pass_tracer);
NEXT_PASS (pass_fre, false /* may_iterate */);
/* After late FRE we rewrite no longer addressed locals into SSA
diff --git a/gcc/testsuite/g++.dg/torture/pr88797.C
b/gcc/testsuite/g++.dg/torture/pr88797.C
new file mode 100644
index 00000000000..3dd00fcb7a9
--- /dev/null
+++ b/gcc/testsuite/g++.dg/torture/pr88797.C
@@ -0,0 +1,13 @@
+/* { dg-do compile } */
+
+
+void use(unsigned);
+bool f(unsigned x, unsigned y) {
+ return x < 1111 + (y <= 2222);
+}
+void test_f(unsigned x, unsigned y) {
+ for (unsigned i = 0; i < 3333; ++i)
+ use(f(x++, y++));
+}
+
+
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr88797.C
b/gcc/testsuite/g++.dg/tree-ssa/pr88797.C
deleted file mode 100644
index 541ae8e71e1..00000000000
--- a/gcc/testsuite/g++.dg/tree-ssa/pr88797.C
+++ /dev/null
@@ -1,16 +0,0 @@
-/* { dg-do compile } */
-/* { dg-options "-O3 -fdump-tree-split-paths-details" } */
-
-
-void use(unsigned);
-bool f(unsigned x, unsigned y) {
- return x < 1111 + (y <= 2222);
-}
-void test_f(unsigned x, unsigned y) {
- for (unsigned i = 0; i < 3333; ++i)
- use(f(x++, y++));
-}
-
-/* { dg-final { scan-tree-dump-not "Duplicating join block" "split-paths" } }
*/
-/* { dg-final { scan-tree-dump-times "appears to be a join point for
if-convertible bbs." 1 "split-paths" } } */
-
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr69270.c
b/gcc/testsuite/gcc.c-torture/compile/pr69270.c
similarity index 57%
rename from gcc/testsuite/gcc.dg/tree-ssa/pr69270.c
rename to gcc/testsuite/gcc.c-torture/compile/pr69270.c
index b08ec9d6ddb..daed456ec60 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/pr69270.c
+++ b/gcc/testsuite/gcc.c-torture/compile/pr69270.c
@@ -1,17 +1,10 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-dom3-details" } */
/* There should be two references to bufferstep that turn into
constants. */
-/* { dg-final { scan-tree-dump-times "Replaced .bufferstep_\[0-9\]+. with
constant .0." 1 "dom3"} } */
-/* { dg-final { scan-tree-dump-times "Replaced .bufferstep_\[0-9\]+. with
constant .1." 1 "dom3"} } */
/* And some assignments ought to fold down to constants. */
-/* { dg-final { scan-tree-dump-times "Folded to: (?:bufferstep)?_\[0-9\]+ =
1;" 1 "dom3"} } */
-/* { dg-final { scan-tree-dump-times "Folded to: (?:bufferstep)?_\[0-9\]+ =
0;" 1 "dom3"} } */
/* The XOR operations should have been optimized to constants. */
-/* { dg-final { scan-tree-dump-not "bit_xor" "dom3"} } */
extern int *stepsizeTable;
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-10.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-10.c
similarity index 81%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-10.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-10.c
index ed208795488..336b11893b6 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-10.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-10.c
@@ -1,6 +1,4 @@
/* PR tree-optimization/79389 */
-/* { dg-do compile } */
-/* { dg-options "-O3 -fdump-tree-split-paths-details" } */
typedef struct
{
@@ -46,4 +44,3 @@ double MonteCarlo_integrate(int Num_samples)
return ((double) under_curve / Num_samples) * 4.0;
}
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 0 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-11.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-11.c
similarity index 55%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-11.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-11.c
index fa33367feaa..44b8b059481 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-11.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-11.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fno-tree-vectorize -fsplit-paths
-fdump-tree-split-paths-details -w" } */
void foo(unsigned long long *M)
{
@@ -11,4 +9,3 @@ void foo(unsigned long long *M)
}
}
-/* { dg-final { scan-tree-dump-times "join point for if-convertible" 1
"split-paths" } } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-12.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-12.c
similarity index 70%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-12.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-12.c
index da00f795ef0..dc9da4e90ef 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-12.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-12.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details " } */
double
foo(double *d1, double *d2, double *d3, int num, double *ip)
@@ -18,4 +16,3 @@ foo(double *d1, double *d2, double *d3, int num, double *ip)
/* Split-paths shouldn't do anything here, if there's a diamond it would
be if-convertible. */
-/* { dg-final { scan-tree-dump-not "Duplicating join block" "split-paths" } }
*/
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-13.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-13.c
similarity index 62%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-13.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-13.c
index d24e23bc59d..554ae4d8f39 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-13.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-13.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details " } */
/* PR tree-optimization/112402 */
/* This is similar to split-path-2.c but instead of the add
being inside both sides, we have a constant. */
@@ -22,5 +20,4 @@ foo(signed char *p, int n)
return s;
}
-/* { dg-final { scan-tree-dump "appears to be a join point for if-convertible"
"split-paths" } } */
diff --git a/gcc/testsuite/gcc.c-torture/compile/split-path-2.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-2.c
new file mode 100644
index 00000000000..9418c9488d4
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-2.c
@@ -0,0 +1,18 @@
+
+int
+foo(signed char *p, int n)
+{
+ int s = 0;
+ int i;
+
+ for (i = 0; i < n; i++) {
+ if (p[i] >= 0)
+ s++;
+ else
+ s--;
+ }
+
+ return s;
+}
+
+
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-3.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-3.c
similarity index 93%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-3.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-3.c
index f6a29f628a2..9ea9fb2fed1 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-3.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-3.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details -w" } */
typedef struct bitmap_head_def *bitmap;
extern void vec_assert_fail (const char *, const char *, const char *file_,
@@ -94,4 +92,3 @@ compute_idf (bitmap_head * dfs)
(VEC_int_heap_free (&work_stack));
}
-/* { dg-final { scan-tree-dump-not "Duplicating join block" "split-paths" } }
*/
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-4.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-4.c
similarity index 62%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-4.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-4.c
index cbee6fce4b7..6705f9e8426 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-4.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-4.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details -w
-fdisable-tree-thread1 -fdisable-tree-thread2" } */
/* Note: Threader causes the infinite loop in val & 1 sooner. */
@@ -25,5 +23,4 @@ powi_cost (long n)
}
}
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 1 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-5.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-5.c
similarity index 84%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-5.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-5.c
index 2f5e7edcfa8..aff1f038195 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-5.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-5.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details -w" } */
const extern signed char *__ctype_ptr__;
typedef unsigned char uchar;
@@ -41,4 +39,3 @@ bmhi_init (const signed char *pattern)
}
}
-/* { dg-final { scan-tree-dump-times "join point for if-convertible" 1
"split-paths" } } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-6.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-6.c
similarity index 82%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-6.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-6.c
index e2b0a9571f0..9c32c813b60 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-6.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-6.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fno-tree-cselim -fno-ssa-phiopt
-fdump-tree-split-paths-details -fno-finite-loops -fno-tree-dominator-opts
-fno-tree-vrp -w" } */
struct __sFILE
{
@@ -75,4 +73,3 @@ lookharder (char *string)
}
}
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 2 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-7.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-7.c
similarity index 87%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-7.c
rename to gcc/testsuite/gcc.c-torture/compile/split-path-7.c
index 35634ab3bd8..33d04b4ff7d 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-7.c
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-7.c
@@ -1,5 +1,3 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fno-tree-cselim -fno-ssa-phiopt
-fno-tree-sink -fdump-tree-split-paths-details -w" } */
struct _reent
@@ -91,4 +89,3 @@ linit ()
}
}
}
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 0 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.c-torture/compile/split-path-8.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-8.c
new file mode 100644
index 00000000000..cccbf0ca0a3
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-8.c
@@ -0,0 +1,11 @@
+/* PR77283 */
+
+void
+foo (double *x, double *a, double *b, long n, double limit)
+{
+ long i;
+ for (i=0; i < n; i++)
+ if (a[i] < limit)
+ x[i] = b[i];
+}
+
diff --git a/gcc/testsuite/gcc.c-torture/compile/split-path-9.c
b/gcc/testsuite/gcc.c-torture/compile/split-path-9.c
new file mode 100644
index 00000000000..4eacad2978a
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/split-path-9.c
@@ -0,0 +1,14 @@
+/* PR77366 */
+
+void
+foo(unsigned int size, unsigned int *state)
+{
+ unsigned int i;
+
+ for(i = 0; i < size; i++)
+ {
+ if(state[i] & 1)
+ state[i] ^= 1;
+ }
+}
+
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-1.c
b/gcc/testsuite/gcc.c-torture/execute/split-path-1.c
similarity index 83%
rename from gcc/testsuite/gcc.dg/tree-ssa/split-path-1.c
rename to gcc/testsuite/gcc.c-torture/execute/split-path-1.c
index b670dee8d10..e0ca386b4ea 100644
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-1.c
+++ b/gcc/testsuite/gcc.c-torture/execute/split-path-1.c
@@ -1,6 +1,4 @@
-/* { dg-do run } */
/* Note both PHI-OPT and the loop if conversion pass converts the inner if to
be branchless using min/max. */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details --param
max-jump-thread-duplication-stmts=20 -fno-ssa-phiopt -fno-tree-loop-if-convert"
} */
#include <stdio.h>
#include <stdlib.h>
@@ -67,4 +65,3 @@ main()
return 0;
}
-/* { dg-final { scan-tree-dump "Duplicating join block" "split-paths" } } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-2.c
b/gcc/testsuite/gcc.dg/tree-ssa/split-path-2.c
deleted file mode 100644
index 61697a35e56..00000000000
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-2.c
+++ /dev/null
@@ -1,21 +0,0 @@
-/* { dg-do compile } */
-/* { dg-options "-O2 -fsplit-paths -fdump-tree-split-paths-details " } */
-
-int
-foo(signed char *p, int n)
-{
- int s = 0;
- int i;
-
- for (i = 0; i < n; i++) {
- if (p[i] >= 0)
- s++;
- else
- s--;
- }
-
- return s;
-}
-
-/* { dg-final { scan-tree-dump "appears to be a join point for if-convertible"
"split-paths" } } */
-
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-8.c
b/gcc/testsuite/gcc.dg/tree-ssa/split-path-8.c
deleted file mode 100644
index fb54f5dc512..00000000000
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-8.c
+++ /dev/null
@@ -1,14 +0,0 @@
-/* PR77283 */
-/* { dg-do compile } */
-/* { dg-options "-O3 -fdump-tree-split-paths-details" } */
-
-void
-foo (double *x, double *a, double *b, long n, double limit)
-{
- long i;
- for (i=0; i < n; i++)
- if (a[i] < limit)
- x[i] = b[i];
-}
-
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 0 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/split-path-9.c
b/gcc/testsuite/gcc.dg/tree-ssa/split-path-9.c
deleted file mode 100644
index 8be0cd01201..00000000000
--- a/gcc/testsuite/gcc.dg/tree-ssa/split-path-9.c
+++ /dev/null
@@ -1,17 +0,0 @@
-/* PR77366 */
-/* { dg-do compile } */
-/* { dg-options "-O3 -fdump-tree-split-paths-details" } */
-
-void
-foo(unsigned int size, unsigned int *state)
-{
- unsigned int i;
-
- for(i = 0; i < size; i++)
- {
- if(state[i] & 1)
- state[i] ^= 1;
- }
-}
-
-/* { dg-final { scan-tree-dump-times "Duplicating join block" 0 "split-paths"
} } */
diff --git a/gcc/testsuite/gcc.target/i386/pr106450.c
b/gcc/testsuite/gcc.target/i386/pr106450.c
index d16231f6abd..009e3eb8c74 100644
--- a/gcc/testsuite/gcc.target/i386/pr106450.c
+++ b/gcc/testsuite/gcc.target/i386/pr106450.c
@@ -1,5 +1,5 @@
/* { dg-do compile { target int128 } } */
-/* { dg-options "-O2 -fsplit-paths" } */
+/* { dg-options "-O2" } */
__int128 n;
diff --git a/gcc/timevar.def b/gcc/timevar.def
index 588d987ec35..c7020997609 100644
--- a/gcc/timevar.def
+++ b/gcc/timevar.def
@@ -287,7 +287,6 @@ DEFTIMEVAR (TV_GCSE_AFTER_RELOAD , "load CSE after
reload")
DEFTIMEVAR (TV_REE , "ree")
DEFTIMEVAR (TV_THREAD_PROLOGUE_AND_EPILOGUE, "thread pro- & epilogue")
DEFTIMEVAR (TV_IFCVT2 , "if-conversion 2")
-DEFTIMEVAR (TV_SPLIT_PATHS , "split paths")
DEFTIMEVAR (TV_COMBINE_STACK_ADJUST , "combine stack adjustments")
DEFTIMEVAR (TV_PEEPHOLE2 , "peephole 2")
DEFTIMEVAR (TV_RENAME_REGISTERS , "rename registers")
diff --git a/gcc/tree-pass.h b/gcc/tree-pass.h
index b3c97658a8f..a3b35e009e0 100644
--- a/gcc/tree-pass.h
+++ b/gcc/tree-pass.h
@@ -404,7 +404,6 @@ extern gimple_opt_pass *make_pass_ch (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_ch_vect (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_sccopy (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_ccp (gcc::context *ctxt);
-extern gimple_opt_pass *make_pass_split_paths (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_build_ssa (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_build_alias (gcc::context *ctxt);
extern gimple_opt_pass *make_pass_build_ealias (gcc::context *ctxt);
--
2.50.1 (Apple Git-155)