mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
CodeGen/LiveVariables: switch to std::vector
No functionality change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216367 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2c6a26dc68
commit
20d7da5b79
@ -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.
|
||||
|
@ -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;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user