Home | History | Annotate | Download | only in DependenceAnalysis
      1 ; RUN: opt < %s -analyze -basicaa -da | FileCheck %s
      2 
      3 ; ModuleID = 'ExactSIV.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 unsigned i = 0; i < 10; i++) {
      9 ;;    A[i + 10] = i;
     10 ;;    *B++ = A[2*i + 1];
     11 
     12 define void @exact0(i32* %A, i32* %B) nounwind uwtable ssp {
     13 entry:
     14   br label %for.body
     15 
     16 ; CHECK: da analyze - none!
     17 ; CHECK: da analyze - flow [<=|<]!
     18 ; CHECK: da analyze - confused!
     19 ; CHECK: da analyze - none!
     20 ; CHECK: da analyze - confused!
     21 ; CHECK: da analyze - none!
     22 
     23 for.body:                                         ; preds = %entry, %for.body
     24   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
     25   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
     26   %conv = trunc i64 %i.02 to i32
     27   %add = add i64 %i.02, 10
     28   %arrayidx = getelementptr inbounds i32* %A, i64 %add
     29   store i32 %conv, i32* %arrayidx, align 4
     30   %mul = shl i64 %i.02, 1
     31   %add13 = or i64 %mul, 1
     32   %arrayidx2 = getelementptr inbounds i32* %A, i64 %add13
     33   %0 = load i32* %arrayidx2, align 4
     34   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
     35   store i32 %0, i32* %B.addr.01, align 4
     36   %inc = add i64 %i.02, 1
     37   %exitcond = icmp ne i64 %inc, 10
     38   br i1 %exitcond, label %for.body, label %for.end
     39 
     40 for.end:                                          ; preds = %for.body
     41   ret void
     42 }
     43 
     44 
     45 ;;  for (long unsigned i = 0; i < 10; i++) {
     46 ;;    A[4*i + 10] = i;
     47 ;;    *B++ = A[2*i + 1];
     48 
     49 define void @exact1(i32* %A, i32* %B) nounwind uwtable ssp {
     50 entry:
     51   br label %for.body
     52 
     53 ; CHECK: da analyze - none!
     54 ; CHECK: da analyze - none!
     55 ; CHECK: da analyze - confused!
     56 ; CHECK: da analyze - none!
     57 ; CHECK: da analyze - confused!
     58 ; CHECK: da analyze - none!
     59 
     60 for.body:                                         ; preds = %entry, %for.body
     61   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
     62   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
     63   %conv = trunc i64 %i.02 to i32
     64   %mul = shl i64 %i.02, 2
     65   %add = add i64 %mul, 10
     66   %arrayidx = getelementptr inbounds i32* %A, i64 %add
     67   store i32 %conv, i32* %arrayidx, align 4
     68   %mul1 = shl i64 %i.02, 1
     69   %add23 = or i64 %mul1, 1
     70   %arrayidx3 = getelementptr inbounds i32* %A, i64 %add23
     71   %0 = load i32* %arrayidx3, align 4
     72   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
     73   store i32 %0, i32* %B.addr.01, align 4
     74   %inc = add i64 %i.02, 1
     75   %exitcond = icmp ne i64 %inc, 10
     76   br i1 %exitcond, label %for.body, label %for.end
     77 
     78 for.end:                                          ; preds = %for.body
     79   ret void
     80 }
     81 
     82 
     83 ;;  for (long unsigned i = 0; i < 10; i++) {
     84 ;;    A[6*i] = i;
     85 ;;    *B++ = A[i + 60];
     86 
     87 define void @exact2(i32* %A, i32* %B) nounwind uwtable ssp {
     88 entry:
     89   br label %for.body
     90 
     91 ; CHECK: da analyze - none!
     92 ; CHECK: da analyze - none!
     93 ; CHECK: da analyze - confused!
     94 ; CHECK: da analyze - none!
     95 ; CHECK: da analyze - confused!
     96 ; CHECK: da analyze - none!
     97 
     98 for.body:                                         ; preds = %entry, %for.body
     99   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    100   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    101   %conv = trunc i64 %i.02 to i32
    102   %mul = mul i64 %i.02, 6
    103   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    104   store i32 %conv, i32* %arrayidx, align 4
    105   %add = add i64 %i.02, 60
    106   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    107   %0 = load i32* %arrayidx1, align 4
    108   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    109   store i32 %0, i32* %B.addr.01, align 4
    110   %inc = add i64 %i.02, 1
    111   %exitcond = icmp ne i64 %inc, 10
    112   br i1 %exitcond, label %for.body, label %for.end
    113 
    114 for.end:                                          ; preds = %for.body
    115   ret void
    116 }
    117 
    118 
    119 ;;  for (long unsigned i = 0; i <= 10; i++) {
    120 ;;    A[6*i] = i;
    121 ;;    *B++ = A[i + 60];
    122 
    123 define void @exact3(i32* %A, i32* %B) nounwind uwtable ssp {
    124 entry:
    125   br label %for.body
    126 
    127 ; CHECK: da analyze - none!
    128 ; CHECK: da analyze - flow [>]!
    129 ; CHECK: da analyze - confused!
    130 ; CHECK: da analyze - none!
    131 ; CHECK: da analyze - confused!
    132 ; CHECK: da analyze - none!
    133 
    134 for.body:                                         ; preds = %entry, %for.body
    135   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    136   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    137   %conv = trunc i64 %i.02 to i32
    138   %mul = mul i64 %i.02, 6
    139   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    140   store i32 %conv, i32* %arrayidx, align 4
    141   %add = add i64 %i.02, 60
    142   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    143   %0 = load i32* %arrayidx1, align 4
    144   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    145   store i32 %0, i32* %B.addr.01, align 4
    146   %inc = add i64 %i.02, 1
    147   %exitcond = icmp ne i64 %inc, 11
    148   br i1 %exitcond, label %for.body, label %for.end
    149 
    150 for.end:                                          ; preds = %for.body
    151   ret void
    152 }
    153 
    154 
    155 ;;  for (long unsigned i = 0; i < 12; i++) {
    156 ;;    A[6*i] = i;
    157 ;;    *B++ = A[i + 60];
    158 
    159 define void @exact4(i32* %A, i32* %B) nounwind uwtable ssp {
    160 entry:
    161   br label %for.body
    162 
    163 ; CHECK: da analyze - none!
    164 ; CHECK: da analyze - flow [>]!
    165 ; CHECK: da analyze - confused!
    166 ; CHECK: da analyze - none!
    167 ; CHECK: da analyze - confused!
    168 ; CHECK: da analyze - none!
    169 
    170 for.body:                                         ; preds = %entry, %for.body
    171   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    172   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    173   %conv = trunc i64 %i.02 to i32
    174   %mul = mul i64 %i.02, 6
    175   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    176   store i32 %conv, i32* %arrayidx, align 4
    177   %add = add i64 %i.02, 60
    178   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    179   %0 = load i32* %arrayidx1, align 4
    180   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    181   store i32 %0, i32* %B.addr.01, align 4
    182   %inc = add i64 %i.02, 1
    183   %exitcond = icmp ne i64 %inc, 12
    184   br i1 %exitcond, label %for.body, label %for.end
    185 
    186 for.end:                                          ; preds = %for.body
    187   ret void
    188 }
    189 
    190 
    191 ;;  for (long unsigned i = 0; i <= 12; i++) {
    192 ;;    A[6*i] = i;
    193 ;;    *B++ = A[i + 60];
    194 
    195 define void @exact5(i32* %A, i32* %B) nounwind uwtable ssp {
    196 entry:
    197   br label %for.body
    198 
    199 ; CHECK: da analyze - none!
    200 ; CHECK: da analyze - flow [=>|<]!
    201 ; CHECK: da analyze - confused!
    202 ; CHECK: da analyze - none!
    203 ; CHECK: da analyze - confused!
    204 ; CHECK: da analyze - none!
    205 
    206 for.body:                                         ; preds = %entry, %for.body
    207   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    208   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    209   %conv = trunc i64 %i.02 to i32
    210   %mul = mul i64 %i.02, 6
    211   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    212   store i32 %conv, i32* %arrayidx, align 4
    213   %add = add i64 %i.02, 60
    214   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    215   %0 = load i32* %arrayidx1, align 4
    216   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    217   store i32 %0, i32* %B.addr.01, align 4
    218   %inc = add i64 %i.02, 1
    219   %exitcond = icmp ne i64 %inc, 13
    220   br i1 %exitcond, label %for.body, label %for.end
    221 
    222 for.end:                                          ; preds = %for.body
    223   ret void
    224 }
    225 
    226 
    227 ;;  for (long unsigned i = 0; i < 18; i++) {
    228 ;;    A[6*i] = i;
    229 ;;    *B++ = A[i + 60];
    230 
    231 define void @exact6(i32* %A, i32* %B) nounwind uwtable ssp {
    232 entry:
    233   br label %for.body
    234 
    235 ; CHECK: da analyze - none!
    236 ; CHECK: da analyze - flow [=>|<]!
    237 ; CHECK: da analyze - confused!
    238 ; CHECK: da analyze - none!
    239 ; CHECK: da analyze - confused!
    240 ; CHECK: da analyze - none!
    241 
    242 for.body:                                         ; preds = %entry, %for.body
    243   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    244   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    245   %conv = trunc i64 %i.02 to i32
    246   %mul = mul i64 %i.02, 6
    247   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    248   store i32 %conv, i32* %arrayidx, align 4
    249   %add = add i64 %i.02, 60
    250   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    251   %0 = load i32* %arrayidx1, align 4
    252   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    253   store i32 %0, i32* %B.addr.01, align 4
    254   %inc = add i64 %i.02, 1
    255   %exitcond = icmp ne i64 %inc, 18
    256   br i1 %exitcond, label %for.body, label %for.end
    257 
    258 for.end:                                          ; preds = %for.body
    259   ret void
    260 }
    261 
    262 
    263 ;;  for (long unsigned i = 0; i <= 18; i++) {
    264 ;;    A[6*i] = i;
    265 ;;    *B++ = A[i + 60];
    266 
    267 define void @exact7(i32* %A, i32* %B) nounwind uwtable ssp {
    268 entry:
    269   br label %for.body
    270 
    271 ; CHECK: da analyze - none!
    272 ; CHECK: da analyze - flow [*|<]!
    273 ; CHECK: da analyze - confused!
    274 ; CHECK: da analyze - none!
    275 ; CHECK: da analyze - confused!
    276 ; CHECK: da analyze - none!
    277 
    278 for.body:                                         ; preds = %entry, %for.body
    279   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    280   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    281   %conv = trunc i64 %i.02 to i32
    282   %mul = mul i64 %i.02, 6
    283   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    284   store i32 %conv, i32* %arrayidx, align 4
    285   %add = add i64 %i.02, 60
    286   %arrayidx1 = getelementptr inbounds i32* %A, i64 %add
    287   %0 = load i32* %arrayidx1, align 4
    288   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    289   store i32 %0, i32* %B.addr.01, align 4
    290   %inc = add i64 %i.02, 1
    291   %exitcond = icmp ne i64 %inc, 19
    292   br i1 %exitcond, label %for.body, label %for.end
    293 
    294 for.end:                                          ; preds = %for.body
    295   ret void
    296 }
    297 
    298 
    299 ;;  for (long unsigned i = 0; i < 10; i++) {
    300 ;;    A[-6*i] = i;
    301 ;;    *B++ = A[-i - 60];
    302 
    303 define void @exact8(i32* %A, i32* %B) nounwind uwtable ssp {
    304 entry:
    305   br label %for.body
    306 
    307 ; CHECK: da analyze - none!
    308 ; CHECK: da analyze - none!
    309 ; CHECK: da analyze - confused!
    310 ; CHECK: da analyze - none!
    311 ; CHECK: da analyze - confused!
    312 ; CHECK: da analyze - none!
    313 
    314 for.body:                                         ; preds = %entry, %for.body
    315   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    316   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    317   %conv = trunc i64 %i.02 to i32
    318   %mul = mul i64 %i.02, -6
    319   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    320   store i32 %conv, i32* %arrayidx, align 4
    321   %sub1 = sub i64 -60, %i.02
    322   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    323   %0 = load i32* %arrayidx2, align 4
    324   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    325   store i32 %0, i32* %B.addr.01, align 4
    326   %inc = add i64 %i.02, 1
    327   %exitcond = icmp ne i64 %inc, 10
    328   br i1 %exitcond, label %for.body, label %for.end
    329 
    330 for.end:                                          ; preds = %for.body
    331   ret void
    332 }
    333 
    334 
    335 ;;  for (long unsigned i = 0; i <= 10; i++) {
    336 ;;    A[-6*i] = i;
    337 ;;    *B++ = A[-i - 60];
    338 
    339 define void @exact9(i32* %A, i32* %B) nounwind uwtable ssp {
    340 entry:
    341   br label %for.body
    342 
    343 ; CHECK: da analyze - none!
    344 ; CHECK: da analyze - flow [>]!
    345 ; CHECK: da analyze - confused!
    346 ; CHECK: da analyze - none!
    347 ; CHECK: da analyze - confused!
    348 ; CHECK: da analyze - none!
    349 
    350 for.body:                                         ; preds = %entry, %for.body
    351   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    352   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    353   %conv = trunc i64 %i.02 to i32
    354   %mul = mul i64 %i.02, -6
    355   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    356   store i32 %conv, i32* %arrayidx, align 4
    357   %sub1 = sub i64 -60, %i.02
    358   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    359   %0 = load i32* %arrayidx2, align 4
    360   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    361   store i32 %0, i32* %B.addr.01, align 4
    362   %inc = add i64 %i.02, 1
    363   %exitcond = icmp ne i64 %inc, 11
    364   br i1 %exitcond, label %for.body, label %for.end
    365 
    366 for.end:                                          ; preds = %for.body
    367   ret void
    368 }
    369 
    370 
    371 ;;  for (long unsigned i = 0; i < 12; i++) {
    372 ;;    A[-6*i] = i;
    373 ;;    *B++ = A[-i - 60];
    374 
    375 define void @exact10(i32* %A, i32* %B) nounwind uwtable ssp {
    376 entry:
    377   br label %for.body
    378 
    379 ; CHECK: da analyze - none!
    380 ; CHECK: da analyze - flow [>]!
    381 ; CHECK: da analyze - confused!
    382 ; CHECK: da analyze - none!
    383 ; CHECK: da analyze - confused!
    384 ; CHECK: da analyze - none!
    385 
    386 for.body:                                         ; preds = %entry, %for.body
    387   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    388   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    389   %conv = trunc i64 %i.02 to i32
    390   %mul = mul i64 %i.02, -6
    391   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    392   store i32 %conv, i32* %arrayidx, align 4
    393   %sub1 = sub i64 -60, %i.02
    394   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    395   %0 = load i32* %arrayidx2, align 4
    396   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    397   store i32 %0, i32* %B.addr.01, align 4
    398   %inc = add i64 %i.02, 1
    399   %exitcond = icmp ne i64 %inc, 12
    400   br i1 %exitcond, label %for.body, label %for.end
    401 
    402 for.end:                                          ; preds = %for.body
    403   ret void
    404 }
    405 
    406 
    407 ;;  for (long unsigned i = 0; i <= 12; i++) {
    408 ;;    A[-6*i] = i;
    409 ;;    *B++ = A[-i - 60];
    410 
    411 define void @exact11(i32* %A, i32* %B) nounwind uwtable ssp {
    412 entry:
    413   br label %for.body
    414 
    415 ; CHECK: da analyze - none!
    416 ; CHECK: da analyze - flow [=>|<]!
    417 ; CHECK: da analyze - confused!
    418 ; CHECK: da analyze - none!
    419 ; CHECK: da analyze - confused!
    420 ; CHECK: da analyze - none!
    421 
    422 for.body:                                         ; preds = %entry, %for.body
    423   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    424   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    425   %conv = trunc i64 %i.02 to i32
    426   %mul = mul i64 %i.02, -6
    427   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    428   store i32 %conv, i32* %arrayidx, align 4
    429   %sub1 = sub i64 -60, %i.02
    430   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    431   %0 = load i32* %arrayidx2, align 4
    432   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    433   store i32 %0, i32* %B.addr.01, align 4
    434   %inc = add i64 %i.02, 1
    435   %exitcond = icmp ne i64 %inc, 13
    436   br i1 %exitcond, label %for.body, label %for.end
    437 
    438 for.end:                                          ; preds = %for.body
    439   ret void
    440 }
    441 
    442 
    443 ;;  for (long unsigned i = 0; i < 18; i++) {
    444 ;;    A[-6*i] = i;
    445 ;;    *B++ = A[-i - 60];
    446 
    447 define void @exact12(i32* %A, i32* %B) nounwind uwtable ssp {
    448 entry:
    449   br label %for.body
    450 
    451 ; CHECK: da analyze - none!
    452 ; CHECK: da analyze - flow [=>|<]!
    453 ; CHECK: da analyze - confused!
    454 ; CHECK: da analyze - none!
    455 ; CHECK: da analyze - confused!
    456 ; CHECK: da analyze - none!
    457 
    458 for.body:                                         ; preds = %entry, %for.body
    459   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    460   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    461   %conv = trunc i64 %i.02 to i32
    462   %mul = mul i64 %i.02, -6
    463   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    464   store i32 %conv, i32* %arrayidx, align 4
    465   %sub1 = sub i64 -60, %i.02
    466   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    467   %0 = load i32* %arrayidx2, align 4
    468   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    469   store i32 %0, i32* %B.addr.01, align 4
    470   %inc = add i64 %i.02, 1
    471   %exitcond = icmp ne i64 %inc, 18
    472   br i1 %exitcond, label %for.body, label %for.end
    473 
    474 for.end:                                          ; preds = %for.body
    475   ret void
    476 }
    477 
    478 
    479 ;;  for (long unsigned i = 0; i <= 18; i++) {
    480 ;;    A[-6*i] = i;
    481 ;;    *B++ = A[-i - 60];
    482 
    483 define void @exact13(i32* %A, i32* %B) nounwind uwtable ssp {
    484 entry:
    485   br label %for.body
    486 
    487 ; CHECK: da analyze - none!
    488 ; CHECK: da analyze - flow [*|<]!
    489 ; CHECK: da analyze - confused!
    490 ; CHECK: da analyze - none!
    491 ; CHECK: da analyze - confused!
    492 ; CHECK: da analyze - none!
    493 
    494 for.body:                                         ; preds = %entry, %for.body
    495   %i.02 = phi i64 [ 0, %entry ], [ %inc, %for.body ]
    496   %B.addr.01 = phi i32* [ %B, %entry ], [ %incdec.ptr, %for.body ]
    497   %conv = trunc i64 %i.02 to i32
    498   %mul = mul i64 %i.02, -6
    499   %arrayidx = getelementptr inbounds i32* %A, i64 %mul
    500   store i32 %conv, i32* %arrayidx, align 4
    501   %sub1 = sub i64 -60, %i.02
    502   %arrayidx2 = getelementptr inbounds i32* %A, i64 %sub1
    503   %0 = load i32* %arrayidx2, align 4
    504   %incdec.ptr = getelementptr inbounds i32* %B.addr.01, i64 1
    505   store i32 %0, i32* %B.addr.01, align 4
    506   %inc = add i64 %i.02, 1
    507   %exitcond = icmp ne i64 %inc, 19
    508   br i1 %exitcond, label %for.body, label %for.end
    509 
    510 for.end:                                          ; preds = %for.body
    511   ret void
    512 }
    513