Fixed scalarizing an extract subvector and prevent an infinite loop
authorMon P Wang <wangmp@apple.com>
Thu, 6 Nov 2008 22:52:21 +0000 (22:52 +0000)
committerMon P Wang <wangmp@apple.com>
Thu, 6 Nov 2008 22:52:21 +0000 (22:52 +0000)
when simplify a vector.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@58820 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
lib/Transforms/Scalar/InstructionCombining.cpp

index f9d1ddc615779a44c627e7cbf0a821b47adabee0..c17ef9cedcb9752b5c52ba85a645ac8ed17e222d 100644 (file)
@@ -7516,8 +7516,8 @@ SDValue SelectionDAGLegalize::ScalarizeVectorOp(SDValue Op) {
     break;
   }
   case ISD::EXTRACT_SUBVECTOR:
-    Result = Node->getOperand(0);
-    assert(Result.getValueType() == NewVT);
+    Result = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, NewVT, Node->getOperand(0),
+                          Node->getOperand(1));
     break;
   case ISD::BIT_CONVERT: {
     SDValue Op0 = Op.getOperand(0);
@@ -8174,7 +8174,7 @@ void SelectionDAGLegalize::genWidenVectorStores(SDValueVector& StChain,
 
   SDValue VecOp = DAG.getNode(ISD::BIT_CONVERT, VecEVT, ValOp);
   SDValue EOp = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, EVT, VecOp,
-                                  DAG.getIntPtrConstant(0));
+                            DAG.getIntPtrConstant(0));
   SDValue StOp = DAG.getStore(Chain, EOp, BasePtr, SV, SVOffset,
                                isVolatile, Alignment);
   StChain.push_back(StOp);
index 3210b12cbb96ac86afa9d8a15e5ee11db863a96b..743d8bb15f7711b96d52d2b57b1da09d7dfd31db 100644 (file)
@@ -1410,6 +1410,12 @@ Value *InstCombiner::SimplifyDemandedVectorElts(Value *V, uint64_t DemandedElts,
   } else if (isa<ConstantAggregateZero>(V)) {
     // Simplify the CAZ to a ConstantVector where the non-demanded elements are
     // set to undef.
+    
+    // Check if this is identity. If so, return 0 since we are not simplifying
+    // anything.
+    if (DemandedElts == ((1ULL << VWidth) -1))
+      return 0;
+    
     const Type *EltTy = cast<VectorType>(V->getType())->getElementType();
     Constant *Zero = Constant::getNullValue(EltTy);
     Constant *Undef = UndefValue::get(EltTy);