Fix a couple of places where changes are made but not tracked.

llvm-svn: 129287
This commit is contained in:
Evan Cheng 2011-04-11 18:47:20 +00:00
parent 66fab75920
commit fe917efc8b
2 changed files with 10 additions and 3 deletions

View File

@ -365,6 +365,8 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {
if (!FoundCSE) { if (!FoundCSE) {
// Look for trivial copy coalescing opportunities. // Look for trivial copy coalescing opportunities.
if (PerformTrivialCoalescing(MI, MBB)) { if (PerformTrivialCoalescing(MI, MBB)) {
Changed = true;
// After coalescing MI itself may become a copy. // After coalescing MI itself may become a copy.
if (MI->isCopyLike()) if (MI->isCopyLike())
continue; continue;
@ -379,10 +381,11 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {
if (NewMI) { if (NewMI) {
Commuted = true; Commuted = true;
FoundCSE = VNT.count(NewMI); FoundCSE = VNT.count(NewMI);
if (NewMI != MI) if (NewMI != MI) {
// New instruction. It doesn't need to be kept. // New instruction. It doesn't need to be kept.
NewMI->eraseFromParent(); NewMI->eraseFromParent();
else if (!FoundCSE) Changed = true;
} else if (!FoundCSE)
// MI was changed but it didn't help, commute it back! // MI was changed but it didn't help, commute it back!
(void)TII->commuteInstruction(MI); (void)TII->commuteInstruction(MI);
} }
@ -450,6 +453,7 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {
++NumPhysCSEs; ++NumPhysCSEs;
if (Commuted) if (Commuted)
++NumCommutes; ++NumCommutes;
Changed = true;
} else { } else {
DEBUG(dbgs() << "*** Not profitable, avoid CSE!\n"); DEBUG(dbgs() << "*** Not profitable, avoid CSE!\n");
VNT.insert(MI, CurrVN++); VNT.insert(MI, CurrVN++);

View File

@ -265,8 +265,11 @@ bool MachineSinking::ProcessBlock(MachineBasicBlock &MBB) {
if (MI->isDebugValue()) if (MI->isDebugValue())
continue; continue;
if (PerformTrivialForwardCoalescing(MI, &MBB)) bool Joined = PerformTrivialForwardCoalescing(MI, &MBB);
if (Joined) {
MadeChange = true;
continue; continue;
}
if (SinkInstruction(MI, SawStore)) if (SinkInstruction(MI, SawStore))
++NumSunk, MadeChange = true; ++NumSunk, MadeChange = true;