Home | History | Annotate | Download | only in CorrelatedValuePropagation
      1 ; RUN: opt < %s -correlated-propagation -S | FileCheck %s
      2 ; PR2581
      3 
      4 ; CHECK-LABEL: @test1(
      5 define i32 @test1(i1 %C) nounwind  {
      6         br i1 %C, label %exit, label %body
      7 
      8 body:           ; preds = %0
      9 ; CHECK-NOT: select
     10         %A = select i1 %C, i32 10, i32 11               ; <i32> [#uses=1]
     11 ; CHECK: ret i32 11
     12         ret i32 %A
     13 
     14 exit:           ; preds = %0
     15 ; CHECK: ret i32 10
     16         ret i32 10
     17 }
     18 
     19 ; PR4420
     20 declare i1 @ext()
     21 ; CHECK-LABEL: @test2(
     22 define i1 @test2() {
     23 entry:
     24         %cond = tail call i1 @ext()             ; <i1> [#uses=2]
     25         br i1 %cond, label %bb1, label %bb2
     26 
     27 bb1:            ; preds = %entry
     28         %cond2 = tail call i1 @ext()            ; <i1> [#uses=1]
     29         br i1 %cond2, label %bb3, label %bb2
     30 
     31 bb2:            ; preds = %bb1, %entry
     32 ; CHECK-NOT: phi i1
     33         %cond_merge = phi i1 [ %cond, %entry ], [ false, %bb1 ]         ; <i1> [#uses=1]
     34 ; CHECK: ret i1 false
     35         ret i1 %cond_merge
     36 
     37 bb3:            ; preds = %bb1
     38         %res = tail call i1 @ext()              ; <i1> [#uses=1]
     39 ; CHECK: ret i1 %res
     40         ret i1 %res
     41 }
     42 
     43 ; PR4855
     44 @gv = internal constant i8 7
     45 ; CHECK-LABEL: @test3(
     46 define i8 @test3(i8* %a) nounwind {
     47 entry:
     48         %cond = icmp eq i8* %a, @gv
     49         br i1 %cond, label %bb2, label %bb
     50 
     51 bb:             ; preds = %entry
     52         ret i8 0
     53 
     54 bb2:            ; preds = %entry
     55 ; CHECK: %should_be_const = load i8, i8* @gv
     56         %should_be_const = load i8, i8* %a
     57         ret i8 %should_be_const
     58 }
     59 
     60 ; PR1757
     61 ; CHECK-LABEL: @test4(
     62 define i32 @test4(i32) {
     63 EntryBlock:
     64 ; CHECK: icmp sgt i32 %0, 2  
     65   %.demorgan = icmp sgt i32 %0, 2    
     66   br i1 %.demorgan, label %GreaterThanTwo, label %LessThanOrEqualToTwo
     67 
     68 GreaterThanTwo:
     69 ; CHECK-NOT: icmp eq i32 %0, 2
     70   icmp eq i32 %0, 2
     71 ; CHECK: br i1 false
     72   br i1 %1, label %Impossible, label %NotTwoAndGreaterThanTwo
     73 
     74 NotTwoAndGreaterThanTwo:
     75   ret i32 2
     76 
     77 Impossible:
     78   ret i32 1
     79 
     80 LessThanOrEqualToTwo:
     81   ret i32 0
     82 }
     83 
     84 declare i32* @f(i32*)
     85 define void @test5(i32* %x, i32* %y) {
     86 ; CHECK-LABEL: @test5(
     87 entry:
     88   %pre = icmp eq i32* %x, null
     89   br i1 %pre, label %return, label %loop
     90 
     91 loop:
     92   %phi = phi i32* [ %sel, %loop ], [ %x, %entry ]
     93 ; CHECK: %phi = phi i32* [ %f, %loop ], [ %x, %entry ]
     94   %f = tail call i32* @f(i32* %phi)
     95   %cmp1 = icmp ne i32* %f, %y
     96   %sel = select i1 %cmp1, i32* %f, i32* null
     97   %cmp2 = icmp eq i32* %sel, null
     98   br i1 %cmp2, label %return, label %loop
     99 
    100 return:
    101   ret void
    102 }
    103 
    104 define i32 @switch1(i32 %s) {
    105 ; CHECK-LABEL: @switch1(
    106 entry:
    107   %cmp = icmp slt i32 %s, 0
    108   br i1 %cmp, label %negative, label %out
    109 
    110 negative:
    111   switch i32 %s, label %out [
    112 ; CHECK: switch i32 %s, label %out
    113     i32 0, label %out
    114 ; CHECK-NOT: i32 0
    115     i32 1, label %out
    116 ; CHECK-NOT: i32 1
    117     i32 -1, label %next
    118 ; CHECK: i32 -1, label %next
    119     i32 -2, label %next
    120 ; CHECK: i32 -2, label %next
    121     i32 2, label %out
    122 ; CHECK-NOT: i32 2
    123     i32 3, label %out
    124 ; CHECK-NOT: i32 3
    125   ]
    126 
    127 out:
    128   %p = phi i32 [ 1, %entry ], [ -1, %negative ], [ -1, %negative ], [ -1, %negative ], [ -1, %negative ], [ -1, %negative ]
    129   ret i32 %p
    130 
    131 next:
    132   %q = phi i32 [ 0, %negative ], [ 0, %negative ]
    133   ret i32 %q
    134 }
    135 
    136 define i32 @switch2(i32 %s) {
    137 ; CHECK-LABEL: @switch2(
    138 entry:
    139   %cmp = icmp sgt i32 %s, 0
    140   br i1 %cmp, label %positive, label %out
    141 
    142 positive:
    143   switch i32 %s, label %out [
    144     i32 0, label %out
    145     i32 -1, label %next
    146     i32 -2, label %next
    147   ]
    148 ; CHECK: br label %out
    149 
    150 out:
    151   %p = phi i32 [ -1, %entry ], [ 1, %positive ], [ 1, %positive ]
    152   ret i32 %p
    153 
    154 next:
    155   %q = phi i32 [ 0, %positive ], [ 0, %positive ]
    156   ret i32 %q
    157 }
    158 
    159 define i32 @switch3(i32 %s) {
    160 ; CHECK-LABEL: @switch3(
    161 entry:
    162   %cmp = icmp sgt i32 %s, 0
    163   br i1 %cmp, label %positive, label %out
    164 
    165 positive:
    166   switch i32 %s, label %out [
    167     i32 -1, label %out
    168     i32 -2, label %next
    169     i32 -3, label %next
    170   ]
    171 ; CHECK: br label %out
    172 
    173 out:
    174   %p = phi i32 [ -1, %entry ], [ 1, %positive ], [ 1, %positive ]
    175   ret i32 %p
    176 
    177 next:
    178   %q = phi i32 [ 0, %positive ], [ 0, %positive ]
    179   ret i32 %q
    180 }
    181 
    182 define void @switch4(i32 %s) {
    183 ; CHECK-LABEL: @switch4(
    184 entry:
    185   %cmp = icmp eq i32 %s, 0
    186   br i1 %cmp, label %zero, label %out
    187 
    188 zero:
    189   switch i32 %s, label %out [
    190     i32 0, label %next
    191     i32 1, label %out
    192     i32 -1, label %out
    193   ]
    194 ; CHECK: br label %next
    195 
    196 out:
    197   ret void
    198 
    199 next:
    200   ret void
    201 }
    202