diff options
author | Andrew Trick <atrick@apple.com> | 2012-05-19 00:48:25 +0000 |
---|---|---|
committer | Andrew Trick <atrick@apple.com> | 2012-05-19 00:48:25 +0000 |
commit | 8aa22019ca5ef29a15058be905d782e7225aa206 (patch) | |
tree | 8b4d0c98b890e76017e78904ec69c94f16457f96 /test/Analysis/ScalarEvolution | |
parent | ce5d8b0d03b9c37727d08de4fa1bcc7be7ea8bb1 (diff) | |
download | external_llvm-8aa22019ca5ef29a15058be905d782e7225aa206.zip external_llvm-8aa22019ca5ef29a15058be905d782e7225aa206.tar.gz external_llvm-8aa22019ca5ef29a15058be905d782e7225aa206.tar.bz2 |
SCEV: Add MarkPendingLoopPredicates to avoid recursive isImpliedCond.
getUDivExpr attempts to simplify by checking for overflow.
isLoopEntryGuardedByCond then evaluates the loop predicate which
may lead to the same getUDivExpr causing endless recursion.
Fixes PR12868: clang 3.2 segmentation fault.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157092 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Analysis/ScalarEvolution')
-rw-r--r-- | test/Analysis/ScalarEvolution/2012-05-18-LoopPredRecurse.ll | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/test/Analysis/ScalarEvolution/2012-05-18-LoopPredRecurse.ll b/test/Analysis/ScalarEvolution/2012-05-18-LoopPredRecurse.ll new file mode 100644 index 0000000..52e6683 --- /dev/null +++ b/test/Analysis/ScalarEvolution/2012-05-18-LoopPredRecurse.ll @@ -0,0 +1,30 @@ +; RUN: opt < %s -iv-users -S -disable-output +; +; PR12868: Infinite recursion: +; getUDivExpr()->getZeroExtendExpr()->isLoopBackedgeGuardedBy() +; +; We actually want SCEV simplification to fail gracefully in this +; case, so there's no output to check, just the absense of stack overflow. + +@c = common global i8 0, align 1 + +define i32 @func() { +entry: + br label %for.cond + +for.cond: ; preds = %for.body, %entry + %storemerge = phi i8 [ -1, %entry ], [ %inc, %for.body ] + %ui.0 = phi i32 [ undef, %entry ], [ %div, %for.body ] + %tobool = icmp eq i8 %storemerge, 0 + br i1 %tobool, label %for.end, label %for.body + +for.body: ; preds = %for.cond + %conv = sext i8 %storemerge to i32 + %div = lshr i32 %conv, 1 + %tobool2 = icmp eq i32 %div, 0 + %inc = add i8 %storemerge, 1 + br i1 %tobool2, label %for.cond, label %for.end + +for.end: ; preds = %for.body, %for.cond + ret i32 0 +} |