Taints the non-acquire RMW's store address with the load part
[oota-llvm.git] / test / Transforms / JumpThreading / thread-loads.ll
1 ; RUN: opt < %s -jump-threading -S | FileCheck %s
2
3 target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
4 target triple = "i386-apple-darwin7"
5
6 ; Test that we can thread through the block with the partially redundant load (%2).
7 ; rdar://6402033
8 define i32 @test1(i32* %P) nounwind {
9 ; CHECK-LABEL: @test1(
10 entry:
11         %0 = tail call i32 (...) @f1() nounwind         ; <i32> [#uses=1]
12         %1 = icmp eq i32 %0, 0          ; <i1> [#uses=1]
13         br i1 %1, label %bb1, label %bb
14
15 bb:             ; preds = %entry
16 ; CHECK: bb1.thread:
17 ; CHECK: store
18 ; CHECK: br label %bb3
19         store i32 42, i32* %P, align 4
20         br label %bb1
21
22 bb1:            ; preds = %entry, %bb
23         %res.0 = phi i32 [ 1, %bb ], [ 0, %entry ]              ; <i32> [#uses=2]
24         %2 = load i32, i32* %P, align 4         ; <i32> [#uses=1]
25         %3 = icmp sgt i32 %2, 36                ; <i1> [#uses=1]
26         br i1 %3, label %bb3, label %bb2
27
28 bb2:            ; preds = %bb1
29         %4 = tail call i32 (...) @f2() nounwind         ; <i32> [#uses=0]
30         ret i32 %res.0
31
32 bb3:            ; preds = %bb1
33 ; CHECK: bb3:
34 ; CHECK: %res.01 = phi i32 [ 1, %bb1.thread ], [ 0, %bb1 ]
35 ; CHECK: ret i32 %res.01
36         ret i32 %res.0
37 }
38
39 declare i32 @f1(...)
40
41 declare i32 @f2(...)
42
43
44 ;; Check that we preserve TBAA information.
45 ; rdar://11039258
46
47 define i32 @test2(i32* %P) nounwind {
48 ; CHECK-LABEL: @test2(
49 entry:
50         %0 = tail call i32 (...) @f1() nounwind         ; <i32> [#uses=1]
51         %1 = icmp eq i32 %0, 0          ; <i1> [#uses=1]
52         br i1 %1, label %bb1, label %bb
53
54 bb:             ; preds = %entry
55 ; CHECK: bb1.thread:
56 ; CHECK: store{{.*}}, !tbaa !0
57 ; CHECK: br label %bb3
58         store i32 42, i32* %P, align 4, !tbaa !0
59         br label %bb1
60
61 bb1:            ; preds = %entry, %bb
62         %res.0 = phi i32 [ 1, %bb ], [ 0, %entry ]
63         %2 = load i32, i32* %P, align 4, !tbaa !0
64         %3 = icmp sgt i32 %2, 36
65         br i1 %3, label %bb3, label %bb2
66
67 bb2:            ; preds = %bb1
68         %4 = tail call i32 (...) @f2() nounwind
69         ret i32 %res.0
70
71 bb3:            ; preds = %bb1
72 ; CHECK: bb3:
73 ; CHECK: %res.01 = phi i32 [ 1, %bb1.thread ], [ 0, %bb1 ]
74 ; CHECK: ret i32 %res.01
75         ret i32 %res.0
76 }
77
78 define i32 @test3(i8** %x, i1 %f) {
79 ; Correctly thread loads of different (but compatible) types, placing bitcasts
80 ; as necessary in the predecessors. This is especially tricky because the same
81 ; predecessor ends up with two entries in the PHI node and they must share
82 ; a single cast.
83 ; CHECK-LABEL: @test3(
84 entry:
85   %0 = bitcast i8** %x to i32**
86   %1 = load i32*, i32** %0, align 8
87   br i1 %f, label %if.end57, label %if.then56
88 ; CHECK: %[[LOAD:.*]] = load i32*, i32**
89 ; CHECK: %[[CAST:.*]] = bitcast i32* %[[LOAD]] to i8*
90
91 if.then56:
92   br label %if.end57
93
94 if.end57:
95   %2 = load i8*, i8** %x, align 8
96   %tobool59 = icmp eq i8* %2, null
97   br i1 %tobool59, label %return, label %if.then60
98 ; CHECK: %[[PHI:.*]] = phi i8* [ %[[CAST]], %[[PRED:[^ ]+]] ], [ %[[CAST]], %[[PRED]] ]
99 ; CHECK-NEXT: %[[CMP:.*]] = icmp eq i8* %[[PHI]], null
100 ; CHECK-NEXT: br i1 %[[CMP]]
101
102 if.then60:
103   ret i32 42
104
105 return:
106   ret i32 13
107 }
108
109 !0 = !{!3, !3, i64 0}
110 !1 = !{!"omnipotent char", !2}
111 !2 = !{!"Simple C/C++ TBAA", null}
112 !3 = !{!"int", !1}