[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / LoopStrengthReduce / 2011-10-03-CritEdgeMerge.ll
blobbf52c968ad870858ec914bd7befc52e2f8dc61ab
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -loop-reduce -S < %s | FileCheck %s
4 ; Test LSR's use of SplitCriticalEdge during phi rewriting.
6 target triple = "x86_64-apple-darwin"
8 ; Provide legal integer types.
9 target datalayout = "n8:16:32:64"
11 ; Verify that identical edges are merged. rdar://problem/6453893
13 define ptr @test1() {
15 ; CHECK-LABEL: @test1(
16 ; CHECK-NEXT:  entry:
17 ; CHECK-NEXT:    br label [[LOOP:%.*]]
18 ; CHECK:       loop:
19 ; CHECK-NEXT:    [[LSR_IV:%.*]] = phi ptr [ [[SCEVGEP:%.*]], [[LOOP]] ], [ null, [[ENTRY:%.*]] ]
20 ; CHECK-NEXT:    [[SCEVGEP]] = getelementptr i8, ptr [[LSR_IV]], i64 1
21 ; CHECK-NEXT:    br i1 false, label [[LOOP]], label [[LOOPEXIT:%.*]]
22 ; CHECK:       loopexit:
23 ; CHECK-NEXT:    [[SCEVGEP_LCSSA:%.*]] = phi ptr [ [[SCEVGEP]], [[LOOP]] ]
24 ; CHECK-NEXT:    br i1 false, label [[BBA:%.*]], label [[BBB:%.*]]
25 ; CHECK:       bbA:
26 ; CHECK-NEXT:    switch i32 0, label [[BBA_BB89_CRIT_EDGE:%.*]] [
27 ; CHECK-NEXT:    i32 47, label [[BBA_BB89_CRIT_EDGE]]
28 ; CHECK-NEXT:    i32 58, label [[BBA_BB89_CRIT_EDGE]]
29 ; CHECK-NEXT:    ]
30 ; CHECK:       bbA.bb89_crit_edge:
31 ; CHECK-NEXT:    br label [[BB89:%.*]]
32 ; CHECK:       bbB:
33 ; CHECK-NEXT:    switch i8 0, label [[BBB_BB89_CRIT_EDGE:%.*]] [
34 ; CHECK-NEXT:    i8 47, label [[BBB_BB89_CRIT_EDGE]]
35 ; CHECK-NEXT:    i8 58, label [[BBB_BB89_CRIT_EDGE]]
36 ; CHECK-NEXT:    ]
37 ; CHECK:       bbB.bb89_crit_edge:
38 ; CHECK-NEXT:    br label [[BB89]]
39 ; CHECK:       bb89:
40 ; CHECK-NEXT:    [[TMP75PHI:%.*]] = phi ptr [ [[SCEVGEP_LCSSA]], [[BBA_BB89_CRIT_EDGE]] ], [ [[SCEVGEP_LCSSA]], [[BBB_BB89_CRIT_EDGE]] ]
41 ; CHECK-NEXT:    br label [[EXIT:%.*]]
42 ; CHECK:       exit:
43 ; CHECK-NEXT:    ret ptr [[TMP75PHI]]
45 entry:
46   br label %loop
48 loop:
49   %rec = phi i32 [ %next, %loop ], [ 0, %entry ]
50   %next = add i32 %rec, 1
51   %tmp75 = getelementptr i8, ptr null, i32 %next
52   br i1 false, label %loop, label %loopexit
54 loopexit:
55   br i1 false, label %bbA, label %bbB
57 bbA:
58   switch i32 0, label %bb89 [
59   i32 47, label %bb89
60   i32 58, label %bb89
61   ]
63 bbB:
64   switch i8 0, label %bb89 [
65   i8 47, label %bb89
66   i8 58, label %bb89
67   ]
69 bb89:
70   %tmp75phi = phi ptr [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbB ], [ %tmp75, %bbB ], [ %tmp75, %bbB ]
71   br label %exit
73 exit:
74   ret ptr %tmp75phi
77 ; Handle single-predecessor phis: PR13756
78 define ptr @test2() {
80 ; CHECK-LABEL: @test2(
81 ; CHECK-NEXT:  entry:
82 ; CHECK-NEXT:    br label [[LOOP:%.*]]
83 ; CHECK:       loop:
84 ; CHECK-NEXT:    [[LSR_IV:%.*]] = phi ptr [ [[SCEVGEP:%.*]], [[LOOP]] ], [ null, [[ENTRY:%.*]] ]
85 ; CHECK-NEXT:    [[SCEVGEP]] = getelementptr i8, ptr [[LSR_IV]], i64 1
86 ; CHECK-NEXT:    br i1 false, label [[LOOP]], label [[LOOPEXIT:%.*]]
87 ; CHECK:       loopexit:
88 ; CHECK-NEXT:    [[SCEVGEP_LCSSA1:%.*]] = phi ptr [ [[SCEVGEP]], [[LOOP]] ]
89 ; CHECK-NEXT:    [[SCEVGEP_LCSSA:%.*]] = phi ptr [ [[SCEVGEP]], [[LOOP]] ]
90 ; CHECK-NEXT:    br i1 false, label [[BBA:%.*]], label [[BBB:%.*]]
91 ; CHECK:       bbA:
92 ; CHECK-NEXT:    switch i32 0, label [[BB89:%.*]] [
93 ; CHECK-NEXT:    i32 47, label [[BB89]]
94 ; CHECK-NEXT:    i32 58, label [[BB89]]
95 ; CHECK-NEXT:    ]
96 ; CHECK:       bbB:
97 ; CHECK-NEXT:    switch i8 0, label [[BBB_EXIT_CRIT_EDGE:%.*]] [
98 ; CHECK-NEXT:    i8 47, label [[BBB_EXIT_CRIT_EDGE]]
99 ; CHECK-NEXT:    i8 58, label [[BBB_EXIT_CRIT_EDGE]]
100 ; CHECK-NEXT:    ]
101 ; CHECK:       bbB.exit_crit_edge:
102 ; CHECK-NEXT:    br label [[EXIT:%.*]]
103 ; CHECK:       bb89:
104 ; CHECK-NEXT:    [[TMP75PHI:%.*]] = phi ptr [ [[SCEVGEP_LCSSA1]], [[BBA]] ], [ [[SCEVGEP_LCSSA1]], [[BBA]] ], [ [[SCEVGEP_LCSSA1]], [[BBA]] ]
105 ; CHECK-NEXT:    br label [[EXIT]]
106 ; CHECK:       exit:
107 ; CHECK-NEXT:    [[RESULT:%.*]] = phi ptr [ [[TMP75PHI]], [[BB89]] ], [ [[SCEVGEP_LCSSA]], [[BBB_EXIT_CRIT_EDGE]] ]
108 ; CHECK-NEXT:    ret ptr [[RESULT]]
110 entry:
111   br label %loop
113 loop:
114   %rec = phi i32 [ %next, %loop ], [ 0, %entry ]
115   %next = add i32 %rec, 1
116   %tmp75 = getelementptr i8, ptr null, i32 %next
117   br i1 false, label %loop, label %loopexit
119 loopexit:
120   br i1 false, label %bbA, label %bbB
122 bbA:
123   switch i32 0, label %bb89 [
124   i32 47, label %bb89
125   i32 58, label %bb89
126   ]
128 bbB:
129   switch i8 0, label %exit [
130   i8 47, label %exit
131   i8 58, label %exit
132   ]
134 bb89:
135   %tmp75phi = phi ptr [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbA ]
136   br label %exit
138 exit:
139   %result = phi ptr [ %tmp75phi, %bb89 ], [ %tmp75, %bbB ], [ %tmp75, %bbB ], [ %tmp75, %bbB ]
140   ret ptr %result