MachineScheduler: Ignore COPYs with undef/dead op in CopyConstrain mutation.

There is no problem with the code today, but the fix will avoid a crash
in test/CodeGen/AMDGPU/subreg-coalescer-undef-use.ll once the
DetectDeadLanes pass is added.

llvm-svn: 265351
This commit is contained in:
Matthias Braun 2016-04-04 21:23:46 +00:00
parent 571e3481e7
commit 7511abd5c1
1 changed files with 6 additions and 4 deletions

View File

@ -1580,12 +1580,14 @@ void CopyConstrain::constrainLocalCopy(SUnit *CopySU, ScheduleDAGMILive *DAG) {
MachineInstr *Copy = CopySU->getInstr(); MachineInstr *Copy = CopySU->getInstr();
// Check for pure vreg copies. // Check for pure vreg copies.
unsigned SrcReg = Copy->getOperand(1).getReg(); const MachineOperand &SrcOp = Copy->getOperand(1);
if (!TargetRegisterInfo::isVirtualRegister(SrcReg)) unsigned SrcReg = SrcOp.getReg();
if (!TargetRegisterInfo::isVirtualRegister(SrcReg) || !SrcOp.readsReg())
return; return;
unsigned DstReg = Copy->getOperand(0).getReg(); const MachineOperand &DstOp = Copy->getOperand(0);
if (!TargetRegisterInfo::isVirtualRegister(DstReg)) unsigned DstReg = DstOp.getReg();
if (!TargetRegisterInfo::isVirtualRegister(DstReg) || DstOp.isDead())
return; return;
// Check if either the dest or source is local. If it's live across a back // Check if either the dest or source is local. If it's live across a back