diff options
author | Yi Jiang <yjiang@apple.com> | 2015-06-18 22:34:09 +0000 |
---|---|---|
committer | Yi Jiang <yjiang@apple.com> | 2015-06-18 22:34:09 +0000 |
commit | e0b3499db7cf9d26bc774be7d3e1175bac7665e0 (patch) | |
tree | d44eec82e4c59818ae07981a6ff1c5a44b5600a3 /llvm/lib/CodeGen/EarlyIfConversion.cpp | |
parent | 67d492a544164c75004f9a5a64a0501cc0ce71ad (diff) | |
download | bcm5719-llvm-e0b3499db7cf9d26bc774be7d3e1175bac7665e0.tar.gz bcm5719-llvm-e0b3499db7cf9d26bc774be7d3e1175bac7665e0.zip |
Avoid redundant select node in early if-conversion pass
llvm-svn: 240072
Diffstat (limited to 'llvm/lib/CodeGen/EarlyIfConversion.cpp')
-rw-r--r-- | llvm/lib/CodeGen/EarlyIfConversion.cpp | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/EarlyIfConversion.cpp b/llvm/lib/CodeGen/EarlyIfConversion.cpp index d3687b98b34..fbc4d97c498 100644 --- a/llvm/lib/CodeGen/EarlyIfConversion.cpp +++ b/llvm/lib/CodeGen/EarlyIfConversion.cpp @@ -479,11 +479,20 @@ void SSAIfConv::rewritePHIOperands() { // Convert all PHIs to select instructions inserted before FirstTerm. for (unsigned i = 0, e = PHIs.size(); i != e; ++i) { PHIInfo &PI = PHIs[i]; + unsigned DstReg = 0; + DEBUG(dbgs() << "If-converting " << *PI.PHI); - unsigned PHIDst = PI.PHI->getOperand(0).getReg(); - unsigned DstReg = MRI->createVirtualRegister(MRI->getRegClass(PHIDst)); - TII->insertSelect(*Head, FirstTerm, HeadDL, DstReg, Cond, PI.TReg, PI.FReg); - DEBUG(dbgs() << " --> " << *std::prev(FirstTerm)); + if (PI.TReg == PI.FReg) { + // We do not need the select instruction if both incoming values are + // equal. + DstReg = PI.TReg; + } else { + unsigned PHIDst = PI.PHI->getOperand(0).getReg(); + DstReg = MRI->createVirtualRegister(MRI->getRegClass(PHIDst)); + TII->insertSelect(*Head, FirstTerm, HeadDL, + DstReg, Cond, PI.TReg, PI.FReg); + DEBUG(dbgs() << " --> " << *std::prev(FirstTerm)); + } // Rewrite PHI operands TPred -> (DstReg, Head), remove FPred. for (unsigned i = PI.PHI->getNumOperands(); i != 1; i -= 2) { |