mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-24 19:44:49 +00:00
Fix PR2226. Avoid using uninitialized variables.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49807 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a5261923b4
commit
ff7a3e557e
@ -97,6 +97,8 @@ bool SimpleRegisterCoalescing::AdjustCopiesBackFrom(LiveInterval &IntA,
|
|||||||
// BValNo is a value number in B that is defined by a copy from A. 'B3' in
|
// BValNo is a value number in B that is defined by a copy from A. 'B3' in
|
||||||
// the example above.
|
// the example above.
|
||||||
LiveInterval::iterator BLR = IntB.FindLiveRangeContaining(CopyIdx);
|
LiveInterval::iterator BLR = IntB.FindLiveRangeContaining(CopyIdx);
|
||||||
|
if (BLR == IntB.end()) // Should never happen!
|
||||||
|
return false;
|
||||||
VNInfo *BValNo = BLR->valno;
|
VNInfo *BValNo = BLR->valno;
|
||||||
|
|
||||||
// Get the location that B is defined at. Two options: either this value has
|
// Get the location that B is defined at. Two options: either this value has
|
||||||
@ -107,6 +109,8 @@ bool SimpleRegisterCoalescing::AdjustCopiesBackFrom(LiveInterval &IntA,
|
|||||||
|
|
||||||
// AValNo is the value number in A that defines the copy, A3 in the example.
|
// AValNo is the value number in A that defines the copy, A3 in the example.
|
||||||
LiveInterval::iterator ALR = IntA.FindLiveRangeContaining(CopyIdx-1);
|
LiveInterval::iterator ALR = IntA.FindLiveRangeContaining(CopyIdx-1);
|
||||||
|
if (ALR == IntA.end()) // Should never happen!
|
||||||
|
return false;
|
||||||
VNInfo *AValNo = ALR->valno;
|
VNInfo *AValNo = ALR->valno;
|
||||||
|
|
||||||
// If AValNo is defined as a copy from IntB, we can potentially process this.
|
// If AValNo is defined as a copy from IntB, we can potentially process this.
|
||||||
@ -122,6 +126,8 @@ bool SimpleRegisterCoalescing::AdjustCopiesBackFrom(LiveInterval &IntA,
|
|||||||
|
|
||||||
// Get the LiveRange in IntB that this value number starts with.
|
// Get the LiveRange in IntB that this value number starts with.
|
||||||
LiveInterval::iterator ValLR = IntB.FindLiveRangeContaining(AValNo->def-1);
|
LiveInterval::iterator ValLR = IntB.FindLiveRangeContaining(AValNo->def-1);
|
||||||
|
if (ValLR == IntB.end()) // Should never happen!
|
||||||
|
return false;
|
||||||
|
|
||||||
// Make sure that the end of the live range is inside the same block as
|
// Make sure that the end of the live range is inside the same block as
|
||||||
// CopyMI.
|
// CopyMI.
|
||||||
@ -251,6 +257,8 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,
|
|||||||
// BValNo is a value number in B that is defined by a copy from A. 'B3' in
|
// BValNo is a value number in B that is defined by a copy from A. 'B3' in
|
||||||
// the example above.
|
// the example above.
|
||||||
LiveInterval::iterator BLR = IntB.FindLiveRangeContaining(CopyIdx);
|
LiveInterval::iterator BLR = IntB.FindLiveRangeContaining(CopyIdx);
|
||||||
|
if (BLR == IntB.end()) // Should never happen!
|
||||||
|
return false;
|
||||||
VNInfo *BValNo = BLR->valno;
|
VNInfo *BValNo = BLR->valno;
|
||||||
|
|
||||||
// Get the location that B is defined at. Two options: either this value has
|
// Get the location that B is defined at. Two options: either this value has
|
||||||
@ -261,6 +269,8 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,
|
|||||||
|
|
||||||
// AValNo is the value number in A that defines the copy, A3 in the example.
|
// AValNo is the value number in A that defines the copy, A3 in the example.
|
||||||
LiveInterval::iterator ALR = IntA.FindLiveRangeContaining(CopyIdx-1);
|
LiveInterval::iterator ALR = IntA.FindLiveRangeContaining(CopyIdx-1);
|
||||||
|
if (ALR == IntA.end()) // Should never happen!
|
||||||
|
return false;
|
||||||
VNInfo *AValNo = ALR->valno;
|
VNInfo *AValNo = ALR->valno;
|
||||||
// If other defs can reach uses of this def, then it's not safe to perform
|
// If other defs can reach uses of this def, then it's not safe to perform
|
||||||
// the optimization.
|
// the optimization.
|
||||||
@ -290,6 +300,8 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,
|
|||||||
MachineInstr *UseMI = &*UI;
|
MachineInstr *UseMI = &*UI;
|
||||||
unsigned UseIdx = li_->getInstructionIndex(UseMI);
|
unsigned UseIdx = li_->getInstructionIndex(UseMI);
|
||||||
LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx);
|
LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx);
|
||||||
|
if (ULR == IntA.end())
|
||||||
|
continue;
|
||||||
if (ULR->valno == AValNo && JoinedCopies.count(UseMI))
|
if (ULR->valno == AValNo && JoinedCopies.count(UseMI))
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -337,7 +349,7 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,
|
|||||||
continue;
|
continue;
|
||||||
unsigned UseIdx = li_->getInstructionIndex(UseMI);
|
unsigned UseIdx = li_->getInstructionIndex(UseMI);
|
||||||
LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx);
|
LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx);
|
||||||
if (ULR->valno != AValNo)
|
if (ULR == IntA.end() || ULR->valno != AValNo)
|
||||||
continue;
|
continue;
|
||||||
UseMO.setReg(NewReg);
|
UseMO.setReg(NewReg);
|
||||||
if (UseMI == CopyMI)
|
if (UseMI == CopyMI)
|
||||||
@ -356,7 +368,7 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,
|
|||||||
// remove that val# as well. However this live range is being
|
// remove that val# as well. However this live range is being
|
||||||
// extended to the end of the existing live range defined by the copy.
|
// extended to the end of the existing live range defined by the copy.
|
||||||
unsigned DefIdx = li_->getDefIndex(UseIdx);
|
unsigned DefIdx = li_->getDefIndex(UseIdx);
|
||||||
LiveInterval::iterator DLR = IntB.FindLiveRangeContaining(DefIdx);
|
const LiveRange *DLR = IntB.getLiveRangeContaining(DefIdx);
|
||||||
BHasPHIKill |= DLR->valno->hasPHIKill;
|
BHasPHIKill |= DLR->valno->hasPHIKill;
|
||||||
assert(DLR->valno->def == DefIdx);
|
assert(DLR->valno->def == DefIdx);
|
||||||
BDeadValNos.push_back(DLR->valno);
|
BDeadValNos.push_back(DLR->valno);
|
||||||
@ -515,8 +527,7 @@ void SimpleRegisterCoalescing::RemoveUnnecessaryKills(unsigned Reg,
|
|||||||
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(UseMI));
|
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(UseMI));
|
||||||
if (JoinedCopies.count(UseMI))
|
if (JoinedCopies.count(UseMI))
|
||||||
continue;
|
continue;
|
||||||
LiveInterval::const_iterator UI = LI.FindLiveRangeContaining(UseIdx);
|
const LiveRange *UI = LI.getLiveRangeContaining(UseIdx);
|
||||||
assert(UI != LI.end());
|
|
||||||
if (!LI.isKill(UI->valno, UseIdx+1))
|
if (!LI.isKill(UI->valno, UseIdx+1))
|
||||||
UseMO.setIsKill(false);
|
UseMO.setIsKill(false);
|
||||||
}
|
}
|
||||||
@ -614,7 +625,7 @@ SimpleRegisterCoalescing::ShortenDeadCopySrcLiveRange(LiveInterval &li,
|
|||||||
assert(TargetRegisterInfo::isPhysicalRegister(li.reg));
|
assert(TargetRegisterInfo::isPhysicalRegister(li.reg));
|
||||||
// Live-in to the function but dead. Remove it from entry live-in set.
|
// Live-in to the function but dead. Remove it from entry live-in set.
|
||||||
mf_->begin()->removeLiveIn(li.reg);
|
mf_->begin()->removeLiveIn(li.reg);
|
||||||
LiveInterval::iterator LR = li.FindLiveRangeContaining(CopyIdx);
|
const LiveRange *LR = li.getLiveRangeContaining(CopyIdx);
|
||||||
removeRange(li, LR->start, LR->end, li_, tri_);
|
removeRange(li, LR->start, LR->end, li_, tri_);
|
||||||
removeIntervalIfEmpty(li, li_, tri_);
|
removeIntervalIfEmpty(li, li_, tri_);
|
||||||
return;
|
return;
|
||||||
@ -694,7 +705,7 @@ bool SimpleRegisterCoalescing::CanCoalesceWithImpDef(MachineInstr *CopyMI,
|
|||||||
continue;
|
continue;
|
||||||
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(UseMI));
|
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(UseMI));
|
||||||
LiveInterval::iterator ULR = li.FindLiveRangeContaining(UseIdx);
|
LiveInterval::iterator ULR = li.FindLiveRangeContaining(UseIdx);
|
||||||
if (ULR->valno != LR->valno)
|
if (ULR == li.end() || ULR->valno != LR->valno)
|
||||||
continue;
|
continue;
|
||||||
// If the use is not a use, then it's not safe to coalesce the move.
|
// If the use is not a use, then it's not safe to coalesce the move.
|
||||||
unsigned SrcReg, DstReg;
|
unsigned SrcReg, DstReg;
|
||||||
@ -733,7 +744,7 @@ void SimpleRegisterCoalescing::RemoveCopiesFromValNo(LiveInterval &li,
|
|||||||
continue;
|
continue;
|
||||||
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(MI));
|
unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(MI));
|
||||||
LiveInterval::iterator ULR = li.FindLiveRangeContaining(UseIdx);
|
LiveInterval::iterator ULR = li.FindLiveRangeContaining(UseIdx);
|
||||||
if (ULR->valno != VNI)
|
if (ULR == li.end() || ULR->valno != VNI)
|
||||||
continue;
|
continue;
|
||||||
// If the use is a copy, turn it into an identity copy.
|
// If the use is a copy, turn it into an identity copy.
|
||||||
unsigned SrcReg, DstReg;
|
unsigned SrcReg, DstReg;
|
||||||
@ -1013,9 +1024,8 @@ bool SimpleRegisterCoalescing::JoinCopy(CopyRec &TheCopy, bool &Again) {
|
|||||||
SmallSet<const VNInfo*, 4> CopiedValNos;
|
SmallSet<const VNInfo*, 4> CopiedValNos;
|
||||||
for (LiveInterval::Ranges::const_iterator I = ResSrcInt->ranges.begin(),
|
for (LiveInterval::Ranges::const_iterator I = ResSrcInt->ranges.begin(),
|
||||||
E = ResSrcInt->ranges.end(); I != E; ++I) {
|
E = ResSrcInt->ranges.end(); I != E; ++I) {
|
||||||
LiveInterval::const_iterator DstLR =
|
const LiveRange *DstLR = ResDstInt->getLiveRangeContaining(I->start);
|
||||||
ResDstInt->FindLiveRangeContaining(I->start);
|
assert(DstLR && "Invalid joined interval!");
|
||||||
assert(DstLR != ResDstInt->end() && "Invalid joined interval!");
|
|
||||||
const VNInfo *DstValNo = DstLR->valno;
|
const VNInfo *DstValNo = DstLR->valno;
|
||||||
if (CopiedValNos.insert(DstValNo)) {
|
if (CopiedValNos.insert(DstValNo)) {
|
||||||
VNInfo *ValNo = RealInt.getNextValue(DstValNo->def, DstValNo->copy,
|
VNInfo *ValNo = RealInt.getNextValue(DstValNo->def, DstValNo->copy,
|
||||||
@ -1095,7 +1105,7 @@ bool SimpleRegisterCoalescing::JoinCopy(CopyRec &TheCopy, bool &Again) {
|
|||||||
// by the copy is being defined by an IMPLICIT_DEF which defines a zero
|
// by the copy is being defined by an IMPLICIT_DEF which defines a zero
|
||||||
// length interval. Remove the val#.
|
// length interval. Remove the val#.
|
||||||
unsigned CopyIdx = li_->getDefIndex(li_->getInstructionIndex(CopyMI));
|
unsigned CopyIdx = li_->getDefIndex(li_->getInstructionIndex(CopyMI));
|
||||||
LiveInterval::iterator LR = ResDstInt->FindLiveRangeContaining(CopyIdx);
|
const LiveRange *LR = ResDstInt->getLiveRangeContaining(CopyIdx);
|
||||||
VNInfo *ImpVal = LR->valno;
|
VNInfo *ImpVal = LR->valno;
|
||||||
assert(ImpVal->def == CopyIdx);
|
assert(ImpVal->def == CopyIdx);
|
||||||
unsigned NextDef = LR->end;
|
unsigned NextDef = LR->end;
|
||||||
@ -1877,7 +1887,7 @@ SimpleRegisterCoalescing::TurnCopyIntoImpDef(MachineBasicBlock::iterator &I,
|
|||||||
if (!li_->hasInterval(DstReg))
|
if (!li_->hasInterval(DstReg))
|
||||||
return false;
|
return false;
|
||||||
LiveInterval &DstInt = li_->getInterval(DstReg);
|
LiveInterval &DstInt = li_->getInterval(DstReg);
|
||||||
LiveInterval::iterator DstLR = DstInt.FindLiveRangeContaining(CopyIdx);
|
const LiveRange *DstLR = DstInt.getLiveRangeContaining(CopyIdx);
|
||||||
DstInt.removeValNo(DstLR->valno);
|
DstInt.removeValNo(DstLR->valno);
|
||||||
CopyMI->setDesc(tii_->get(TargetInstrInfo::IMPLICIT_DEF));
|
CopyMI->setDesc(tii_->get(TargetInstrInfo::IMPLICIT_DEF));
|
||||||
for (int i = CopyMI->getNumOperands() - 1, e = 0; i > e; --i)
|
for (int i = CopyMI->getNumOperands() - 1, e = 0; i > e; --i)
|
||||||
@ -1934,7 +1944,12 @@ bool SimpleRegisterCoalescing::runOnMachineFunction(MachineFunction &fn) {
|
|||||||
E = JoinedCopies.end(); I != E; ++I) {
|
E = JoinedCopies.end(); I != E; ++I) {
|
||||||
MachineInstr *CopyMI = *I;
|
MachineInstr *CopyMI = *I;
|
||||||
unsigned SrcReg, DstReg;
|
unsigned SrcReg, DstReg;
|
||||||
tii_->isMoveInstr(*CopyMI, SrcReg, DstReg);
|
if (!tii_->isMoveInstr(*CopyMI, SrcReg, DstReg)) {
|
||||||
|
assert((CopyMI->getOpcode() == TargetInstrInfo::EXTRACT_SUBREG ||
|
||||||
|
CopyMI->getOpcode() == TargetInstrInfo::INSERT_SUBREG) &&
|
||||||
|
"Unrecognized copy instruction");
|
||||||
|
DstReg = CopyMI->getOperand(0).getReg();
|
||||||
|
}
|
||||||
if (CopyMI->registerDefIsDead(DstReg)) {
|
if (CopyMI->registerDefIsDead(DstReg)) {
|
||||||
LiveInterval &li = li_->getInterval(DstReg);
|
LiveInterval &li = li_->getInterval(DstReg);
|
||||||
ShortenDeadCopySrcLiveRange(li, CopyMI);
|
ShortenDeadCopySrcLiveRange(li, CopyMI);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user