Fix for PR9633 [indvars] Assertion `isa<X>(Val) && "cast<Ty>() argument of incompatib...
authorAndrew Trick <atrick@apple.com>
Wed, 27 Apr 2011 01:21:25 +0000 (01:21 +0000)
committerAndrew Trick <atrick@apple.com>
Wed, 27 Apr 2011 01:21:25 +0000 (01:21 +0000)
Added a type check in ScalarEvolution::computeSCEVAtScope to handle the case in which operands of an
AddRecExpr in the current scope are folded.

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

lib/Analysis/ScalarEvolution.cpp

index 3f69ce80f43e38c292b295c46032fec8e90c5f7a..9396b07dab923c8639d09bf3e00723cbcd170317 100644 (file)
@@ -4701,9 +4701,14 @@ const SCEV *ScalarEvolution::computeSCEVAtScope(const SCEV *V, const Loop *L) {
       for (++i; i != e; ++i)
         NewOps.push_back(getSCEVAtScope(AddRec->getOperand(i), L));
 
-      AddRec = cast<SCEVAddRecExpr>(
+      const SCEV *FoldedRec =
         getAddRecExpr(NewOps, AddRec->getLoop(),
-                      AddRec->getNoWrapFlags(SCEV::FlagNW)));
+                      AddRec->getNoWrapFlags(SCEV::FlagNW));
+      AddRec = dyn_cast<SCEVAddRecExpr>(FoldedRec);
+      // In cases with "undef" values, a loop's own recurrence may
+      // fold into a constant. Go ahead and return the optimistic value.
+      if (!AddRec)
+        return FoldedRec;
       break;
     }