mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-03 13:51:39 +00:00
Update DBG_VALUEs while breaking anti dependencies.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132487 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
201cfcd6de
commit
e29e8e100e
@ -719,7 +719,9 @@ unsigned AggressiveAntiDepBreaker::BreakAntiDependencies(
|
||||
const std::vector<SUnit>& SUnits,
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex) {
|
||||
unsigned InsertPosIndex,
|
||||
DbgValueVector &DbgValues) {
|
||||
|
||||
std::vector<unsigned> &KillIndices = State->GetKillIndices();
|
||||
std::vector<unsigned> &DefIndices = State->GetDefIndices();
|
||||
std::multimap<unsigned, AggressiveAntiDepState::RegisterReference>&
|
||||
@ -923,14 +925,10 @@ unsigned AggressiveAntiDepBreaker::BreakAntiDependencies(
|
||||
// sure to update that as well.
|
||||
const SUnit *SU = MISUnitMap[Q->second.Operand->getParent()];
|
||||
if (!SU) continue;
|
||||
for (unsigned i = 0, e = SU->DbgInstrList.size() ; i < e ; ++i) {
|
||||
MachineInstr *DI = SU->DbgInstrList[i];
|
||||
assert (DI->getNumOperands()==3 && DI->getOperand(0).isReg() &&
|
||||
DI->getOperand(0).getReg()
|
||||
&& "Non register dbg_value attached to SUnit!");
|
||||
if (DI->getOperand(0).getReg() == AntiDepReg)
|
||||
DI->getOperand(0).setReg(NewReg);
|
||||
}
|
||||
for (DbgValueVector::iterator DVI = DbgValues.begin(),
|
||||
DVE = DbgValues.end(); DVI != DVE; ++DVI)
|
||||
if (DVI->second == Q->second.Operand->getParent())
|
||||
UpdateDbgValue(DVI->first, AntiDepReg, NewReg);
|
||||
}
|
||||
|
||||
// We just went back in time and modified history; the
|
||||
|
@ -146,7 +146,8 @@ namespace llvm {
|
||||
unsigned BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex);
|
||||
unsigned InsertPosIndex,
|
||||
DbgValueVector &DbgValues);
|
||||
|
||||
/// Observe - Update liveness information to account for the current
|
||||
/// instruction, which will not be scheduled.
|
||||
|
@ -30,6 +30,9 @@ namespace llvm {
|
||||
/// anti-dependencies.
|
||||
class AntiDepBreaker {
|
||||
public:
|
||||
typedef std::vector<std::pair<MachineInstr *, MachineInstr *> >
|
||||
DbgValueVector;
|
||||
|
||||
virtual ~AntiDepBreaker();
|
||||
|
||||
/// Start - Initialize anti-dep breaking for a new basic block.
|
||||
@ -40,9 +43,10 @@ public:
|
||||
/// the number of anti-dependencies broken.
|
||||
///
|
||||
virtual unsigned BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex) =0;
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex,
|
||||
DbgValueVector &DbgValues) = 0;
|
||||
|
||||
/// Observe - Update liveness information to account for the current
|
||||
/// instruction, which will not be scheduled.
|
||||
@ -52,6 +56,14 @@ public:
|
||||
|
||||
/// Finish - Finish anti-dep breaking for a basic block.
|
||||
virtual void FinishBlock() =0;
|
||||
|
||||
/// UpdateDbgValue - Update DBG_VALUE if dependency breaker is updating
|
||||
/// other machine instruction to use NewReg.
|
||||
void UpdateDbgValue(MachineInstr *MI, unsigned OldReg, unsigned NewReg) {
|
||||
assert (MI->isDebugValue() && "MI is not DBG_VALUE!");
|
||||
if (MI && MI->getOperand(0).isReg() && MI->getOperand(0).getReg() == OldReg)
|
||||
MI->getOperand(0).setReg(NewReg);
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
|
@ -421,7 +421,8 @@ unsigned CriticalAntiDepBreaker::
|
||||
BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex) {
|
||||
unsigned InsertPosIndex,
|
||||
DbgValueVector &DbgValues) {
|
||||
// The code below assumes that there is at least one instruction,
|
||||
// so just duck out immediately if the block is empty.
|
||||
if (SUnits.empty()) return 0;
|
||||
@ -628,14 +629,10 @@ BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
||||
// as well.
|
||||
const SUnit *SU = MISUnitMap[Q->second->getParent()];
|
||||
if (!SU) continue;
|
||||
for (unsigned i = 0, e = SU->DbgInstrList.size() ; i < e ; ++i) {
|
||||
MachineInstr *DI = SU->DbgInstrList[i];
|
||||
assert (DI->getNumOperands()==3 && DI->getOperand(0).isReg() &&
|
||||
DI->getOperand(0).getReg()
|
||||
&& "Non register dbg_value attached to SUnit!");
|
||||
if (DI->getOperand(0).getReg() == AntiDepReg)
|
||||
DI->getOperand(0).setReg(NewReg);
|
||||
}
|
||||
for (DbgValueVector::iterator DVI = DbgValues.begin(),
|
||||
DVE = DbgValues.end(); DVI != DVE; ++DVI)
|
||||
if (DVI->second == Q->second->getParent())
|
||||
UpdateDbgValue(DVI->first, AntiDepReg, NewReg);
|
||||
}
|
||||
|
||||
// We just went back in time and modified history; the
|
||||
|
@ -79,7 +79,8 @@ class TargetRegisterInfo;
|
||||
unsigned BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
||||
MachineBasicBlock::iterator Begin,
|
||||
MachineBasicBlock::iterator End,
|
||||
unsigned InsertPosIndex);
|
||||
unsigned InsertPosIndex,
|
||||
DbgValueVector &DbgValues);
|
||||
|
||||
/// Observe - Update liveness information to account for the current
|
||||
/// instruction, which will not be scheduled.
|
||||
|
@ -304,7 +304,7 @@ void SchedulePostRATDList::Schedule() {
|
||||
if (AntiDepBreak != NULL) {
|
||||
unsigned Broken =
|
||||
AntiDepBreak->BreakAntiDependencies(SUnits, Begin, InsertPos,
|
||||
InsertPosIndex);
|
||||
InsertPosIndex, DbgValues);
|
||||
|
||||
if (Broken != 0) {
|
||||
// We made changes. Update the dependency graph.
|
||||
|
@ -36,7 +36,7 @@ ScheduleDAGInstrs::ScheduleDAGInstrs(MachineFunction &mf,
|
||||
: ScheduleDAG(mf), MLI(mli), MDT(mdt), MFI(mf.getFrameInfo()),
|
||||
InstrItins(mf.getTarget().getInstrItineraryData()),
|
||||
Defs(TRI->getNumRegs()), Uses(TRI->getNumRegs()),
|
||||
FirstDbgValue(0), LoopRegs(MLI, MDT) {
|
||||
LoopRegs(MLI, MDT), FirstDbgValue(0) {
|
||||
DbgValues.clear();
|
||||
}
|
||||
|
||||
|
@ -110,10 +110,6 @@ namespace llvm {
|
||||
std::vector<std::vector<SUnit *> > Defs;
|
||||
std::vector<std::vector<SUnit *> > Uses;
|
||||
|
||||
/// DbgValues - Remember instruction that preceeds DBG_VALUE.
|
||||
std::vector<std::pair<MachineInstr *, MachineInstr *> >DbgValues;
|
||||
MachineInstr *FirstDbgValue;
|
||||
|
||||
/// PendingLoads - Remember where unknown loads are after the most recent
|
||||
/// unknown store, as we iterate. As with Defs and Uses, this is here
|
||||
/// to minimize construction/destruction.
|
||||
@ -128,6 +124,14 @@ namespace llvm {
|
||||
///
|
||||
SmallSet<unsigned, 8> LoopLiveInRegs;
|
||||
|
||||
protected:
|
||||
|
||||
/// DbgValues - Remember instruction that preceeds DBG_VALUE.
|
||||
typedef std::vector<std::pair<MachineInstr *, MachineInstr *> >
|
||||
DbgValueVector;
|
||||
DbgValueVector DbgValues;
|
||||
MachineInstr *FirstDbgValue;
|
||||
|
||||
public:
|
||||
MachineBasicBlock::iterator Begin; // The beginning of the range to
|
||||
// be scheduled. The range extends
|
||||
|
Loading…
x
Reference in New Issue
Block a user