Fix two warnings in polly, -Wmismatched-tags and -Wreorder
[polly-mirror.git] / test / ScopInfo / run-time-check-many-array-disjuncts.ll
blob191f4bd9cde989f26460240380ec04fd9259f493
1 ; RUN: opt %loadPolly -polly-detect -analyze < %s \
2 ; RUN: | FileCheck %s -check-prefix=DETECT
3 ; RUN: opt %loadPolly -polly-scops -analyze < %s | FileCheck %s
5 ; DETECT: Valid Region for Scop: bb124 => bb176
7 ; A valid Scop would print the list of it's statements, we check that we do not
8 ; see that list.
10 ; CHECK-NOT: Statements
12 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
13 target triple = "aarch64--linux-android"
15 %0 = type { i8*, i64, i64, i64, i64, i64, i64 }
17 define void @_Z1fR1SS0_Ph(%0* nocapture readonly dereferenceable(56) %arg, %0* nocapture readonly dereferenceable(56) %arg1, i8* nocapture readonly %arg2) {
18 bb:
19   %tmp = getelementptr inbounds %0, %0* %arg1, i64 0, i32 1
20   %tmp3 = getelementptr inbounds %0, %0* %arg, i64 0, i32 0
21   %tmp4 = load i8*, i8** %tmp3, align 8
22   %tmp5 = getelementptr inbounds %0, %0* %arg, i64 0, i32 4
23   %tmp6 = load i64, i64* %tmp5, align 8
24   %tmp7 = getelementptr inbounds %0, %0* %arg, i64 0, i32 1
25   %tmp8 = load i64, i64* %tmp7, align 8
26   %tmp9 = mul i64 %tmp8, %tmp6
27   %tmp10 = getelementptr inbounds i8, i8* %tmp4, i64 %tmp9
28   %tmp11 = getelementptr inbounds %0, %0* %arg, i64 0, i32 3
29   %tmp12 = load i64, i64* %tmp11, align 8
30   %tmp13 = getelementptr inbounds i8, i8* %tmp10, i64 %tmp12
31   %tmp14 = getelementptr inbounds %0, %0* %arg, i64 0, i32 6
32   %tmp15 = load i64, i64* %tmp14, align 8
33   %tmp16 = add i64 %tmp15, 1
34   %tmp17 = icmp eq i64 %tmp16, %tmp6
35   br i1 %tmp17, label %bb51, label %bb18
37 bb18:                                             ; preds = %bb
38   %tmp19 = getelementptr inbounds %0, %0* %arg, i64 0, i32 2
39   %tmp20 = load i64, i64* %tmp19, align 8
40   %tmp21 = mul i64 %tmp20, %tmp8
41   %tmp22 = getelementptr inbounds i8, i8* %tmp13, i64 %tmp21
42   %tmp23 = getelementptr inbounds i8, i8* %tmp22, i64 %tmp9
43   %tmp24 = getelementptr inbounds i8, i8* %tmp23, i64 %tmp12
44   %tmp25 = bitcast %0* %arg1 to i16**
45   %tmp26 = load i16*, i16** %tmp25, align 8
46   %tmp27 = load i64, i64* %tmp, align 8
47   %tmp28 = getelementptr inbounds %0, %0* %arg1, i64 0, i32 4
48   %tmp29 = load i64, i64* %tmp28, align 8
49   %tmp30 = mul i64 %tmp27, %tmp29
50   %tmp31 = getelementptr inbounds i16, i16* %tmp26, i64 %tmp30
51   %tmp32 = getelementptr inbounds %0, %0* %arg1, i64 0, i32 3
52   %tmp33 = load i64, i64* %tmp32, align 8
53   %tmp34 = getelementptr inbounds i16, i16* %tmp31, i64 %tmp33
54   %tmp35 = getelementptr inbounds %0, %0* %arg, i64 0, i32 5
55   %tmp36 = load i64, i64* %tmp35, align 8
56   br label %bb37
58 bb37:                                             ; preds = %bb57, %bb18
59   %tmp38 = phi i64 [ %tmp6, %bb18 ], [ %tmp58, %bb57 ]
60   %tmp39 = phi i64 [ %tmp15, %bb18 ], [ %tmp59, %bb57 ]
61   %tmp40 = phi i64 [ %tmp27, %bb18 ], [ %tmp60, %bb57 ]
62   %tmp41 = phi i64 [ %tmp8, %bb18 ], [ %tmp61, %bb57 ]
63   %tmp42 = phi i64 [ %tmp12, %bb18 ], [ %tmp62, %bb57 ]
64   %tmp43 = phi i64 [ %tmp36, %bb18 ], [ %tmp63, %bb57 ]
65   %tmp44 = phi i16* [ %tmp34, %bb18 ], [ %tmp69, %bb57 ]
66   %tmp45 = phi i8* [ %tmp13, %bb18 ], [ %tmp64, %bb57 ]
67   %tmp46 = phi i8* [ %tmp24, %bb18 ], [ %tmp68, %bb57 ]
68   %tmp47 = phi i64 [ 0, %bb18 ], [ %tmp70, %bb57 ]
69   %tmp48 = add i64 %tmp43, 1
70   %tmp49 = sub i64 %tmp48, %tmp42
71   %tmp50 = icmp eq i64 %tmp49, 0
72   br i1 %tmp50, label %bb57, label %bb74
74 bb51:                                             ; preds = %bb57, %bb
75   ret void
77 bb52:                                             ; preds = %bb176
78   %tmp53 = load i64, i64* %tmp7, align 8
79   %tmp54 = load i64, i64* %tmp, align 8
80   %tmp55 = load i64, i64* %tmp14, align 8
81   %tmp56 = load i64, i64* %tmp5, align 8
82   br label %bb57
84 bb57:                                             ; preds = %bb52, %bb37
85   %tmp58 = phi i64 [ %tmp56, %bb52 ], [ %tmp38, %bb37 ]
86   %tmp59 = phi i64 [ %tmp55, %bb52 ], [ %tmp39, %bb37 ]
87   %tmp60 = phi i64 [ %tmp54, %bb52 ], [ %tmp40, %bb37 ]
88   %tmp61 = phi i64 [ %tmp53, %bb52 ], [ %tmp41, %bb37 ]
89   %tmp62 = phi i64 [ %tmp179, %bb52 ], [ %tmp42, %bb37 ]
90   %tmp63 = phi i64 [ %tmp178, %bb52 ], [ %tmp43, %bb37 ]
91   %tmp64 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp61
92   %tmp65 = and i64 %tmp47, 1
93   %tmp66 = icmp eq i64 %tmp65, 0
94   %tmp67 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp61
95   %tmp68 = select i1 %tmp66, i8* %tmp46, i8* %tmp67
96   %tmp69 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp60
97   %tmp70 = add i64 %tmp47, 1
98   %tmp71 = add i64 %tmp59, 1
99   %tmp72 = sub i64 %tmp71, %tmp58
100   %tmp73 = icmp ult i64 %tmp70, %tmp72
101   br i1 %tmp73, label %bb37, label %bb51
103 bb74:                                             ; preds = %bb176, %bb37
104   %tmp75 = phi i64 [ %tmp181, %bb176 ], [ %tmp49, %bb37 ]
105   %tmp76 = phi i64 [ %tmp177, %bb176 ], [ 0, %bb37 ]
106   %tmp77 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp76
107   %tmp78 = load i8, i8* %tmp77, align 1
108   %tmp79 = zext i8 %tmp78 to i32
109   %tmp80 = or i64 %tmp76, 1
110   %tmp81 = getelementptr inbounds i8, i8* %tmp45, i64 %tmp80
111   %tmp82 = load i8, i8* %tmp81, align 1
112   %tmp83 = zext i8 %tmp82 to i32
113   %tmp84 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp76
114   %tmp85 = load i8, i8* %tmp84, align 1
115   %tmp86 = zext i8 %tmp85 to i32
116   %tmp87 = getelementptr inbounds i8, i8* %tmp46, i64 %tmp80
117   %tmp88 = load i8, i8* %tmp87, align 1
118   %tmp89 = zext i8 %tmp88 to i32
119   %tmp90 = mul nuw nsw i32 %tmp86, 517
120   %tmp91 = add nsw i32 %tmp90, -66176
121   %tmp92 = sub nsw i32 128, %tmp86
122   %tmp93 = mul nsw i32 %tmp92, 100
123   %tmp94 = sub nsw i32 128, %tmp89
124   %tmp95 = mul nsw i32 %tmp94, 208
125   %tmp96 = mul nuw nsw i32 %tmp89, 409
126   %tmp97 = add nsw i32 %tmp96, -52352
127   %tmp98 = mul nuw nsw i32 %tmp79, 298
128   %tmp99 = add nsw i32 %tmp98, -4768
129   %tmp100 = add nsw i32 %tmp91, %tmp99
130   %tmp101 = sdiv i32 %tmp100, 256
131   %tmp102 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp99, i32 %tmp95)
132   %tmp103 = extractvalue { i32, i1 } %tmp102, 1
133   br i1 %tmp103, label %bb104, label %bb105
135 bb104:                                            ; preds = %bb120, %bb109, %bb105, %bb74
136   tail call void @llvm.trap()
137   unreachable
139 bb105:                                            ; preds = %bb74
140   %tmp106 = extractvalue { i32, i1 } %tmp102, 0
141   %tmp107 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp106, i32 %tmp93)
142   %tmp108 = extractvalue { i32, i1 } %tmp107, 1
143   br i1 %tmp108, label %bb104, label %bb109
145 bb109:                                            ; preds = %bb105
146   %tmp110 = extractvalue { i32, i1 } %tmp107, 0
147   %tmp111 = sdiv i32 %tmp110, 256
148   %tmp112 = add nsw i32 %tmp97, %tmp99
149   %tmp113 = sdiv i32 %tmp112, 256
150   %tmp114 = mul nuw nsw i32 %tmp83, 298
151   %tmp115 = add nsw i32 %tmp114, -4768
152   %tmp116 = add nsw i32 %tmp91, %tmp115
153   %tmp117 = sdiv i32 %tmp116, 256
154   %tmp118 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp115, i32 %tmp95)
155   %tmp119 = extractvalue { i32, i1 } %tmp118, 1
156   br i1 %tmp119, label %bb104, label %bb120
158 bb120:                                            ; preds = %bb109
159   %tmp121 = extractvalue { i32, i1 } %tmp118, 0
160   %tmp122 = tail call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 %tmp121, i32 %tmp93)
161   %tmp123 = extractvalue { i32, i1 } %tmp122, 1
162   br i1 %tmp123, label %bb104, label %bb124
164 bb124:                                            ; preds = %bb120
165   %tmp125 = sext i32 %tmp101 to i64
166   %tmp126 = getelementptr inbounds i8, i8* %arg2, i64 %tmp125
167   %tmp127 = load i8, i8* %tmp126, align 1
168   %tmp128 = zext i8 %tmp127 to i32
169   %tmp129 = lshr i32 %tmp128, 3
170   %tmp130 = shl nuw nsw i32 %tmp129, 11
171   %tmp131 = sext i32 %tmp111 to i64
172   %tmp132 = getelementptr inbounds i8, i8* %arg2, i64 %tmp131
173   %tmp133 = load i8, i8* %tmp132, align 1
174   %tmp134 = zext i8 %tmp133 to i32
175   %tmp135 = lshr i32 %tmp134, 2
176   %tmp136 = shl nuw nsw i32 %tmp135, 5
177   %tmp137 = or i32 %tmp136, %tmp130
178   %tmp138 = sext i32 %tmp113 to i64
179   %tmp139 = getelementptr inbounds i8, i8* %arg2, i64 %tmp138
180   %tmp140 = load i8, i8* %tmp139, align 1
181   %tmp141 = zext i8 %tmp140 to i32
182   %tmp142 = lshr i32 %tmp141, 3
183   %tmp143 = or i32 %tmp137, %tmp142
184   %tmp144 = icmp ult i64 %tmp80, %tmp75
185   br i1 %tmp144, label %bb145, label %bb173
187 bb145:                                            ; preds = %bb124
188   %tmp146 = add nsw i32 %tmp97, %tmp115
189   %tmp147 = sdiv i32 %tmp146, 256
190   %tmp148 = sext i32 %tmp147 to i64
191   %tmp149 = getelementptr inbounds i8, i8* %arg2, i64 %tmp148
192   %tmp150 = load i8, i8* %tmp149, align 1
193   %tmp151 = extractvalue { i32, i1 } %tmp122, 0
194   %tmp152 = sdiv i32 %tmp151, 256
195   %tmp153 = sext i32 %tmp152 to i64
196   %tmp154 = getelementptr inbounds i8, i8* %arg2, i64 %tmp153
197   %tmp155 = load i8, i8* %tmp154, align 1
198   %tmp156 = sext i32 %tmp117 to i64
199   %tmp157 = getelementptr inbounds i8, i8* %arg2, i64 %tmp156
200   %tmp158 = load i8, i8* %tmp157, align 1
201   %tmp159 = zext i8 %tmp158 to i32
202   %tmp160 = lshr i32 %tmp159, 3
203   %tmp161 = shl nuw nsw i32 %tmp160, 11
204   %tmp162 = zext i8 %tmp155 to i32
205   %tmp163 = lshr i32 %tmp162, 2
206   %tmp164 = shl nuw nsw i32 %tmp163, 5
207   %tmp165 = zext i8 %tmp150 to i32
208   %tmp166 = lshr i32 %tmp165, 3
209   %tmp167 = or i32 %tmp164, %tmp166
210   %tmp168 = or i32 %tmp167, %tmp161
211   %tmp169 = shl nuw i32 %tmp168, 16
212   %tmp170 = or i32 %tmp169, %tmp143
213   %tmp171 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp76
214   %tmp172 = bitcast i16* %tmp171 to i32*
215   store i32 %tmp170, i32* %tmp172, align 4
216   br label %bb176
218 bb173:                                            ; preds = %bb124
219   %tmp174 = trunc i32 %tmp143 to i16
220   %tmp175 = getelementptr inbounds i16, i16* %tmp44, i64 %tmp76
221   store i16 %tmp174, i16* %tmp175, align 2
222   br label %bb176
224 bb176:                                            ; preds = %bb173, %bb145
225   %tmp177 = add i64 %tmp76, 2
226   %tmp178 = load i64, i64* %tmp35, align 8
227   %tmp179 = load i64, i64* %tmp11, align 8
228   %tmp180 = add i64 %tmp178, 1
229   %tmp181 = sub i64 %tmp180, %tmp179
230   %tmp182 = icmp ult i64 %tmp177, %tmp181
231   br i1 %tmp182, label %bb74, label %bb52
234 ; Function Attrs: noreturn nounwind
235 declare void @llvm.trap() #0
237 ; Function Attrs: nounwind readnone
238 declare { i32, i1 } @llvm.sadd.with.overflow.i32(i32, i32) #1
240 attributes #0 = { noreturn nounwind }
241 attributes #1 = { nounwind readnone }