mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-02 01:38:34 +00:00
Update debug information when breaking anti-dependencies. rdar://7759363
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105300 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
891f27380c
commit
533934e06e
@ -905,6 +905,18 @@ unsigned AggressiveAntiDepBreaker::BreakAntiDependencies(
|
|||||||
AggressiveAntiDepState::RegisterReference>::iterator
|
AggressiveAntiDepState::RegisterReference>::iterator
|
||||||
Q = Range.first, QE = Range.second; Q != QE; ++Q) {
|
Q = Range.first, QE = Range.second; Q != QE; ++Q) {
|
||||||
Q->second.Operand->setReg(NewReg);
|
Q->second.Operand->setReg(NewReg);
|
||||||
|
// If the SU for the instruction being updated has debug
|
||||||
|
// information related to the anti-dependency register, make
|
||||||
|
// sure to update that as well.
|
||||||
|
const SUnit *SU = MISUnitMap[Q->second.Operand->getParent()];
|
||||||
|
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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// We just went back in time and modified history; the
|
// We just went back in time and modified history; the
|
||||||
|
@ -334,10 +334,15 @@ BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
|||||||
// so just duck out immediately if the block is empty.
|
// so just duck out immediately if the block is empty.
|
||||||
if (SUnits.empty()) return 0;
|
if (SUnits.empty()) return 0;
|
||||||
|
|
||||||
|
// Keep a map of the MachineInstr*'s back to the SUnit representing them.
|
||||||
|
// This is used for updating debug information.
|
||||||
|
DenseMap<MachineInstr*,const SUnit*> MISUnitMap;
|
||||||
|
|
||||||
// Find the node at the bottom of the critical path.
|
// Find the node at the bottom of the critical path.
|
||||||
const SUnit *Max = 0;
|
const SUnit *Max = 0;
|
||||||
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
|
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
|
||||||
const SUnit *SU = &SUnits[i];
|
const SUnit *SU = &SUnits[i];
|
||||||
|
MISUnitMap[SU->getInstr()] = SU;
|
||||||
if (!Max || SU->getDepth() + SU->Latency > Max->getDepth() + Max->Latency)
|
if (!Max || SU->getDepth() + SU->Latency > Max->getDepth() + Max->Latency)
|
||||||
Max = SU;
|
Max = SU;
|
||||||
}
|
}
|
||||||
@ -519,8 +524,21 @@ BreakAntiDependencies(const std::vector<SUnit>& SUnits,
|
|||||||
std::multimap<unsigned, MachineOperand *>::iterator>
|
std::multimap<unsigned, MachineOperand *>::iterator>
|
||||||
Range = RegRefs.equal_range(AntiDepReg);
|
Range = RegRefs.equal_range(AntiDepReg);
|
||||||
for (std::multimap<unsigned, MachineOperand *>::iterator
|
for (std::multimap<unsigned, MachineOperand *>::iterator
|
||||||
Q = Range.first, QE = Range.second; Q != QE; ++Q)
|
Q = Range.first, QE = Range.second; Q != QE; ++Q) {
|
||||||
Q->second->setReg(NewReg);
|
Q->second->setReg(NewReg);
|
||||||
|
// If the SU for the instruction being updated has debug information
|
||||||
|
// related to the anti-dependency register, make sure to update that
|
||||||
|
// as well.
|
||||||
|
const SUnit *SU = MISUnitMap[Q->second->getParent()];
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// We just went back in time and modified history; the
|
// We just went back in time and modified history; the
|
||||||
// liveness information for the anti-depenence reg is now
|
// liveness information for the anti-depenence reg is now
|
||||||
|
Loading…
Reference in New Issue
Block a user