Home | History | Annotate | Download | only in ScalarRepl
      1 ; RUN: opt -scalarrepl -S < %s | FileCheck %s
      2 ; Test promotion of allocas that have phis and select users.
      3 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"
      4 target triple = "x86_64-apple-darwin10.2"
      5 
      6 %struct.X = type { i32 }
      7 %PairTy = type {i32, i32}
      8 
      9 ; CHECK-LABEL: @test1(
     10 ; CHECK: %a.0 = alloca i32
     11 ; CHECK: %b.0 = alloca i32
     12 define i32 @test1(i32 %x) nounwind readnone ssp {
     13 entry:
     14   %a = alloca %struct.X, align 8                  ; <%struct.X*> [#uses=2]
     15   %b = alloca %struct.X, align 8                  ; <%struct.X*> [#uses=2]
     16   %0 = getelementptr inbounds %struct.X* %a, i64 0, i32 0 ; <i32*> [#uses=1]
     17   store i32 1, i32* %0, align 8
     18   %1 = getelementptr inbounds %struct.X* %b, i64 0, i32 0 ; <i32*> [#uses=1]
     19   store i32 2, i32* %1, align 8
     20   %2 = icmp eq i32 %x, 0                          ; <i1> [#uses=1]
     21   %p.0 = select i1 %2, %struct.X* %b, %struct.X* %a ; <%struct.X*> [#uses=1]
     22   %3 = getelementptr inbounds %struct.X* %p.0, i64 0, i32 0 ; <i32*> [#uses=1]
     23   %4 = load i32* %3, align 8                      ; <i32> [#uses=1]
     24   ret i32 %4
     25 }
     26 
     27 ; CHECK-LABEL: @test2(
     28 ; CHECK: %X.ld = phi i32 [ 1, %entry ], [ 2, %T ]
     29 ; CHECK-NEXT: ret i32 %X.ld
     30 define i32 @test2(i1 %c) {
     31 entry:
     32   %A = alloca {i32, i32}
     33   %B = getelementptr {i32, i32}* %A, i32 0, i32 0
     34   store i32 1, i32* %B
     35   br i1 %c, label %T, label %F
     36 T:
     37   %C = getelementptr {i32, i32}* %A, i32 0, i32 1
     38   store i32 2, i32* %C
     39   br label %F
     40 F:
     41   %X = phi i32* [%B, %entry], [%C, %T]
     42   %Q = load i32* %X
     43   ret i32 %Q
     44 }
     45 
     46 ; CHECK-LABEL: @test3(
     47 ; CHECK-NEXT: %Q = select i1 %c, i32 1, i32 2
     48 ; CHECK-NEXT: ret i32 %Q
     49 ; rdar://8904039
     50 define i32 @test3(i1 %c) {
     51   %A = alloca {i32, i32}
     52   %B = getelementptr {i32, i32}* %A, i32 0, i32 0
     53   store i32 1, i32* %B
     54   %C = getelementptr {i32, i32}* %A, i32 0, i32 1
     55   store i32 2, i32* %C
     56   
     57   %X = select i1 %c, i32* %B, i32* %C
     58   %Q = load i32* %X
     59   ret i32 %Q
     60 }
     61 
     62 ;; We can't scalarize this, a use of the select is not an element access.
     63 define i64 @test4(i1 %c) {
     64 entry:
     65   %A = alloca %PairTy
     66   ; CHECK-LABEL: @test4(
     67   ; CHECK: %A = alloca %PairTy
     68   %B = getelementptr %PairTy* %A, i32 0, i32 0
     69   store i32 1, i32* %B
     70   %C = getelementptr %PairTy* %A, i32 0, i32 1
     71   store i32 2, i32* %B
     72   
     73   %X = select i1 %c, i32* %B, i32* %C
     74   %Y = bitcast i32* %X to i64*
     75   %Q = load i64* %Y
     76   ret i64 %Q
     77 }
     78 
     79 
     80 ;;
     81 ;; Tests for promoting allocas used by selects.
     82 ;; rdar://7339113
     83 ;;
     84 
     85 define i32 @test5(i32 *%P) nounwind readnone ssp {
     86 entry:
     87   %b = alloca i32, align 8 
     88   store i32 2, i32* %b, align 8
     89   
     90   ;; Select on constant condition should be folded.
     91   %p.0 = select i1 false, i32* %b, i32* %P
     92   store i32 123, i32* %p.0
     93   
     94   %r = load i32* %b, align 8
     95   ret i32 %r
     96   
     97 ; CHECK-LABEL: @test5(
     98 ; CHECK: store i32 123, i32* %P
     99 ; CHECK: ret i32 2
    100 }
    101 
    102 define i32 @test6(i32 %x, i1 %c) nounwind readnone ssp {
    103   %a = alloca i32, align 8
    104   %b = alloca i32, align 8
    105   store i32 1, i32* %a, align 8
    106   store i32 2, i32* %b, align 8
    107   %p.0 = select i1 %c, i32* %b, i32* %a
    108   %r = load i32* %p.0, align 8
    109   ret i32 %r
    110 ; CHECK-LABEL: @test6(
    111 ; CHECK-NEXT: %r = select i1 %c, i32 2, i32 1
    112 ; CHECK-NEXT: ret i32 %r
    113 }
    114 
    115 ; Verify that the loads happen where the loads are, not where the select is.
    116 define i32 @test7(i32 %x, i1 %c) nounwind readnone ssp {
    117   %a = alloca i32, align 8
    118   %b = alloca i32, align 8
    119   store i32 1, i32* %a
    120   store i32 2, i32* %b
    121   %p.0 = select i1 %c, i32* %b, i32* %a
    122   
    123   store i32 0, i32* %a
    124   
    125   %r = load i32* %p.0, align 8
    126   ret i32 %r
    127 ; CHECK-LABEL: @test7(
    128 ; CHECK-NOT: alloca i32
    129 ; CHECK: %r = select i1 %c, i32 2, i32 0
    130 ; CHECK: ret i32 %r
    131 }
    132 
    133 ;; Promote allocs that are PHI'd together by moving the loads.
    134 define i32 @test8(i32 %x) nounwind readnone ssp {
    135 ; CHECK-LABEL: @test8(
    136 ; CHECK-NOT: load i32
    137 ; CHECK-NOT: store i32
    138 ; CHECK: %p.0.ld = phi i32 [ 2, %entry ], [ 1, %T ]
    139 ; CHECK-NEXT: ret i32 %p.0.ld
    140 entry:
    141   %a = alloca i32, align 8
    142   %b = alloca i32, align 8
    143   store i32 1, i32* %a, align 8
    144   store i32 2, i32* %b, align 8
    145   %c = icmp eq i32 %x, 0 
    146   br i1 %c, label %T, label %Cont
    147 T:
    148   br label %Cont
    149 Cont:
    150   %p.0 = phi i32* [%b, %entry],[%a, %T]
    151   %r = load i32* %p.0, align 8
    152   ret i32 %r
    153 }
    154