1 ; RUN: opt < %s -analyze -basicaa -da | FileCheck %s 2 3 ; ModuleID = 'Propagating.bc' 4 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 target triple = "x86_64-apple-macosx10.6.0" 6 7 8 ;; for (long int i = 0; i < 100; i++) 9 ;; for (long int j = 0; j < 100; j++) { 10 ;; A[i + 1][i + j] = i; 11 ;; *B++ = A[i][i + j]; 12 13 define void @prop0([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 14 entry: 15 br label %for.cond1.preheader 16 17 ; CHECK: da analyze - none! 18 ; CHECK: da analyze - consistent flow [1 -1]! 19 ; CHECK: da analyze - confused! 20 ; CHECK: da analyze - none! 21 ; CHECK: da analyze - confused! 22 ; CHECK: da analyze - none! 23 24 for.cond1.preheader: ; preds = %entry, %for.inc9 25 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc9 ] 26 %i.03 = phi i64 [ 0, %entry ], [ %inc10, %for.inc9 ] 27 br label %for.body3 28 29 for.body3: ; preds = %for.cond1.preheader, %for.body3 30 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 31 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 32 %conv = trunc i64 %i.03 to i32 33 %add = add nsw i64 %i.03, %j.02 34 %add4 = add nsw i64 %i.03, 1 35 %arrayidx5 = getelementptr inbounds [100 x i32]* %A, i64 %add4, i64 %add 36 store i32 %conv, i32* %arrayidx5, align 4 37 %add6 = add nsw i64 %i.03, %j.02 38 %arrayidx8 = getelementptr inbounds [100 x i32]* %A, i64 %i.03, i64 %add6 39 %0 = load i32* %arrayidx8, align 4 40 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 41 store i32 %0, i32* %B.addr.11, align 4 42 %inc = add nsw i64 %j.02, 1 43 %exitcond = icmp ne i64 %inc, 100 44 br i1 %exitcond, label %for.body3, label %for.inc9 45 46 for.inc9: ; preds = %for.body3 47 %scevgep = getelementptr i32* %B.addr.04, i64 100 48 %inc10 = add nsw i64 %i.03, 1 49 %exitcond5 = icmp ne i64 %inc10, 100 50 br i1 %exitcond5, label %for.cond1.preheader, label %for.end11 51 52 for.end11: ; preds = %for.inc9 53 ret void 54 } 55 56 57 ;; for (long int i = 0; i < 100; i++) 58 ;; for (long int j = 0; j < 100; j++) 59 ;; for (long int k = 0; k < 100; k++) { 60 ;; A[j - i][i + 1][j + k] = i; 61 ;; *B++ = A[j - i][i][j + k]; 62 63 define void @prop1([100 x [100 x i32]]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 64 entry: 65 br label %for.cond1.preheader 66 67 ; CHECK: da analyze - none! 68 ; CHECK: da analyze - consistent flow [1 1 -1]! 69 ; CHECK: da analyze - confused! 70 ; CHECK: da analyze - none! 71 ; CHECK: da analyze - confused! 72 ; CHECK: da analyze - none! 73 74 for.cond1.preheader: ; preds = %entry, %for.inc18 75 %B.addr.06 = phi i32* [ %B, %entry ], [ %scevgep7, %for.inc18 ] 76 %i.05 = phi i64 [ 0, %entry ], [ %inc19, %for.inc18 ] 77 br label %for.cond4.preheader 78 79 for.cond4.preheader: ; preds = %for.cond1.preheader, %for.inc15 80 %B.addr.14 = phi i32* [ %B.addr.06, %for.cond1.preheader ], [ %scevgep, %for.inc15 ] 81 %j.03 = phi i64 [ 0, %for.cond1.preheader ], [ %inc16, %for.inc15 ] 82 br label %for.body6 83 84 for.body6: ; preds = %for.cond4.preheader, %for.body6 85 %k.02 = phi i64 [ 0, %for.cond4.preheader ], [ %inc, %for.body6 ] 86 %B.addr.21 = phi i32* [ %B.addr.14, %for.cond4.preheader ], [ %incdec.ptr, %for.body6 ] 87 %conv = trunc i64 %i.05 to i32 88 %add = add nsw i64 %j.03, %k.02 89 %add7 = add nsw i64 %i.05, 1 90 %sub = sub nsw i64 %j.03, %i.05 91 %arrayidx9 = getelementptr inbounds [100 x [100 x i32]]* %A, i64 %sub, i64 %add7, i64 %add 92 store i32 %conv, i32* %arrayidx9, align 4 93 %add10 = add nsw i64 %j.03, %k.02 94 %sub11 = sub nsw i64 %j.03, %i.05 95 %arrayidx14 = getelementptr inbounds [100 x [100 x i32]]* %A, i64 %sub11, i64 %i.05, i64 %add10 96 %0 = load i32* %arrayidx14, align 4 97 %incdec.ptr = getelementptr inbounds i32* %B.addr.21, i64 1 98 store i32 %0, i32* %B.addr.21, align 4 99 %inc = add nsw i64 %k.02, 1 100 %exitcond = icmp ne i64 %inc, 100 101 br i1 %exitcond, label %for.body6, label %for.inc15 102 103 for.inc15: ; preds = %for.body6 104 %scevgep = getelementptr i32* %B.addr.14, i64 100 105 %inc16 = add nsw i64 %j.03, 1 106 %exitcond8 = icmp ne i64 %inc16, 100 107 br i1 %exitcond8, label %for.cond4.preheader, label %for.inc18 108 109 for.inc18: ; preds = %for.inc15 110 %scevgep7 = getelementptr i32* %B.addr.06, i64 10000 111 %inc19 = add nsw i64 %i.05, 1 112 %exitcond9 = icmp ne i64 %inc19, 100 113 br i1 %exitcond9, label %for.cond1.preheader, label %for.end20 114 115 for.end20: ; preds = %for.inc18 116 ret void 117 } 118 119 120 ;; for (long int i = 0; i < 100; i++) 121 ;; for (long int j = 0; j < 100; j++) { 122 ;; A[i - 1][2*i] = i; 123 ;; *B++ = A[i][i + j + 110]; 124 125 define void @prop2([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 126 entry: 127 br label %for.cond1.preheader 128 129 ; CHECK: da analyze - consistent output [0 S]! 130 ; CHECK: da analyze - none! 131 ; CHECK: da analyze - confused! 132 ; CHECK: da analyze - none! 133 ; CHECK: da analyze - confused! 134 ; CHECK: da analyze - none! 135 136 for.cond1.preheader: ; preds = %entry, %for.inc8 137 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc8 ] 138 %i.03 = phi i64 [ 0, %entry ], [ %inc9, %for.inc8 ] 139 br label %for.body3 140 141 for.body3: ; preds = %for.cond1.preheader, %for.body3 142 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 143 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 144 %conv = trunc i64 %i.03 to i32 145 %mul = shl nsw i64 %i.03, 1 146 %sub = add nsw i64 %i.03, -1 147 %arrayidx4 = getelementptr inbounds [100 x i32]* %A, i64 %sub, i64 %mul 148 store i32 %conv, i32* %arrayidx4, align 4 149 %add = add nsw i64 %i.03, %j.02 150 %add5 = add nsw i64 %add, 110 151 %arrayidx7 = getelementptr inbounds [100 x i32]* %A, i64 %i.03, i64 %add5 152 %0 = load i32* %arrayidx7, align 4 153 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 154 store i32 %0, i32* %B.addr.11, align 4 155 %inc = add nsw i64 %j.02, 1 156 %exitcond = icmp ne i64 %inc, 100 157 br i1 %exitcond, label %for.body3, label %for.inc8 158 159 for.inc8: ; preds = %for.body3 160 %scevgep = getelementptr i32* %B.addr.04, i64 100 161 %inc9 = add nsw i64 %i.03, 1 162 %exitcond5 = icmp ne i64 %inc9, 100 163 br i1 %exitcond5, label %for.cond1.preheader, label %for.end10 164 165 for.end10: ; preds = %for.inc8 166 ret void 167 } 168 169 170 ;; for (long int i = 0; i < 100; i++) 171 ;; for (long int j = 0; j < 100; j++) { 172 ;; A[i][2*j + i] = i; 173 ;; *B++ = A[i][2*j - i + 5]; 174 175 define void @prop3([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 176 entry: 177 br label %for.cond1.preheader 178 179 ; CHECK: da analyze - none! 180 ; CHECK: da analyze - none! 181 ; CHECK: da analyze - confused! 182 ; CHECK: da analyze - none! 183 ; CHECK: da analyze - confused! 184 ; CHECK: da analyze - none! 185 186 for.cond1.preheader: ; preds = %entry, %for.inc9 187 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc9 ] 188 %i.03 = phi i64 [ 0, %entry ], [ %inc10, %for.inc9 ] 189 br label %for.body3 190 191 for.body3: ; preds = %for.cond1.preheader, %for.body3 192 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 193 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 194 %conv = trunc i64 %i.03 to i32 195 %mul = shl nsw i64 %j.02, 1 196 %add = add nsw i64 %mul, %i.03 197 %arrayidx4 = getelementptr inbounds [100 x i32]* %A, i64 %i.03, i64 %add 198 store i32 %conv, i32* %arrayidx4, align 4 199 %mul5 = shl nsw i64 %j.02, 1 200 %sub = sub nsw i64 %mul5, %i.03 201 %add6 = add nsw i64 %sub, 5 202 %arrayidx8 = getelementptr inbounds [100 x i32]* %A, i64 %i.03, i64 %add6 203 %0 = load i32* %arrayidx8, align 4 204 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 205 store i32 %0, i32* %B.addr.11, align 4 206 %inc = add nsw i64 %j.02, 1 207 %exitcond = icmp ne i64 %inc, 100 208 br i1 %exitcond, label %for.body3, label %for.inc9 209 210 for.inc9: ; preds = %for.body3 211 %scevgep = getelementptr i32* %B.addr.04, i64 100 212 %inc10 = add nsw i64 %i.03, 1 213 %exitcond5 = icmp ne i64 %inc10, 100 214 br i1 %exitcond5, label %for.cond1.preheader, label %for.end11 215 216 for.end11: ; preds = %for.inc9 217 ret void 218 } 219 220 221 ;; for (long int i = 0; i < 100; i++) 222 ;; for (long int j = 0; j < 100; j++) { 223 ;; A[i + 2][2*i + j + 1] = i; 224 ;; *B++ = A[i][2*i + j]; 225 226 define void @prop4([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 227 entry: 228 br label %for.cond1.preheader 229 230 ; CHECK: da analyze - none! 231 ; CHECK: da analyze - consistent flow [2 -3]! 232 ; CHECK: da analyze - confused! 233 ; CHECK: da analyze - none! 234 ; CHECK: da analyze - confused! 235 ; CHECK: da analyze - none! 236 237 for.cond1.preheader: ; preds = %entry, %for.inc11 238 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc11 ] 239 %i.03 = phi i64 [ 0, %entry ], [ %inc12, %for.inc11 ] 240 br label %for.body3 241 242 for.body3: ; preds = %for.cond1.preheader, %for.body3 243 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 244 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 245 %conv = trunc i64 %i.03 to i32 246 %mul = shl nsw i64 %i.03, 1 247 %add = add nsw i64 %mul, %j.02 248 %add4 = add nsw i64 %add, 1 249 %add5 = add nsw i64 %i.03, 2 250 %arrayidx6 = getelementptr inbounds [100 x i32]* %A, i64 %add5, i64 %add4 251 store i32 %conv, i32* %arrayidx6, align 4 252 %mul7 = shl nsw i64 %i.03, 1 253 %add8 = add nsw i64 %mul7, %j.02 254 %arrayidx10 = getelementptr inbounds [100 x i32]* %A, i64 %i.03, i64 %add8 255 %0 = load i32* %arrayidx10, align 4 256 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 257 store i32 %0, i32* %B.addr.11, align 4 258 %inc = add nsw i64 %j.02, 1 259 %exitcond = icmp ne i64 %inc, 100 260 br i1 %exitcond, label %for.body3, label %for.inc11 261 262 for.inc11: ; preds = %for.body3 263 %scevgep = getelementptr i32* %B.addr.04, i64 100 264 %inc12 = add nsw i64 %i.03, 1 265 %exitcond5 = icmp ne i64 %inc12, 100 266 br i1 %exitcond5, label %for.cond1.preheader, label %for.end13 267 268 for.end13: ; preds = %for.inc11 269 ret void 270 } 271 272 273 ;; for (long int i = 0; i < 100; i++) 274 ;; for (long int j = 0; j < 100; j++) { 275 ;; A[3*i - 18][22 - i][2*i + j] = i; 276 ;; *B++ = A[i][i][3*i + j]; 277 278 define void @prop5([100 x [100 x i32]]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 279 entry: 280 br label %for.cond1.preheader 281 282 ; CHECK: da analyze - none! 283 ; CHECK: da analyze - flow [< -16] splitable! 284 ; CHECK: da analyze - split level = 1, iteration = 11! 285 ; CHECK: da analyze - confused! 286 ; CHECK: da analyze - none! 287 ; CHECK: da analyze - confused! 288 ; CHECK: da analyze - none! 289 290 for.cond1.preheader: ; preds = %entry, %for.inc13 291 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc13 ] 292 %i.03 = phi i64 [ 0, %entry ], [ %inc14, %for.inc13 ] 293 br label %for.body3 294 295 for.body3: ; preds = %for.cond1.preheader, %for.body3 296 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 297 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 298 %conv = trunc i64 %i.03 to i32 299 %mul = shl nsw i64 %i.03, 1 300 %add = add nsw i64 %mul, %j.02 301 %sub = sub nsw i64 22, %i.03 302 %mul4 = mul nsw i64 %i.03, 3 303 %sub5 = add nsw i64 %mul4, -18 304 %arrayidx7 = getelementptr inbounds [100 x [100 x i32]]* %A, i64 %sub5, i64 %sub, i64 %add 305 store i32 %conv, i32* %arrayidx7, align 4 306 %mul8 = mul nsw i64 %i.03, 3 307 %add9 = add nsw i64 %mul8, %j.02 308 %arrayidx12 = getelementptr inbounds [100 x [100 x i32]]* %A, i64 %i.03, i64 %i.03, i64 %add9 309 %0 = load i32* %arrayidx12, align 4 310 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 311 store i32 %0, i32* %B.addr.11, align 4 312 %inc = add nsw i64 %j.02, 1 313 %exitcond = icmp ne i64 %inc, 100 314 br i1 %exitcond, label %for.body3, label %for.inc13 315 316 for.inc13: ; preds = %for.body3 317 %scevgep = getelementptr i32* %B.addr.04, i64 100 318 %inc14 = add nsw i64 %i.03, 1 319 %exitcond5 = icmp ne i64 %inc14, 100 320 br i1 %exitcond5, label %for.cond1.preheader, label %for.end15 321 322 for.end15: ; preds = %for.inc13 323 ret void 324 } 325 326 327 ;; for (long int i = 0; i < 100; i++) 328 ;; for (long int j = 0; j < 100; j++) { 329 ;; A[i + 1][4*i + j + 2] = i; 330 ;; *B++ = A[2*i][8*i + j]; 331 332 define void @prop6([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 333 entry: 334 br label %for.cond1.preheader 335 336 ; CHECK: da analyze - none! 337 ; CHECK: da analyze - flow [=> -2]! 338 ; CHECK: da analyze - confused! 339 ; CHECK: da analyze - none! 340 ; CHECK: da analyze - confused! 341 ; CHECK: da analyze - none! 342 343 for.cond1.preheader: ; preds = %entry, %for.inc12 344 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc12 ] 345 %i.03 = phi i64 [ 0, %entry ], [ %inc13, %for.inc12 ] 346 br label %for.body3 347 348 for.body3: ; preds = %for.cond1.preheader, %for.body3 349 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 350 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 351 %conv = trunc i64 %i.03 to i32 352 %mul = shl nsw i64 %i.03, 2 353 %add = add nsw i64 %mul, %j.02 354 %add4 = add nsw i64 %add, 2 355 %add5 = add nsw i64 %i.03, 1 356 %arrayidx6 = getelementptr inbounds [100 x i32]* %A, i64 %add5, i64 %add4 357 store i32 %conv, i32* %arrayidx6, align 4 358 %mul7 = shl nsw i64 %i.03, 3 359 %add8 = add nsw i64 %mul7, %j.02 360 %mul9 = shl nsw i64 %i.03, 1 361 %arrayidx11 = getelementptr inbounds [100 x i32]* %A, i64 %mul9, i64 %add8 362 %0 = load i32* %arrayidx11, align 4 363 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 364 store i32 %0, i32* %B.addr.11, align 4 365 %inc = add nsw i64 %j.02, 1 366 %exitcond = icmp ne i64 %inc, 100 367 br i1 %exitcond, label %for.body3, label %for.inc12 368 369 for.inc12: ; preds = %for.body3 370 %scevgep = getelementptr i32* %B.addr.04, i64 100 371 %inc13 = add nsw i64 %i.03, 1 372 %exitcond5 = icmp ne i64 %inc13, 100 373 br i1 %exitcond5, label %for.cond1.preheader, label %for.end14 374 375 for.end14: ; preds = %for.inc12 376 ret void 377 } 378 379 380 ;; for (long int i = 0; i < 100; i++) 381 ;; for (long int j = 0; j < 100; j++) { 382 ;; A[2*i + 4][-5*i + j + 2] = i; 383 ;; *B++ = A[-2*i + 20][5*i + j]; 384 385 define void @prop7([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 386 entry: 387 br label %for.cond1.preheader 388 389 ; CHECK: da analyze - none! 390 ; CHECK: da analyze - flow [* -38] splitable! 391 ; CHECK: da analyze - split level = 1, iteration = 4! 392 ; CHECK: da analyze - confused! 393 ; CHECK: da analyze - none! 394 ; CHECK: da analyze - confused! 395 ; CHECK: da analyze - none! 396 397 for.cond1.preheader: ; preds = %entry, %for.inc14 398 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc14 ] 399 %i.03 = phi i64 [ 0, %entry ], [ %inc15, %for.inc14 ] 400 br label %for.body3 401 402 for.body3: ; preds = %for.cond1.preheader, %for.body3 403 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 404 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 405 %conv = trunc i64 %i.03 to i32 406 %mul = mul nsw i64 %i.03, -5 407 %add = add nsw i64 %mul, %j.02 408 %add4 = add nsw i64 %add, 2 409 %mul5 = shl nsw i64 %i.03, 1 410 %add6 = add nsw i64 %mul5, 4 411 %arrayidx7 = getelementptr inbounds [100 x i32]* %A, i64 %add6, i64 %add4 412 store i32 %conv, i32* %arrayidx7, align 4 413 %mul8 = mul nsw i64 %i.03, 5 414 %add9 = add nsw i64 %mul8, %j.02 415 %mul10 = mul nsw i64 %i.03, -2 416 %add11 = add nsw i64 %mul10, 20 417 %arrayidx13 = getelementptr inbounds [100 x i32]* %A, i64 %add11, i64 %add9 418 %0 = load i32* %arrayidx13, align 4 419 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 420 store i32 %0, i32* %B.addr.11, align 4 421 %inc = add nsw i64 %j.02, 1 422 %exitcond = icmp ne i64 %inc, 100 423 br i1 %exitcond, label %for.body3, label %for.inc14 424 425 for.inc14: ; preds = %for.body3 426 %scevgep = getelementptr i32* %B.addr.04, i64 100 427 %inc15 = add nsw i64 %i.03, 1 428 %exitcond5 = icmp ne i64 %inc15, 100 429 br i1 %exitcond5, label %for.cond1.preheader, label %for.end16 430 431 for.end16: ; preds = %for.inc14 432 ret void 433 } 434 435 436 ;; for (long int i = 0; i < 100; i++) 437 ;; for (long int j = 0; j < 100; j++) { 438 ;; A[4][j + 2] = i; 439 ;; *B++ = A[-2*i + 4][5*i + j]; 440 441 define void @prop8([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 442 entry: 443 br label %for.cond1.preheader 444 445 ; CHECK: da analyze - consistent output [S 0]! 446 ; CHECK: da analyze - flow [p<= 2]! 447 ; CHECK: da analyze - confused! 448 ; CHECK: da analyze - none! 449 ; CHECK: da analyze - confused! 450 ; CHECK: da analyze - none! 451 452 for.cond1.preheader: ; preds = %entry, %for.inc10 453 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc10 ] 454 %i.03 = phi i64 [ 0, %entry ], [ %inc11, %for.inc10 ] 455 br label %for.body3 456 457 for.body3: ; preds = %for.cond1.preheader, %for.body3 458 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 459 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 460 %conv = trunc i64 %i.03 to i32 461 %add = add nsw i64 %j.02, 2 462 %arrayidx4 = getelementptr inbounds [100 x i32]* %A, i64 4, i64 %add 463 store i32 %conv, i32* %arrayidx4, align 4 464 %mul = mul nsw i64 %i.03, 5 465 %add5 = add nsw i64 %mul, %j.02 466 %mul6 = mul nsw i64 %i.03, -2 467 %add7 = add nsw i64 %mul6, 4 468 %arrayidx9 = getelementptr inbounds [100 x i32]* %A, i64 %add7, i64 %add5 469 %0 = load i32* %arrayidx9, align 4 470 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 471 store i32 %0, i32* %B.addr.11, align 4 472 %inc = add nsw i64 %j.02, 1 473 %exitcond = icmp ne i64 %inc, 100 474 br i1 %exitcond, label %for.body3, label %for.inc10 475 476 for.inc10: ; preds = %for.body3 477 %scevgep = getelementptr i32* %B.addr.04, i64 100 478 %inc11 = add nsw i64 %i.03, 1 479 %exitcond5 = icmp ne i64 %inc11, 100 480 br i1 %exitcond5, label %for.cond1.preheader, label %for.end12 481 482 for.end12: ; preds = %for.inc10 483 ret void 484 } 485 486 487 ;; for (long int i = 0; i < 100; i++) 488 ;; for (long int j = 0; j < 100; j++) { 489 ;; A[2*i + 4][5*i + j + 2] = i; 490 ;; *B++ = A[4][j]; 491 492 define void @prop9([100 x i32]* %A, i32* %B, i32 %n) nounwind uwtable ssp { 493 entry: 494 br label %for.cond1.preheader 495 496 ; CHECK: da analyze - none! 497 ; CHECK: da analyze - flow [p<= 2]! 498 ; CHECK: da analyze - confused! 499 ; CHECK: da analyze - consistent input [S 0]! 500 ; CHECK: da analyze - confused! 501 ; CHECK: da analyze - none! 502 503 for.cond1.preheader: ; preds = %entry, %for.inc10 504 %B.addr.04 = phi i32* [ %B, %entry ], [ %scevgep, %for.inc10 ] 505 %i.03 = phi i64 [ 0, %entry ], [ %inc11, %for.inc10 ] 506 br label %for.body3 507 508 for.body3: ; preds = %for.cond1.preheader, %for.body3 509 %j.02 = phi i64 [ 0, %for.cond1.preheader ], [ %inc, %for.body3 ] 510 %B.addr.11 = phi i32* [ %B.addr.04, %for.cond1.preheader ], [ %incdec.ptr, %for.body3 ] 511 %conv = trunc i64 %i.03 to i32 512 %mul = mul nsw i64 %i.03, 5 513 %add = add nsw i64 %mul, %j.02 514 %add4 = add nsw i64 %add, 2 515 %mul5 = shl nsw i64 %i.03, 1 516 %add6 = add nsw i64 %mul5, 4 517 %arrayidx7 = getelementptr inbounds [100 x i32]* %A, i64 %add6, i64 %add4 518 store i32 %conv, i32* %arrayidx7, align 4 519 %arrayidx9 = getelementptr inbounds [100 x i32]* %A, i64 4, i64 %j.02 520 %0 = load i32* %arrayidx9, align 4 521 %incdec.ptr = getelementptr inbounds i32* %B.addr.11, i64 1 522 store i32 %0, i32* %B.addr.11, align 4 523 %inc = add nsw i64 %j.02, 1 524 %exitcond = icmp ne i64 %inc, 100 525 br i1 %exitcond, label %for.body3, label %for.inc10 526 527 for.inc10: ; preds = %for.body3 528 %scevgep = getelementptr i32* %B.addr.04, i64 100 529 %inc11 = add nsw i64 %i.03, 1 530 %exitcond5 = icmp ne i64 %inc11, 100 531 br i1 %exitcond5, label %for.cond1.preheader, label %for.end12 532 533 for.end12: ; preds = %for.inc10 534 ret void 535 } 536