diff options
| author | Manman Ren <mren@apple.com> | 2012-08-08 00:51:41 +0000 | 
|---|---|---|
| committer | Manman Ren <mren@apple.com> | 2012-08-08 00:51:41 +0000 | 
| commit | 1be131ba275b33e674d09fc84a5ae5f4f27c8e15 (patch) | |
| tree | 6b33a47ea0287c903e15ccbe3583859a54a1cea4 /llvm/lib/CodeGen | |
| parent | 3b9a4428416566bca21fd43cfbaeeb566465b5d4 (diff) | |
| download | bcm5719-llvm-1be131ba275b33e674d09fc84a5ae5f4f27c8e15.tar.gz bcm5719-llvm-1be131ba275b33e674d09fc84a5ae5f4f27c8e15.zip | |
X86: enable CSE between CMP and SUB
We perform the following:
1> Use SUB instead of CMP for i8,i16,i32 and i64 in ISel lowering.
2> Modify MachineCSE to correctly handle implicit defs.
3> Convert SUB back to CMP if possible at peephole.
Removed pattern matching of (a>b) ? (a-b):0 and like, since they are handled
by peephole now.
rdar://11873276
llvm-svn: 161462
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/MachineCSE.cpp | 20 | 
1 files changed, 18 insertions, 2 deletions
| diff --git a/llvm/lib/CodeGen/MachineCSE.cpp b/llvm/lib/CodeGen/MachineCSE.cpp index 0a76f8db0b3..5153abbc4e1 100644 --- a/llvm/lib/CodeGen/MachineCSE.cpp +++ b/llvm/lib/CodeGen/MachineCSE.cpp @@ -417,6 +417,7 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {    bool Changed = false;    SmallVector<std::pair<unsigned, unsigned>, 8> CSEPairs; +  SmallVector<unsigned, 2> ImplicitDefsToUpdate;    for (MachineBasicBlock::iterator I = MBB->begin(), E = MBB->end(); I != E; ) {      MachineInstr *MI = &*I;      ++I; @@ -486,15 +487,24 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {      // Check if it's profitable to perform this CSE.      bool DoCSE = true; -    unsigned NumDefs = MI->getDesc().getNumDefs(); +    unsigned NumDefs = MI->getDesc().getNumDefs() + +                       MI->getDesc().getNumImplicitDefs(); +          for (unsigned i = 0, e = MI->getNumOperands(); NumDefs && i != e; ++i) {        MachineOperand &MO = MI->getOperand(i);        if (!MO.isReg() || !MO.isDef())          continue;        unsigned OldReg = MO.getReg();        unsigned NewReg = CSMI->getOperand(i).getReg(); -      if (OldReg == NewReg) + +      // Go through implicit defs of CSMI and MI, if a def is not dead at MI, +      // we should make sure it is not dead at CSMI. +      if (MO.isImplicit() && !MO.isDead() && CSMI->getOperand(i).isDead()) +        ImplicitDefsToUpdate.push_back(i); +      if (OldReg == NewReg) { +        --NumDefs;          continue; +      }        assert(TargetRegisterInfo::isVirtualRegister(OldReg) &&               TargetRegisterInfo::isVirtualRegister(NewReg) && @@ -526,6 +536,11 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {          MRI->clearKillFlags(CSEPairs[i].second);        } +      // Go through implicit defs of CSMI and MI, if a def is not dead at MI, +      // we should make sure it is not dead at CSMI. +      for (unsigned i = 0, e = ImplicitDefsToUpdate.size(); i != e; ++i) +        CSMI->getOperand(ImplicitDefsToUpdate[i]).setIsDead(false); +        if (CrossMBBPhysDef) {          // Add physical register defs now coming in from a predecessor to MBB          // livein list. @@ -549,6 +564,7 @@ bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {        Exps.push_back(MI);      }      CSEPairs.clear(); +    ImplicitDefsToUpdate.clear();    }    return Changed; | 

