[llvm] [VPlan] Add initial CFG simplification, removing BranchOnCond true. (PR #106748)
via llvm-commits
llvm-commits at lists.llvm.org
Sun Mar 23 04:01:34 PDT 2025
================
@@ -1467,6 +1467,49 @@ void VPlanTransforms::truncateToMinimalBitwidths(
"some entries in MinBWs haven't been processed");
}
+/// Remove BranchOnCond recipes with true conditions together with removing
+/// dead edges to their successors.
+static void simplifyCFG(VPlan &Plan) {
+ using namespace llvm::VPlanPatternMatch;
+ for (VPBasicBlock *VPBB : VPBlockUtils::blocksOnly<VPBasicBlock>(
+ vp_depth_first_deep(Plan.getEntry()))) {
+ if (VPBB->getNumSuccessors() != 2 ||
+ !match(&VPBB->back(), m_BranchOnCond(m_True())))
+ continue;
+
+ VPBasicBlock *RemovedSucc = cast<VPBasicBlock>(VPBB->getSuccessors()[1]);
+ const auto &Preds = RemovedSucc->getPredecessors();
+ unsigned DeadIdx = std::distance(Preds.begin(), find(Preds, VPBB));
+
+ // Remove values coming from VPBB from phi-like recipes in RemovedSucc.
----------------
ayalz wrote:
```suggestion
// Values coming from VPBB into ResumePhi recipes of RemoveSucc are removed from these recipes.
```
clarifying double from.
https://github.com/llvm/llvm-project/pull/106748
More information about the llvm-commits
mailing list