[llvm] [SimplifyCFG] Use hash map to continue hoisting the common instructions (PR #78615)

Yingwei Zheng via llvm-commits llvm-commits at lists.llvm.org
Sat Mar 9 04:10:56 PST 2024


================
@@ -1608,16 +1618,39 @@ bool SimplifyCFGOpt::hoistCommonCodeFromSuccessors(BasicBlock *BB,
 
   auto *TI = BB->getTerminator();
 
+  SmallVector<BasicBlock *, 8> SuccessorBBs;
+  for (auto *Succ : successors(BB)) {
+    BasicBlock::iterator SuccItr = Succ->begin();
+    // If we find an unreachable instruction at the beginning of a basic block,
+    // we can still hoist instructions from the rest of the basic blocks.
+    if (isa<UnreachableInst>(*SuccItr))
+      continue;
+    SuccessorBBs.push_back(Succ);
+  }
+
+  // Find the smallest BB because we always want to iterate over instructions
+  // of the smallest Successor.
+  auto *SmallestBB = *std::min_element(SuccessorBBs.begin(), SuccessorBBs.end(),
+                                       [](BasicBlock *BB1, BasicBlock *BB2) {
+                                         return BB1->size() < BB2->size();
+                                       });
+  std::iter_swap(
+      SuccessorBBs.begin(),
+      std::find(SuccessorBBs.begin(), SuccessorBBs.end(), SmallestBB));
----------------
dtcxzyw wrote:

```suggestion
  auto *SmallestBBPos = std::min_element(SuccessorBBs.begin(), SuccessorBBs.end(),
                                       [](BasicBlock *BB1, BasicBlock *BB2) {
                                         return BB1->size() < BB2->size();
                                       });
  std::iter_swap(
      SuccessorBBs.begin(),
      SmallestBBPos);
  BasicBlock *SmallestBB = *SmallestBBPos;
```

https://github.com/llvm/llvm-project/pull/78615


More information about the llvm-commits mailing list