[PATCH] D124942: [BOLT][NFC] Fix MCPlusBuilder::getAliases caching behavior
Amir Ayupov via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed May 4 12:53:38 PDT 2022
This revision was automatically updated to reflect the committed changes.
Amir marked an inline comment as done.
Closed by commit rG68c7299f16aa: [BOLT][NFC] Fix MCPlusBuilder::getAliases caching behavior (authored by Amir).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124942/new/
https://reviews.llvm.org/D124942
Files:
bolt/include/bolt/Core/MCPlusBuilder.h
bolt/lib/Core/MCPlusBuilder.cpp
Index: bolt/lib/Core/MCPlusBuilder.cpp
===================================================================
--- bolt/lib/Core/MCPlusBuilder.cpp
+++ bolt/lib/Core/MCPlusBuilder.cpp
@@ -441,17 +441,13 @@
const BitVector &MCPlusBuilder::getAliases(MCPhysReg Reg,
bool OnlySmaller) const {
- // AliasMap caches a mapping of registers to the set of registers that
- // alias (are sub or superregs of itself, including itself).
- static std::vector<BitVector> AliasMap;
- static std::vector<BitVector> SmallerAliasMap;
-
- if (AliasMap.size() > 0) {
- if (OnlySmaller)
- return SmallerAliasMap[Reg];
- return AliasMap[Reg];
- }
+ if (OnlySmaller)
+ return SmallerAliasMap[Reg];
+ return AliasMap[Reg];
+}
+void MCPlusBuilder::initAliases() {
+ assert(AliasMap.size() == 0 && SmallerAliasMap.size() == 0);
// Build alias map
for (MCPhysReg I = 0, E = RegInfo->getNumRegs(); I != E; ++I) {
BitVector BV(RegInfo->getNumRegs(), false);
@@ -492,10 +488,6 @@
dbgs() << "\n";
}
});
-
- if (OnlySmaller)
- return SmallerAliasMap[Reg];
- return AliasMap[Reg];
}
uint8_t MCPlusBuilder::getRegSize(MCPhysReg Reg) const {
Index: bolt/include/bolt/Core/MCPlusBuilder.h
===================================================================
--- bolt/include/bolt/Core/MCPlusBuilder.h
+++ bolt/include/bolt/Core/MCPlusBuilder.h
@@ -282,6 +282,8 @@
// Initialize the default annotation allocator with id 0
AnnotationAllocators.emplace(0, AnnotationAllocator());
MaxAllocatorId++;
+ // Build alias map
+ initAliases();
}
/// Initialize a new annotation allocator and return its id
@@ -1135,6 +1137,9 @@
virtual const BitVector &getAliases(MCPhysReg Reg,
bool OnlySmaller = false) const;
+ /// Initialize aliases tables.
+ virtual void initAliases();
+
/// Change \p Regs setting all registers used to pass parameters according
/// to the host abi. Do nothing if not implemented.
virtual BitVector getRegsUsedAsParams() const {
@@ -1904,6 +1909,11 @@
llvm_unreachable("not implemented");
return BlocksVectorTy();
}
+
+ // AliasMap caches a mapping of registers to the set of registers that
+ // alias (are sub or superregs of itself, including itself).
+ std::vector<BitVector> AliasMap;
+ std::vector<BitVector> SmallerAliasMap;
};
MCPlusBuilder *createX86MCPlusBuilder(const MCInstrAnalysis *,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D124942.427111.patch
Type: text/x-patch
Size: 2480 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220504/bd23c640/attachment.bin>
More information about the llvm-commits
mailing list