Don't call getValueType() on a null SDValue
authorJakob Stoklund Olesen <stoklund@2pi.dk>
Thu, 3 Dec 2009 05:15:35 +0000 (05:15 +0000)
committerJakob Stoklund Olesen <stoklund@2pi.dk>
Thu, 3 Dec 2009 05:15:35 +0000 (05:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@90415 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/DAGCombiner.cpp

index 06ffdd63881f11e2ed36b6ed760f363dab894250..64331b0fe26bc8173cf06e0ea7ff921250db7100 100644 (file)
@@ -546,7 +546,8 @@ SDValue DAGCombiner::CombineTo(SDNode *N, const SDValue *To, unsigned NumTo,
         To[0].getNode()->dump(&DAG);
         errs() << " and " << NumTo-1 << " other values\n";
         for (unsigned i = 0, e = NumTo; i != e; ++i)
-          assert(N->getValueType(i) == To[i].getValueType() &&
+          assert((!To[i].getNode() ||
+                  N->getValueType(i) == To[i].getValueType()) &&
                  "Cannot combine value to value of different type!"));
   WorkListRemover DeadNodes(*this);
   DAG.ReplaceAllUsesWith(N, To, &DeadNodes);