CodeGen/LiveVariables: switch to std::vector

No functionality change.

llvm-svn: 216367
This commit is contained in:
Dylan Noblesmith 2014-08-25 01:59:42 +00:00
parent b899464f5b
commit 46a922c191
2 changed files with 16 additions and 14 deletions

View File

@ -134,14 +134,14 @@ private: // Intermediate data structures
// PhysRegInfo - Keep track of which instruction was the last def of a
// physical register. This is a purely local property, because all physical
// register references are presumed dead across basic blocks.
MachineInstr **PhysRegDef;
std::vector<MachineInstr *> PhysRegDef;
// PhysRegInfo - Keep track of which instruction was the last use of a
// physical register. This is a purely local property, because all physical
// register references are presumed dead across basic blocks.
MachineInstr **PhysRegUse;
std::vector<MachineInstr *> PhysRegUse;
SmallVector<unsigned, 4> *PHIVarInfo;
std::vector<SmallVector<unsigned, 4>> PHIVarInfo;
// DistanceMap - Keep track the distance of a MI from the start of the
// current basic block.

View File

@ -502,12 +502,12 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &mf) {
MRI = &mf.getRegInfo();
TRI = MF->getSubtarget().getRegisterInfo();
unsigned NumRegs = TRI->getNumRegs();
PhysRegDef = new MachineInstr*[NumRegs];
PhysRegUse = new MachineInstr*[NumRegs];
PHIVarInfo = new SmallVector<unsigned, 4>[MF->getNumBlockIDs()];
std::fill(PhysRegDef, PhysRegDef + NumRegs, nullptr);
std::fill(PhysRegUse, PhysRegUse + NumRegs, nullptr);
const unsigned NumRegs = TRI->getNumRegs();
PhysRegDef.clear();
PhysRegUse.clear();
PhysRegDef.resize(NumRegs, nullptr);
PhysRegUse.resize(NumRegs, nullptr);
PHIVarInfo.resize(MF->getNumBlockIDs());
PHIJoins.clear();
// FIXME: LiveIntervals will be updated to remove its dependence on
@ -637,8 +637,10 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &mf) {
if ((PhysRegDef[i] || PhysRegUse[i]) && !LiveOuts.count(i))
HandlePhysRegDef(i, nullptr, Defs);
std::fill(PhysRegDef, PhysRegDef + NumRegs, nullptr);
std::fill(PhysRegUse, PhysRegUse + NumRegs, nullptr);
PhysRegDef.clear();
PhysRegUse.clear();
PhysRegDef.resize(NumRegs, nullptr);
PhysRegUse.resize(NumRegs, nullptr);
}
// Convert and transfer the dead / killed information we have gathered into
@ -660,9 +662,9 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &mf) {
assert(Visited.count(&*i) != 0 && "unreachable basic block found");
#endif
delete[] PhysRegDef;
delete[] PhysRegUse;
delete[] PHIVarInfo;
PhysRegDef.clear();
PhysRegUse.clear();
PHIVarInfo.clear();
return false;
}