[llvm] [NFC][IR] Wrap std::set into CfiFunctionIndex (PR #130361)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 7 14:46:06 PST 2025
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-llvm-ir
Author: Vitaly Buka (vitalybuka)
<details>
<summary>Changes</summary>
Preparation for CFI Index refactoring,
which will fix O(N^2) in ThinLTO indexing.
We need a data structure to lookup by GUID.
Wrapping allow us to change implementation
with minimal changes to users.
---
Full diff: https://github.com/llvm/llvm-project/pull/130361.diff
1 Files Affected:
- (modified) llvm/include/llvm/IR/ModuleSummaryIndex.h (+30-14)
``````````diff
diff --git a/llvm/include/llvm/IR/ModuleSummaryIndex.h b/llvm/include/llvm/IR/ModuleSummaryIndex.h
index 3c586a1dd21d8..ada6bb259dc37 100644
--- a/llvm/include/llvm/IR/ModuleSummaryIndex.h
+++ b/llvm/include/llvm/IR/ModuleSummaryIndex.h
@@ -1289,6 +1289,30 @@ struct TypeIdSummary {
std::map<uint64_t, WholeProgramDevirtResolution> WPDRes;
};
+class CfiFunctionIndex {
+ std::set<std::string, std::less<>> Index;
+
+public:
+ CfiFunctionIndex() = default;
+
+ template <typename It>
+ CfiFunctionIndex(It B, It E) : Index(B, E) {}
+
+ std::set<std::string, std::less<>>::const_iterator begin() const {
+ return Index.begin();
+ }
+
+ std::set<std::string, std::less<>>::const_iterator end() const {
+ return Index.end();
+ }
+
+ template <typename... Args> void emplace(Args &&...A) {
+ Index.emplace(std::forward<Args>(A)...);
+ }
+
+ size_t count(StringRef S) const { return Index.count(S); }
+};
+
/// 160 bits SHA1
using ModuleHash = std::array<uint32_t, 5>;
@@ -1418,8 +1442,8 @@ class ModuleSummaryIndex {
/// True if some of the FunctionSummary contains a ParamAccess.
bool HasParamAccess = false;
- std::set<std::string, std::less<>> CfiFunctionDefs;
- std::set<std::string, std::less<>> CfiFunctionDecls;
+ CfiFunctionIndex CfiFunctionDefs;
+ CfiFunctionIndex CfiFunctionDecls;
// Used in cases where we want to record the name of a global, but
// don't have the string owned elsewhere (e.g. the Strtab on a module).
@@ -1667,19 +1691,11 @@ class ModuleSummaryIndex {
return I == OidGuidMap.end() ? 0 : I->second;
}
- std::set<std::string, std::less<>> &cfiFunctionDefs() {
- return CfiFunctionDefs;
- }
- const std::set<std::string, std::less<>> &cfiFunctionDefs() const {
- return CfiFunctionDefs;
- }
+ CfiFunctionIndex &cfiFunctionDefs() { return CfiFunctionDefs; }
+ const CfiFunctionIndex &cfiFunctionDefs() const { return CfiFunctionDefs; }
- std::set<std::string, std::less<>> &cfiFunctionDecls() {
- return CfiFunctionDecls;
- }
- const std::set<std::string, std::less<>> &cfiFunctionDecls() const {
- return CfiFunctionDecls;
- }
+ CfiFunctionIndex &cfiFunctionDecls() { return CfiFunctionDecls; }
+ const CfiFunctionIndex &cfiFunctionDecls() const { return CfiFunctionDecls; }
/// Add a global value summary for a value.
void addGlobalValueSummary(const GlobalValue &GV,
``````````
</details>
https://github.com/llvm/llvm-project/pull/130361
More information about the llvm-commits
mailing list