summaryrefslogtreecommitdiffstats
path: root/test/Transforms/LoopUnroll/pr11361.ll
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2011-11-12 03:09:12 +0000
committerNick Lewycky <nicholas@mxc.ca>2011-11-12 03:09:12 +0000
commitd7ecff49d9190262da48a9f5815c01138fd54ebc (patch)
treed9d2d5c69a14a2744ae55a3dff0e79d70d61b39e /test/Transforms/LoopUnroll/pr11361.ll
parent7386612a1635090acf010aaa4c7f68b181fcfe65 (diff)
downloadexternal_llvm-d7ecff49d9190262da48a9f5815c01138fd54ebc.zip
external_llvm-d7ecff49d9190262da48a9f5815c01138fd54ebc.tar.gz
external_llvm-d7ecff49d9190262da48a9f5815c01138fd54ebc.tar.bz2
Don't try to loop on iterators that are potentially invalidated inside the loop. Fixes PR11361!
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144454 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/LoopUnroll/pr11361.ll')
-rw-r--r--test/Transforms/LoopUnroll/pr11361.ll42
1 files changed, 42 insertions, 0 deletions
diff --git a/test/Transforms/LoopUnroll/pr11361.ll b/test/Transforms/LoopUnroll/pr11361.ll
new file mode 100644
index 0000000..7ce7f5f
--- /dev/null
+++ b/test/Transforms/LoopUnroll/pr11361.ll
@@ -0,0 +1,42 @@
+; RUN: opt -loop-unroll -disable-output
+; PR11361
+
+; This tests for an iterator invalidation issue.
+
+target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @func_1() nounwind uwtable {
+entry:
+ br label %for.cond8.preheader
+
+for.cond8.preheader: ; preds = %for.inc15, %entry
+ %l_1264.04 = phi i32 [ 0, %entry ], [ %add.i, %for.inc15 ]
+ %l_1330.0.03 = phi i80 [ undef, %entry ], [ %ins.lcssa, %for.inc15 ]
+ br label %for.body9
+
+for.body9: ; preds = %for.body9, %for.cond8.preheader
+ %l_1330.0.12 = phi i80 [ %l_1330.0.03, %for.cond8.preheader ], [ %ins, %for.body9 ]
+ %storemerge1 = phi i32 [ 7, %for.cond8.preheader ], [ %sub, %for.body9 ]
+ %tmp = lshr i80 %l_1330.0.12, 8
+ %tmp1 = trunc i80 %tmp to i8
+ %inc12 = add i8 %tmp1, 1
+ %tmp2 = zext i8 %inc12 to i80
+ %tmp3 = shl nuw nsw i80 %tmp2, 8
+ %mask = and i80 %l_1330.0.12, -65281
+ %ins = or i80 %tmp3, %mask
+ %sub = add nsw i32 %storemerge1, -1
+ %tobool = icmp eq i32 %sub, 0
+ br i1 %tobool, label %for.inc15, label %for.body9
+
+for.inc15: ; preds = %for.body9
+ %ins.lcssa = phi i80 [ %ins, %for.body9 ]
+ %sext = shl i32 %l_1264.04, 24
+ %conv.i = ashr exact i32 %sext, 24
+ %add.i = add nsw i32 %conv.i, 1
+ %cmp = icmp slt i32 %add.i, 3
+ br i1 %cmp, label %for.cond8.preheader, label %for.end16
+
+for.end16: ; preds = %for.inc15
+ ret void
+}