aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/llvm/Target/MRegisterInfo.h2
-rw-r--r--lib/Target/MRegisterInfo.cpp20
2 files changed, 1 insertions, 21 deletions
diff --git a/include/llvm/Target/MRegisterInfo.h b/include/llvm/Target/MRegisterInfo.h
index c3cc768..340c811 100644
--- a/include/llvm/Target/MRegisterInfo.h
+++ b/include/llvm/Target/MRegisterInfo.h
@@ -124,7 +124,7 @@ protected:
MRegisterInfo(const MRegisterDesc *D, unsigned NR,
regclass_iterator RegClassBegin, regclass_iterator RegClassEnd,
int CallFrameSetupOpcode = -1, int CallFrameDestroyOpcode = -1);
- virtual ~MRegisterInfo();
+ virtual ~MRegisterInfo() {}
public:
enum { // Define some target independent constants
diff --git a/lib/Target/MRegisterInfo.cpp b/lib/Target/MRegisterInfo.cpp
index 30b54a6..5b8c8e1 100644
--- a/lib/Target/MRegisterInfo.cpp
+++ b/lib/Target/MRegisterInfo.cpp
@@ -22,30 +22,10 @@ MRegisterInfo::MRegisterInfo(const MRegisterDesc *D, unsigned NR,
assert(NumRegs < FirstVirtualRegister &&
"Target has too many physical registers!");
- PhysRegClasses = new const TargetRegisterClass*[NumRegs];
- for (unsigned i = 0; i != NumRegs; ++i)
- PhysRegClasses[i] = 0;
-
- // Fill in the PhysRegClasses map
- for (MRegisterInfo::regclass_iterator I = regclass_begin(),
- 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] = RC;
- }
- }
-
CallFrameSetupOpcode = CFSO;
CallFrameDestroyOpcode = CFDO;
}
-
-MRegisterInfo::~MRegisterInfo() {
- delete[] PhysRegClasses;
-}
-
std::vector<bool> MRegisterInfo::getAllocatableSet(MachineFunction &MF) const {
std::vector<bool> Allocatable(NumRegs);
for (MRegisterInfo::regclass_iterator I = regclass_begin(),