blob: c75752d0294b783ef79eaed2a877fb6e5e1bdfaf [file] [log] [blame]
Arthur Eubanksd0acd972020-08-05 13:49:00 -07001; RUN: opt < %s -loop-unswitch -enable-new-pm=0 -verify-loop-info -S < %s 2>&1 | FileCheck %s
2; RUN: opt < %s -loop-unswitch -enable-new-pm=0 -verify-loop-info -enable-mssa-loop-dependency=true -verify-memoryssa -S < %s 2>&1 | FileCheck %s
Eric Christophercee313d2019-04-17 04:52:47 +00003
4; There are 1 case and 1 default case in the switch. after we unswitch, we know the
5; %a is definitely not 0 in one of the unswitched loop, make sure we take advantage
6; of that and simplify the branches in the loop.
7;
8; CHECK: define void @simplify_with_nonvalness(
9
10; This is the loop in which we know %a is definitely 0.
11; CHECK: sw.bb.us:
12; CHECK: br i1 true, label %if.then.us, label %if.end.us
13
14; This is the loop in which we do not know what %a is but we know %a is definitely NOT 0.
15; Make sure we use that information to simplify.
16; The icmp eq i32 %a, 0 in one of the unswitched loop is simplified to false.
17; CHECK: sw.bb.split:
18; CHECK: br i1 false, label %if.then, label %if.end
19
20define void @simplify_with_nonvalness(i32 %a) #0 {
21entry:
22 br label %for.cond
23
24for.cond:
25 %i.0 = phi i32 [ 0, %entry ], [ %inc, %for.inc ]
26 %cmp = icmp slt i32 %i.0, 1024
27 br i1 %cmp, label %for.body, label %for.end
28
29for.body:
30 switch i32 %a, label %sw.default [
31 i32 0, label %sw.bb
32 ]
33
34sw.bb:
35 %cmp1 = icmp eq i32 %a, 0
36 br i1 %cmp1, label %if.then, label %if.end
37
38if.then:
39 call void (...) @bar()
40 br label %if.end
41
42if.end:
43 br label %sw.epilog
44
45sw.default:
46 br label %sw.epilog
47
48sw.epilog:
49 br label %for.inc
50
51for.inc:
52 %inc = add nsw i32 %i.0, 1
53 br label %for.cond
54
55for.end:
56 ret void
57}
58
59declare void @bar(...)