[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / Transforms / LoopVectorize / lcssa-crash.ll
blob3d3ef9e05935c7dba9f1faf057ddc234acb9bb60
1 ; RUN: opt < %s  -loop-vectorize -force-vector-interleave=1 -force-vector-width=4 
3 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"
5 %type1 = type { %type2 }
6 %type2 = type { [0 x i8*], i8**, i32, i32, i32 }
8 define void @test() nounwind uwtable align 2 {
9   br label %for.body.lr.ph.i.i.i
11 for.body.lr.ph.i.i.i:
12   br label %for.body.i.i.i
14 for.body.i.i.i:
15   %indvars.iv = phi i64 [ %indvars.iv.next, %for.inc.i.i.i ], [ 0, %for.body.lr.ph.i.i.i ]
16   br label %for.inc.i.i.i
18 for.inc.i.i.i:
19   %indvars.iv.next = add i64 %indvars.iv, 1
20   %lftr.wideiv = trunc i64 %indvars.iv.next to i32
21   %exitcond = icmp ne i32 %lftr.wideiv, undef
22   br i1 %exitcond, label %for.body.i.i.i, label %for.end.i.i.i
24 for.end.i.i.i:
25   %lcssa = phi %type1* [ undef, %for.inc.i.i.i ]
26   unreachable
29 ; PR16139
30 define void @test2(i8* %x) {
31 entry:
32   indirectbr i8* %x, [ label %L0, label %L1 ]
34 L0:
35   br label %L0
37 L1:
38   ret void
41 ; This loop has different uniform instructions before and after LCSSA.
42 define void @test3() {
43 entry:
44   %add41 = add i32 undef, undef
45   %idxprom4736 = zext i32 %add41 to i64
46   br label %while.body
48 while.body:
49   %idxprom4738 = phi i64 [ %idxprom47, %while.body ], [ %idxprom4736, %entry ]
50   %pos.337 = phi i32 [ %inc46, %while.body ], [ %add41, %entry ]
51   %inc46 = add i32 %pos.337, 1
52   %arrayidx48 = getelementptr inbounds [1024 x i8], [1024 x i8]* undef, i64 0, i64 %idxprom4738
53   store i8 0, i8* %arrayidx48, align 1
54   %and43 = and i32 %inc46, 3
55   %cmp44 = icmp eq i32 %and43, 0
56   %idxprom47 = zext i32 %inc46 to i64
57   br i1 %cmp44, label %while.end, label %while.body
59 while.end:
60   %add58 = add i32 %inc46, 4
61   ret void