RegisterCoalescer: Do not look for regclass of IMPLICIT_DEF.

IMPLICIT_DEF is a generic instruction and has no (fixed) output register
class defined. The rematerialization code of the register coalescer
should not scan the instruction description for a register class.

This fixes a problem showing up in
test/CodeGen/R600/subreg-coalescer-crash.ll with subregister liveness
enabled.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@229443 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Matthias Braun 2015-02-16 22:05:12 +00:00
parent 0638f4e115
commit 1f67650f77

View File

@ -913,12 +913,13 @@ bool RegisterCoalescer::reMaterializeTrivialDef(CoalescerPair &CP,
const TargetRegisterClass *NewRC = CP.getNewRC(); const TargetRegisterClass *NewRC = CP.getNewRC();
unsigned NewIdx = NewMI->getOperand(0).getSubReg(); unsigned NewIdx = NewMI->getOperand(0).getSubReg();
if (NewIdx) if (DefRC != nullptr) {
NewRC = TRI->getMatchingSuperRegClass(NewRC, DefRC, NewIdx); if (NewIdx)
else NewRC = TRI->getMatchingSuperRegClass(NewRC, DefRC, NewIdx);
NewRC = TRI->getCommonSubClass(NewRC, DefRC); else
NewRC = TRI->getCommonSubClass(NewRC, DefRC);
assert(NewRC && "subreg chosen for remat incompatible with instruction"); assert(NewRC && "subreg chosen for remat incompatible with instruction");
}
MRI->setRegClass(DstReg, NewRC); MRI->setRegClass(DstReg, NewRC);
updateRegDefsUses(DstReg, DstReg, DstIdx); updateRegDefsUses(DstReg, DstReg, DstIdx);