mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-30 00:24:00 +00:00
A REG_SEQUENCE instruction may use the same register twice.
If we are emitting COPY instructions for the REG_SEQUENCE, make sure the kill flag goes on the last COPY. Otherwise we may be using a killed register. <rdar://problem/8287792> llvm-svn: 110589
This commit is contained in:
parent
b6b08dfca1
commit
f73f368ddb
@ -1446,7 +1446,17 @@ bool TwoAddressInstructionPass::EliminateRegSequences() {
|
||||
//
|
||||
// If the REG_SEQUENCE doesn't kill its source, keeping live variables
|
||||
// correctly up to date becomes very difficult. Insert a copy.
|
||||
//
|
||||
|
||||
// Defer any kill flag to the last operand using SrcReg. Otherwise, we
|
||||
// might insert a COPY that uses SrcReg after is was killed.
|
||||
if (isKill)
|
||||
for (unsigned j = i + 2; j < e; j += 2)
|
||||
if (MI->getOperand(j).getReg() == SrcReg) {
|
||||
MI->getOperand(j).setIsKill();
|
||||
isKill = false;
|
||||
break;
|
||||
}
|
||||
|
||||
MachineBasicBlock::iterator InsertLoc = MI;
|
||||
MachineInstr *CopyMI = BuildMI(*MI->getParent(), InsertLoc,
|
||||
MI->getDebugLoc(), TII->get(TargetOpcode::COPY))
|
||||
|
Loading…
x
Reference in New Issue
Block a user