diff options
| author | Chris Lattner <sabre@nondot.org> | 2009-11-06 18:22:54 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2009-11-06 18:22:54 +0000 | 
| commit | 899ef22acb10610c130f4be2c21c0d54b6817f0a (patch) | |
| tree | b50d35e8ed16902dc461f0b30662edafc791f024 | |
| parent | 2f6184f6aa665afa17c0c087b97305e757ce34d3 (diff) | |
| download | bcm5719-llvm-899ef22acb10610c130f4be2c21c0d54b6817f0a.tar.gz bcm5719-llvm-899ef22acb10610c130f4be2c21c0d54b6817f0a.zip | |
eliminate some more code subsumed by r86264
llvm-svn: 86267
| -rw-r--r-- | llvm/lib/Transforms/Scalar/JumpThreading.cpp | 45 | 
1 files changed, 4 insertions, 41 deletions
| diff --git a/llvm/lib/Transforms/Scalar/JumpThreading.cpp b/llvm/lib/Transforms/Scalar/JumpThreading.cpp index 911f7356059..ee9586a0b7f 100644 --- a/llvm/lib/Transforms/Scalar/JumpThreading.cpp +++ b/llvm/lib/Transforms/Scalar/JumpThreading.cpp @@ -1005,47 +1005,10 @@ bool JumpThreading::ProcessThreadableEdges(Instruction *CondInst,  bool JumpThreading::ProcessJumpOnPHI(PHINode *PN) {    BasicBlock *BB = PN->getParent(); -  // See if the phi node has any constant integer or undef values.  If so, we -  // can determine where the corresponding predecessor will branch. -  for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) { -    Value *PredVal = PN->getIncomingValue(i); -     -    // Check to see if this input is a constant integer.  If so, the direction -    // of the branch is predictable. -    if (ConstantInt *CI = dyn_cast<ConstantInt>(PredVal)) { -      // Merge any common predecessors that will act the same. -      BasicBlock *PredBB = FactorCommonPHIPreds(PN, CI); -       -      BasicBlock *SuccBB; -      if (BranchInst *BI = dyn_cast<BranchInst>(BB->getTerminator())) -        SuccBB = BI->getSuccessor(CI->isZero()); -      else { -        SwitchInst *SI = cast<SwitchInst>(BB->getTerminator()); -        SuccBB = SI->getSuccessor(SI->findCaseValue(CI)); -      } -       -      // Ok, try to thread it! -      return ThreadEdge(BB, PredBB, SuccBB); -    } -     -    // If the input is an undef, then it doesn't matter which way it will go. -    // Pick an arbitrary dest and thread the edge. -    if (UndefValue *UV = dyn_cast<UndefValue>(PredVal)) { -      // Merge any common predecessors that will act the same. -      BasicBlock *PredBB = FactorCommonPHIPreds(PN, UV); -      BasicBlock *SuccBB = -        BB->getTerminator()->getSuccessor(GetBestDestForJumpOnUndef(BB)); -       -      // Ok, try to thread it! -      return ThreadEdge(BB, PredBB, SuccBB); -    } -  } -   -  // If the incoming values are all variables, we don't know the destination of -  // any predecessors.  However, if any of the predecessor blocks end in an -  // unconditional branch, we can *duplicate* the jump into that block in order -  // to further encourage jump threading and to eliminate cases where we have -  // branch on a phi of an icmp (branch on icmp is much better). +  // If any of the predecessor blocks end in an unconditional branch, we can +  // *duplicate* the jump into that block in order to further encourage jump +  // threading and to eliminate cases where we have branch on a phi of an icmp +  // (branch on icmp is much better).    // We don't want to do this tranformation for switches, because we don't    // really want to duplicate a switch. | 

