diff options
author | Owen Anderson <resistor@mac.com> | 2008-06-27 06:56:04 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2008-06-27 06:56:04 +0000 |
commit | 1360b7d8f8d1969026870d18c582b4e3a7cff8b8 (patch) | |
tree | d5acfde18f12d4dd270d333944e2f2bec4976f58 | |
parent | 3648f9f0ae79532c6bdc9c6188d0e46676de212f (diff) |
Cache subregister relationships in a set in TargetRegisterInfo to allow faster lookups.
This speeds up LiveVariables from 0.6279s to 0.6165s on kimwitu++.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52818 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Target/TargetRegisterInfo.h | 6 | ||||
-rw-r--r-- | lib/Target/TargetRegisterInfo.cpp | 10 |
2 files changed, 13 insertions, 3 deletions
diff --git a/include/llvm/Target/TargetRegisterInfo.h b/include/llvm/Target/TargetRegisterInfo.h index 2deede235f..68460b30cb 100644 --- a/include/llvm/Target/TargetRegisterInfo.h +++ b/include/llvm/Target/TargetRegisterInfo.h @@ -21,6 +21,7 @@ #include "llvm/CodeGen/ValueTypes.h" #include <cassert> #include <functional> +#include <set> namespace llvm { @@ -285,6 +286,7 @@ private: regclass_iterator RegClassBegin, RegClassEnd; // List of regclasses int CallFrameSetupOpcode, CallFrameDestroyOpcode; + std::set<std::pair<unsigned, unsigned> > Subregs; protected: TargetRegisterInfo(const TargetRegisterDesc *D, unsigned NR, regclass_iterator RegClassBegin, @@ -419,9 +421,7 @@ public: /// isSubRegister - Returns true if regB is a sub-register of regA. /// bool isSubRegister(unsigned regA, unsigned regB) const { - for (const unsigned *SR = getSubRegisters(regA); *SR; ++SR) - if (*SR == regB) return true; - return false; + return Subregs.count(std::make_pair(regA, regB)); } /// isSuperRegister - Returns true if regB is a super-register of regA. diff --git a/lib/Target/TargetRegisterInfo.cpp b/lib/Target/TargetRegisterInfo.cpp index 3f44a0cb5a..e69496f4b2 100644 --- a/lib/Target/TargetRegisterInfo.cpp +++ b/lib/Target/TargetRegisterInfo.cpp @@ -29,6 +29,16 @@ TargetRegisterInfo::TargetRegisterInfo(const TargetRegisterDesc *D, unsigned NR, CallFrameSetupOpcode = CFSO; CallFrameDestroyOpcode = CFDO; + + for (unsigned i = 0; i < NumRegs; ++i) { + const TargetRegisterDesc* CurrReg = Desc + i; + + // Initialize the Subregs set, which stores pairs (a, b) where + // b is a subreg of a. + if (CurrReg->SubRegs) + for (const unsigned* CurrSR = CurrReg->SubRegs; *CurrSR; ++CurrSR) + Subregs.insert(std::make_pair(i, *CurrSR)); + } } TargetRegisterInfo::~TargetRegisterInfo() {} |