diff options
author | Alkis Evlogimenos <alkis@evlogimenos.com> | 2004-08-26 22:21:04 +0000 |
---|---|---|
committer | Alkis Evlogimenos <alkis@evlogimenos.com> | 2004-08-26 22:21:04 +0000 |
commit | bb4bdf4fe4c931e45d0a37e24ec79accd815c1d8 (patch) | |
tree | e151817a9c1f731fe1917b0f7b42c00ac86ea712 /lib/Target/MRegisterInfo.cpp | |
parent | 3921c74652d50ca69427e1109105c43b2e25124f (diff) |
Add getAllocatableSet() function.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16059 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/MRegisterInfo.cpp')
-rw-r--r-- | lib/Target/MRegisterInfo.cpp | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/lib/Target/MRegisterInfo.cpp b/lib/Target/MRegisterInfo.cpp index 7c1028bc32..30b54a6414 100644 --- a/lib/Target/MRegisterInfo.cpp +++ b/lib/Target/MRegisterInfo.cpp @@ -28,12 +28,14 @@ MRegisterInfo::MRegisterInfo(const MRegisterDesc *D, unsigned NR, // Fill in the PhysRegClasses map for (MRegisterInfo::regclass_iterator I = regclass_begin(), - E = regclass_end(); I != E; ++I) - for (unsigned i = 0, e = (*I)->getNumRegs(); i != e; ++i) { - unsigned Reg = (*I)->getRegister(i); + E = regclass_end(); I != E; ++I) { + const TargetRegisterClass *RC = *I; + for (unsigned i = 0, e = RC->getNumRegs(); i != e; ++i) { + unsigned Reg = RC->getRegister(i); assert(PhysRegClasses[Reg] == 0 && "Register in more than one class?"); - PhysRegClasses[Reg] = *I; + PhysRegClasses[Reg] = RC; } + } CallFrameSetupOpcode = CFSO; CallFrameDestroyOpcode = CFDO; @@ -44,4 +46,16 @@ MRegisterInfo::~MRegisterInfo() { delete[] PhysRegClasses; } +std::vector<bool> MRegisterInfo::getAllocatableSet(MachineFunction &MF) const { + std::vector<bool> Allocatable(NumRegs); + for (MRegisterInfo::regclass_iterator I = regclass_begin(), + E = regclass_end(); I != E; ++I) { + const TargetRegisterClass *RC = *I; + for (TargetRegisterClass::iterator I = RC->allocation_order_begin(MF), + E = RC->allocation_order_end(MF); I != E; ++I) + Allocatable[*I] = true; + } + return Allocatable; +} + } // End llvm namespace |