[llvm] [Transforms] Avoid repeated hash lookups (NFC) (PR #130238)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 6 20:49:45 PST 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-coroutines
Author: Kazu Hirata (kazutakahirata)
<details>
<summary>Changes</summary>
---
Full diff: https://github.com/llvm/llvm-project/pull/130238.diff
1 Files Affected:
- (modified) llvm/lib/Transforms/Coroutines/CoroFrame.cpp (+4-3)
``````````diff
diff --git a/llvm/lib/Transforms/Coroutines/CoroFrame.cpp b/llvm/lib/Transforms/Coroutines/CoroFrame.cpp
index 62fa3af502e29..2f5f1089067bf 100644
--- a/llvm/lib/Transforms/Coroutines/CoroFrame.cpp
+++ b/llvm/lib/Transforms/Coroutines/CoroFrame.cpp
@@ -785,7 +785,8 @@ static void buildFrameDebugInfo(Function &F, coro::Shape &Shape,
// fields confilicts with each other.
unsigned UnknownTypeNum = 0;
for (unsigned Index = 0; Index < FrameTy->getNumElements(); Index++) {
- if (!OffsetCache.contains(Index))
+ auto OCIt = OffsetCache.find(Index);
+ if (OCIt == OffsetCache.end())
continue;
std::string Name;
@@ -797,8 +798,8 @@ static void buildFrameDebugInfo(Function &F, coro::Shape &Shape,
Type *Ty = FrameTy->getElementType(Index);
assert(Ty->isSized() && "We can't handle type which is not sized.\n");
SizeInBits = Layout.getTypeSizeInBits(Ty).getFixedValue();
- AlignInBits = OffsetCache[Index].first * 8;
- OffsetInBits = OffsetCache[Index].second * 8;
+ AlignInBits = OCIt->second.first * 8;
+ OffsetInBits = OCIt->second.second * 8;
if (auto It = NameCache.find(Index); It != NameCache.end()) {
Name = It->second.str();
``````````
</details>
https://github.com/llvm/llvm-project/pull/130238
More information about the llvm-commits
mailing list