mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-26 14:25:18 +00:00
Revert r175688 - It broke a test case (see PR15320).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@175765 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8389f24a66
commit
f6c80bde65
@ -49,6 +49,8 @@ private:
|
||||
bool LowerSubregToReg(MachineInstr *MI);
|
||||
bool LowerCopy(MachineInstr *MI);
|
||||
|
||||
void TransferDeadFlag(MachineInstr *MI, unsigned DstReg,
|
||||
const TargetRegisterInfo *TRI);
|
||||
void TransferImplicitDefs(MachineInstr *MI);
|
||||
};
|
||||
} // end anonymous namespace
|
||||
@ -59,6 +61,21 @@ char &llvm::ExpandPostRAPseudosID = ExpandPostRA::ID;
|
||||
INITIALIZE_PASS(ExpandPostRA, "postrapseudos",
|
||||
"Post-RA pseudo instruction expansion pass", false, false)
|
||||
|
||||
/// TransferDeadFlag - MI is a pseudo-instruction with DstReg dead,
|
||||
/// and the lowered replacement instructions immediately precede it.
|
||||
/// Mark the replacement instructions with the dead flag.
|
||||
void
|
||||
ExpandPostRA::TransferDeadFlag(MachineInstr *MI, unsigned DstReg,
|
||||
const TargetRegisterInfo *TRI) {
|
||||
for (MachineBasicBlock::iterator MII =
|
||||
prior(MachineBasicBlock::iterator(MI)); ; --MII) {
|
||||
if (MII->addRegisterDead(DstReg, TRI))
|
||||
break;
|
||||
assert(MII != MI->getParent()->begin() &&
|
||||
"copyPhysReg output doesn't reference destination register!");
|
||||
}
|
||||
}
|
||||
|
||||
/// TransferImplicitDefs - MI is a pseudo-instruction, and the lowered
|
||||
/// replacement instructions immediately precede it. Copy any implicit-def
|
||||
/// operands from MI to the replacement instruction.
|
||||
@ -111,17 +128,17 @@ bool ExpandPostRA::LowerSubregToReg(MachineInstr *MI) {
|
||||
}
|
||||
DEBUG(dbgs() << "subreg: eliminated!");
|
||||
} else {
|
||||
if (MI->getOperand(0).isDead()) {
|
||||
MI->setDesc(TII->get(TargetOpcode::KILL));
|
||||
DEBUG(dbgs() << "subreg: replaced by: " << *MI);
|
||||
return true;
|
||||
}
|
||||
TII->copyPhysReg(*MBB, MI, MI->getDebugLoc(), DstSubReg, InsReg,
|
||||
MI->getOperand(2).isKill());
|
||||
|
||||
// Implicitly define DstReg for subsequent uses.
|
||||
MachineBasicBlock::iterator CopyMI = MI;
|
||||
--CopyMI;
|
||||
CopyMI->addRegisterDefined(DstReg);
|
||||
|
||||
// Transfer the kill/dead flags, if needed.
|
||||
if (MI->getOperand(0).isDead())
|
||||
TransferDeadFlag(MI, DstSubReg, TRI);
|
||||
DEBUG(dbgs() << "subreg: " << *CopyMI);
|
||||
}
|
||||
|
||||
@ -134,18 +151,11 @@ bool ExpandPostRA::LowerCopy(MachineInstr *MI) {
|
||||
MachineOperand &DstMO = MI->getOperand(0);
|
||||
MachineOperand &SrcMO = MI->getOperand(1);
|
||||
|
||||
if (DstMO.isDead()) {
|
||||
DEBUG(dbgs() << "dead copy: " << *MI);
|
||||
MI->setDesc(TII->get(TargetOpcode::KILL));
|
||||
DEBUG(dbgs() << "replaced by: " << *MI);
|
||||
return true;
|
||||
}
|
||||
|
||||
if (SrcMO.getReg() == DstMO.getReg()) {
|
||||
DEBUG(dbgs() << "identity copy: " << *MI);
|
||||
// No need to insert an identity copy instruction, but replace with a KILL
|
||||
// if liveness is changed.
|
||||
if (SrcMO.isUndef() || MI->getNumOperands() > 2) {
|
||||
if (DstMO.isDead() || SrcMO.isUndef() || MI->getNumOperands() > 2) {
|
||||
// We must make sure the super-register gets killed. Replace the
|
||||
// instruction with KILL.
|
||||
MI->setDesc(TII->get(TargetOpcode::KILL));
|
||||
@ -161,6 +171,8 @@ bool ExpandPostRA::LowerCopy(MachineInstr *MI) {
|
||||
TII->copyPhysReg(*MI->getParent(), MI, MI->getDebugLoc(),
|
||||
DstMO.getReg(), SrcMO.getReg(), SrcMO.isKill());
|
||||
|
||||
if (DstMO.isDead())
|
||||
TransferDeadFlag(MI, DstMO.getReg(), TRI);
|
||||
if (MI->getNumOperands() > 2)
|
||||
TransferImplicitDefs(MI);
|
||||
DEBUG({
|
||||
|
Loading…
x
Reference in New Issue
Block a user