[llvm] [Analysis] Avoid repeated hash lookups (NFC) (PR #125813)
via llvm-commits
llvm-commits at lists.llvm.org
Tue Feb 4 23:18:53 PST 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-llvm-analysis
Author: Kazu Hirata (kazutakahirata)
<details>
<summary>Changes</summary>
---
Full diff: https://github.com/llvm/llvm-project/pull/125813.diff
1 Files Affected:
- (modified) llvm/include/llvm/Analysis/VectorUtils.h (+5-6)
``````````diff
diff --git a/llvm/include/llvm/Analysis/VectorUtils.h b/llvm/include/llvm/Analysis/VectorUtils.h
index 5d41d1cd14ef455..f21594c557e0ec5 100644
--- a/llvm/include/llvm/Analysis/VectorUtils.h
+++ b/llvm/include/llvm/Analysis/VectorUtils.h
@@ -748,12 +748,11 @@ class InterleavedAccessInfo {
/// \returns the newly created interleave group.
InterleaveGroup<Instruction> *
createInterleaveGroup(Instruction *Instr, int Stride, Align Alignment) {
- assert(!InterleaveGroupMap.count(Instr) &&
- "Already in an interleaved access group");
- InterleaveGroupMap[Instr] =
- new InterleaveGroup<Instruction>(Instr, Stride, Alignment);
- InterleaveGroups.insert(InterleaveGroupMap[Instr]);
- return InterleaveGroupMap[Instr];
+ auto [It, Inserted] = InterleaveGroupMap.try_emplace(Instr);
+ assert(Inserted && "Already in an interleaved access group");
+ It->second = new InterleaveGroup<Instruction>(Instr, Stride, Alignment);
+ InterleaveGroups.insert(It->second);
+ return It->second;
}
/// Release the group and remove all the relationships.
``````````
</details>
https://github.com/llvm/llvm-project/pull/125813
More information about the llvm-commits
mailing list