[llvm-commits] [llvm] r50368 - /llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp

Dan Gohman gohman at apple.com
Mon Apr 28 11:47:17 PDT 2008


Author: djg
Date: Mon Apr 28 13:47:17 2008
New Revision: 50368

URL: http://llvm.org/viewvc/llvm-project?rev=50368&view=rev
Log:
Evan pointed out that folding sext to zext may not be correct
if the zext is not legal.

Modified:
    llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp

Modified: llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp?rev=50368&r1=50367&r2=50368&view=diff

==============================================================================
--- llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp (original)
+++ llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp Mon Apr 28 13:47:17 2008
@@ -2888,7 +2888,8 @@
   }
   
   // fold (sext x) -> (zext x) if the sign bit is known zero.
-  if (DAG.SignBitIsZero(N0))
+  if ((!AfterLegalize || TLI.isOperationLegal(ISD::ZERO_EXTEND, VT)) &&
+      DAG.SignBitIsZero(N0))
     return DAG.getNode(ISD::ZERO_EXTEND, VT, N0);
   
   return SDOperand();





More information about the llvm-commits mailing list