77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
1 ; RUN: opt < %s -instcombine -S | FileCheck %s
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
2 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
3 target triple = "x86_64-unknown-linux-gnu"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
4
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
5 define i32 @foo1(i32* %a) #0 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
6 entry:
|
95
|
7 %0 = load i32, i32* %a, align 4
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
8
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
9 ; Check that the alignment has been upgraded and that the assume has not
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
10 ; been removed:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
11 ; CHECK-LABEL: @foo1
|
95
|
12 ; CHECK-DAG: load i32, i32* %a, align 32
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
13 ; CHECK-DAG: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
14 ; CHECK: ret i32
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
15
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
16 %ptrint = ptrtoint i32* %a to i64
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
17 %maskedptr = and i64 %ptrint, 31
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
18 %maskcond = icmp eq i64 %maskedptr, 0
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
19 tail call void @llvm.assume(i1 %maskcond)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
20
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
21 ret i32 %0
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
22 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
23
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
24 define i32 @foo2(i32* %a) #0 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
25 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
26 ; Same check as in @foo1, but make sure it works if the assume is first too.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
27 ; CHECK-LABEL: @foo2
|
95
|
28 ; CHECK-DAG: load i32, i32* %a, align 32
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
29 ; CHECK-DAG: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
30 ; CHECK: ret i32
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
31
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
32 %ptrint = ptrtoint i32* %a to i64
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
33 %maskedptr = and i64 %ptrint, 31
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
34 %maskcond = icmp eq i64 %maskedptr, 0
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
35 tail call void @llvm.assume(i1 %maskcond)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
36
|
95
|
37 %0 = load i32, i32* %a, align 4
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
38 ret i32 %0
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
39 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
40
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
41 declare void @llvm.assume(i1) #1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
42
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
43 define i32 @simple(i32 %a) #1 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
44 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
45
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
46 ; CHECK-LABEL: @simple
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
47 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
48 ; CHECK: ret i32 4
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
49
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
50 %cmp = icmp eq i32 %a, 4
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
51 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
52 ret i32 %a
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
53 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
54
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
55 define i32 @can1(i1 %a, i1 %b, i1 %c) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
56 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
57 %and1 = and i1 %a, %b
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
58 %and = and i1 %and1, %c
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
59 tail call void @llvm.assume(i1 %and)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
60
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
61 ; CHECK-LABEL: @can1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
62 ; CHECK: call void @llvm.assume(i1 %a)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
63 ; CHECK: call void @llvm.assume(i1 %b)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
64 ; CHECK: call void @llvm.assume(i1 %c)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
65 ; CHECK: ret i32
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
66
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
67 ret i32 5
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
68 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
69
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
70 define i32 @can2(i1 %a, i1 %b, i1 %c) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
71 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
72 %v = or i1 %a, %b
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
73 %w = xor i1 %v, 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
74 tail call void @llvm.assume(i1 %w)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
75
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
76 ; CHECK-LABEL: @can2
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
77 ; CHECK: %[[V1:[^ ]+]] = xor i1 %a, true
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
78 ; CHECK: call void @llvm.assume(i1 %[[V1]])
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
79 ; CHECK: %[[V2:[^ ]+]] = xor i1 %b, true
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
80 ; CHECK: call void @llvm.assume(i1 %[[V2]])
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
81 ; CHECK: ret i32
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
82
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
83 ret i32 5
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
84 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
85
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
86 define i32 @bar1(i32 %a) #0 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
87 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
88 %and1 = and i32 %a, 3
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
89
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
90 ; CHECK-LABEL: @bar1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
91 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
92 ; CHECK: ret i32 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
93
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
94 %and = and i32 %a, 7
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
95 %cmp = icmp eq i32 %and, 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
96 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
97
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
98 ret i32 %and1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
99 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
100
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
101 define i32 @bar2(i32 %a) #0 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
102 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
103 ; CHECK-LABEL: @bar2
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
104 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
105 ; CHECK: ret i32 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
106
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
107 %and = and i32 %a, 7
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
108 %cmp = icmp eq i32 %and, 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
109 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
110
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
111 %and1 = and i32 %a, 3
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
112 ret i32 %and1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
113 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
114
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
115 define i32 @bar3(i32 %a, i1 %x, i1 %y) #0 {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
116 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
117 %and1 = and i32 %a, 3
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
118
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
119 ; Don't be fooled by other assumes around.
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
120 ; CHECK-LABEL: @bar3
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
121 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
122 ; CHECK: ret i32 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
123
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
124 tail call void @llvm.assume(i1 %x)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
125
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
126 %and = and i32 %a, 7
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
127 %cmp = icmp eq i32 %and, 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
128 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
129
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
130 tail call void @llvm.assume(i1 %y)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
131
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
132 ret i32 %and1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
133 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
134
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
135 define i32 @bar4(i32 %a, i32 %b) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
136 entry:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
137 %and1 = and i32 %b, 3
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
138
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
139 ; CHECK-LABEL: @bar4
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
140 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
141 ; CHECK: call void @llvm.assume
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
142 ; CHECK: ret i32 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
143
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
144 %and = and i32 %a, 7
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
145 %cmp = icmp eq i32 %and, 1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
146 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
147
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
148 %cmp2 = icmp eq i32 %a, %b
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
149 tail call void @llvm.assume(i1 %cmp2)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
150
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
151 ret i32 %and1
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
152 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
153
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
154 define i32 @icmp1(i32 %a) #0 {
|
121
|
155 ; CHECK-LABEL: @icmp1(
|
|
156 ; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[A:%.*]], 5
|
|
157 ; CHECK-NEXT: tail call void @llvm.assume(i1 [[CMP]])
|
|
158 ; CHECK-NEXT: ret i32 1
|
|
159 ;
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
160 %cmp = icmp sgt i32 %a, 5
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
161 tail call void @llvm.assume(i1 %cmp)
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
162 %conv = zext i1 %cmp to i32
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
163 ret i32 %conv
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
164 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
165
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
166 define i32 @icmp2(i32 %a) #0 {
|
121
|
167 ; CHECK-LABEL: @icmp2(
|
|
168 ; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[A:%.*]], 5
|
|
169 ; CHECK-NEXT: tail call void @llvm.assume(i1 [[CMP]])
|
|
170 ; CHECK-NEXT: ret i32 0
|
|
171 ;
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
172 %cmp = icmp sgt i32 %a, 5
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
173 tail call void @llvm.assume(i1 %cmp)
|
121
|
174 %t0 = zext i1 %cmp to i32
|
|
175 %lnot.ext = xor i32 %t0, 1
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
176 ret i32 %lnot.ext
|
121
|
177 }
|
|
178
|
|
179 ; If the 'not' of a condition is known true, then the condition must be false.
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
180
|
121
|
181 define i1 @assume_not(i1 %cond) {
|
|
182 ; CHECK-LABEL: @assume_not(
|
|
183 ; CHECK-NEXT: [[NOTCOND:%.*]] = xor i1 [[COND:%.*]], true
|
|
184 ; CHECK-NEXT: call void @llvm.assume(i1 [[NOTCOND]])
|
|
185 ; CHECK-NEXT: ret i1 false
|
|
186 ;
|
|
187 %notcond = xor i1 %cond, true
|
|
188 call void @llvm.assume(i1 %notcond)
|
|
189 ret i1 %cond
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
190 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
191
|
83
|
192 declare void @escape(i32* %a)
|
|
193
|
121
|
194 ; Canonicalize a nonnull assumption on a load into metadata form.
|
|
195
|
83
|
196 define i1 @nonnull1(i32** %a) {
|
121
|
197 ; CHECK-LABEL: @nonnull1(
|
|
198 ; CHECK-NEXT: [[LOAD:%.*]] = load i32*, i32** %a, align 8, !nonnull !0
|
|
199 ; CHECK-NEXT: tail call void @escape(i32* nonnull [[LOAD]])
|
|
200 ; CHECK-NEXT: ret i1 false
|
|
201 ;
|
95
|
202 %load = load i32*, i32** %a
|
83
|
203 %cmp = icmp ne i32* %load, null
|
|
204 tail call void @llvm.assume(i1 %cmp)
|
|
205 tail call void @escape(i32* %load)
|
|
206 %rval = icmp eq i32* %load, null
|
|
207 ret i1 %rval
|
|
208 }
|
|
209
|
|
210 ; Make sure the above canonicalization applies only
|
|
211 ; to pointer types. Doing otherwise would be illegal.
|
121
|
212
|
83
|
213 define i1 @nonnull2(i32* %a) {
|
121
|
214 ; CHECK-LABEL: @nonnull2(
|
|
215 ; CHECK-NEXT: [[LOAD:%.*]] = load i32, i32* %a, align 4
|
|
216 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne i32 [[LOAD]], 0
|
|
217 ; CHECK-NEXT: tail call void @llvm.assume(i1 [[CMP]])
|
|
218 ; CHECK-NEXT: [[RVAL:%.*]] = icmp eq i32 [[LOAD]], 0
|
|
219 ; CHECK-NEXT: ret i1 [[RVAL]]
|
|
220 ;
|
95
|
221 %load = load i32, i32* %a
|
83
|
222 %cmp = icmp ne i32 %load, 0
|
|
223 tail call void @llvm.assume(i1 %cmp)
|
|
224 %rval = icmp eq i32 %load, 0
|
|
225 ret i1 %rval
|
|
226 }
|
|
227
|
|
228 ; Make sure the above canonicalization does not trigger
|
|
229 ; if the assume is control dependent on something else
|
121
|
230
|
83
|
231 define i1 @nonnull3(i32** %a, i1 %control) {
|
121
|
232 ; CHECK-LABEL: @nonnull3(
|
|
233 ; CHECK-NEXT: entry:
|
|
234 ; CHECK-NEXT: [[LOAD:%.*]] = load i32*, i32** %a, align 8
|
|
235 ; CHECK-NEXT: br i1 %control, label %taken, label %not_taken
|
|
236 ; CHECK: taken:
|
|
237 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne i32* [[LOAD]], null
|
|
238 ; CHECK-NEXT: tail call void @llvm.assume(i1 [[CMP]])
|
|
239 ; CHECK-NEXT: [[RVAL:%.*]] = icmp eq i32* [[LOAD]], null
|
|
240 ; CHECK-NEXT: ret i1 [[RVAL]]
|
|
241 ; CHECK: not_taken:
|
|
242 ; CHECK-NEXT: ret i1 true
|
|
243 ;
|
83
|
244 entry:
|
95
|
245 %load = load i32*, i32** %a
|
83
|
246 %cmp = icmp ne i32* %load, null
|
|
247 br i1 %control, label %taken, label %not_taken
|
|
248 taken:
|
|
249 tail call void @llvm.assume(i1 %cmp)
|
|
250 %rval = icmp eq i32* %load, null
|
|
251 ret i1 %rval
|
|
252 not_taken:
|
|
253 ret i1 true
|
|
254 }
|
|
255
|
|
256 ; Make sure the above canonicalization does not trigger
|
121
|
257 ; if the path from the load to the assume is potentially
|
83
|
258 ; interrupted by an exception being thrown
|
121
|
259
|
83
|
260 define i1 @nonnull4(i32** %a) {
|
121
|
261 ; CHECK-LABEL: @nonnull4(
|
|
262 ; CHECK-NEXT: [[LOAD:%.*]] = load i32*, i32** %a, align 8
|
|
263 ; CHECK-NEXT: tail call void @escape(i32* [[LOAD]])
|
|
264 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne i32* [[LOAD]], null
|
|
265 ; CHECK-NEXT: tail call void @llvm.assume(i1 [[CMP]])
|
|
266 ; CHECK-NEXT: [[RVAL:%.*]] = icmp eq i32* [[LOAD]], null
|
|
267 ; CHECK-NEXT: ret i1 [[RVAL]]
|
|
268 ;
|
95
|
269 %load = load i32*, i32** %a
|
83
|
270 ;; This call may throw!
|
|
271 tail call void @escape(i32* %load)
|
|
272 %cmp = icmp ne i32* %load, null
|
|
273 tail call void @llvm.assume(i1 %cmp)
|
|
274 %rval = icmp eq i32* %load, null
|
|
275 ret i1 %rval
|
|
276 }
|
|
277
|
134
|
278 ; PR35846 - https://bugs.llvm.org/show_bug.cgi?id=35846
|
|
279
|
|
280 define i32 @assumption_conflicts_with_known_bits(i32 %a, i32 %b) {
|
|
281 ; CHECK-LABEL: @assumption_conflicts_with_known_bits(
|
|
282 ; CHECK-NEXT: tail call void @llvm.assume(i1 false)
|
|
283 ; CHECK-NEXT: ret i32 0
|
|
284 ;
|
|
285 %and1 = and i32 %b, 3
|
|
286 %B1 = lshr i32 %and1, %and1
|
|
287 %B3 = shl nuw nsw i32 %and1, %B1
|
|
288 %cmp = icmp eq i32 %B3, 1
|
|
289 tail call void @llvm.assume(i1 %cmp)
|
|
290 %cmp2 = icmp eq i32 %B1, %B3
|
|
291 tail call void @llvm.assume(i1 %cmp2)
|
|
292 ret i32 %and1
|
|
293 }
|
|
294
|
83
|
295
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
296 attributes #0 = { nounwind uwtable }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
297 attributes #1 = { nounwind }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
298
|