Be conservative if getresult operand is neither call nor invoke.
authorDevang Patel <dpatel@apple.com>
Wed, 9 Apr 2008 15:58:24 +0000 (15:58 +0000)
committerDevang Patel <dpatel@apple.com>
Wed, 9 Apr 2008 15:58:24 +0000 (15:58 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49430 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/SCCP.cpp

index 0fd93163474917627e48216d73e0659452219b1b..ec2d368d72c0fd191daea1c264b7023478b28f6d 100644 (file)
@@ -690,12 +690,13 @@ void SCCPSolver::visitGetResultInst(GetResultInst &GRI) {
   unsigned Idx = GRI.getIndex();
   Value *Aggr = GRI.getOperand(0);
   Function *F = NULL;
-  if (CallInst *CI = dyn_cast<CallInst>(Aggr)) 
+  if (CallInst *CI = dyn_cast<CallInst>(Aggr))
     F = CI->getCalledFunction();
   else if (InvokeInst *II = dyn_cast<InvokeInst>(Aggr))
     F = II->getCalledFunction();
 
-  assert (F && "Invalid GetResultInst operands!");
+  if (!F)
+    return;
 
   std::multimap<Function*, LatticeValIndexed>::iterator It, E;
   tie(It, E) = TrackedMultipleRetVals.equal_range(F);