[llvm] [PartialInlining] Use DenseSet instead of DenseMap (NFC) (PR #127170)
Kazu Hirata via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 14 01:27:13 PST 2025
https://github.com/kazutakahirata updated https://github.com/llvm/llvm-project/pull/127170
>From 29c0dac3d3944d5aadf3eb1be4f857a11290db9d Mon Sep 17 00:00:00 2001
From: Kazu Hirata <kazu at google.com>
Date: Thu, 13 Feb 2025 12:39:42 -0800
Subject: [PATCH 1/2] [PartialInlining] Use DenseSet instead of DenseMap (NFC)
This patch changes the type of VisitedMap to DenseSet from DenseMap
because the value side of the map is always "true".
Technically:
if (VisitedMap[*SI])
inserts "false" as a value, but the value is immediately overridden
with:
VisitedMap[*SI] = true;
While we are at it, this patch removes the repeated hash lookups
around the "if" statement.
---
llvm/lib/Transforms/IPO/PartialInlining.cpp | 9 ++++-----
1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/llvm/lib/Transforms/IPO/PartialInlining.cpp b/llvm/lib/Transforms/IPO/PartialInlining.cpp
index cead7b84c3fc8..ea75b637c1646 100644
--- a/llvm/lib/Transforms/IPO/PartialInlining.cpp
+++ b/llvm/lib/Transforms/IPO/PartialInlining.cpp
@@ -412,9 +412,9 @@ PartialInlinerImpl::computeOutliningColdRegionsInfo(
bool ColdCandidateFound = false;
BasicBlock *CurrEntry = EntryBlock;
std::vector<BasicBlock *> DFS;
- DenseMap<BasicBlock *, bool> VisitedMap;
+ DenseSet<BasicBlock *> VisitedSet;
DFS.push_back(CurrEntry);
- VisitedMap[CurrEntry] = true;
+ VisitedSet.insert(CurrEntry);
// Use Depth First Search on the basic blocks to find CFG edges that are
// considered cold.
@@ -432,9 +432,8 @@ PartialInlinerImpl::computeOutliningColdRegionsInfo(
BBProfileCount(ThisBB) < MinBlockCounterExecution)
continue;
for (auto SI = succ_begin(ThisBB); SI != succ_end(ThisBB); ++SI) {
- if (VisitedMap[*SI])
+ if (!VisitedSet.insert(*SI).second)
continue;
- VisitedMap[*SI] = true;
DFS.push_back(*SI);
// If branch isn't cold, we skip to the next one.
BranchProbability SuccProb = BPI.getEdgeProbability(ThisBB, *SI);
@@ -492,7 +491,7 @@ PartialInlinerImpl::computeOutliningColdRegionsInfo(
// at inner regions because the outer region may have live-exit
// variables.
for (auto *BB : DominateVector)
- VisitedMap[BB] = true;
+ VisitedSet.insert(BB);
// ReturnBlock here means the block after the outline call
BasicBlock *ReturnBlock = ExitBlock->getSingleSuccessor();
>From ecbb5193ddc11b10cf6daaa3a7041229403366d0 Mon Sep 17 00:00:00 2001
From: Kazu Hirata <kazu at google.com>
Date: Fri, 14 Feb 2025 01:26:58 -0800
Subject: [PATCH 2/2] Address a comment.
---
llvm/lib/Transforms/IPO/PartialInlining.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/llvm/lib/Transforms/IPO/PartialInlining.cpp b/llvm/lib/Transforms/IPO/PartialInlining.cpp
index ea75b637c1646..f2707afe195c4 100644
--- a/llvm/lib/Transforms/IPO/PartialInlining.cpp
+++ b/llvm/lib/Transforms/IPO/PartialInlining.cpp
@@ -412,7 +412,7 @@ PartialInlinerImpl::computeOutliningColdRegionsInfo(
bool ColdCandidateFound = false;
BasicBlock *CurrEntry = EntryBlock;
std::vector<BasicBlock *> DFS;
- DenseSet<BasicBlock *> VisitedSet;
+ SmallPtrSet<BasicBlock *, 8> VisitedSet;
DFS.push_back(CurrEntry);
VisitedSet.insert(CurrEntry);
More information about the llvm-commits
mailing list