blob: e635032e6b712a7c648b49f62e529f623ec24c4c [file] [log] [blame]
Sanjay Patel2580c952016-12-08 20:23:56 +00001; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
Michael Ilsemanbb6f6912012-12-12 00:27:46 +00002; RUN: opt < %s -instsimplify -S | FileCheck %s
3
Benjamin Kramerf5b2a472016-02-29 11:12:23 +00004; fsub -0.0, (fsub -0.0, X) ==> X
Benjamin Kramerf5b2a472016-02-29 11:12:23 +00005define float @fsub_-0_-0_x(float %a) {
Sanjay Patel69632442016-03-25 20:12:25 +00006; CHECK-LABEL: @fsub_-0_-0_x(
Sanjay Patel2580c952016-12-08 20:23:56 +00007; CHECK-NEXT: ret float %a
Sanjay Patel69632442016-03-25 20:12:25 +00008;
Michael Ilsemanbb6f6912012-12-12 00:27:46 +00009 %t1 = fsub float -0.0, %a
10 %ret = fsub float -0.0, %t1
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000011 ret float %ret
12}
13
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000014; fsub 0.0, (fsub -0.0, X) != X
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000015define float @fsub_0_-0_x(float %a) {
Sanjay Patel69632442016-03-25 20:12:25 +000016; CHECK-LABEL: @fsub_0_-0_x(
Sanjay Patel2580c952016-12-08 20:23:56 +000017; CHECK-NEXT: [[T1:%.*]] = fsub float 0.000000e+00, %a
Sanjay Patel69632442016-03-25 20:12:25 +000018; CHECK-NEXT: [[RET:%.*]] = fsub float -0.000000e+00, [[T1]]
19; CHECK-NEXT: ret float [[RET]]
20;
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000021 %t1 = fsub float 0.0, %a
22 %ret = fsub float -0.0, %t1
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000023 ret float %ret
24}
25
26; fsub -0.0, (fsub 0.0, X) != X
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000027define float @fsub_-0_0_x(float %a) {
Sanjay Patel69632442016-03-25 20:12:25 +000028; CHECK-LABEL: @fsub_-0_0_x(
Sanjay Patel2580c952016-12-08 20:23:56 +000029; CHECK-NEXT: [[T1:%.*]] = fsub float -0.000000e+00, %a
Sanjay Patel69632442016-03-25 20:12:25 +000030; CHECK-NEXT: [[RET:%.*]] = fsub float 0.000000e+00, [[T1]]
31; CHECK-NEXT: ret float [[RET]]
32;
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000033 %t1 = fsub float -0.0, %a
34 %ret = fsub float 0.0, %t1
Benjamin Kramerf5b2a472016-02-29 11:12:23 +000035 ret float %ret
36}
37
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000038; fsub X, 0 ==> X
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000039define float @fsub_x_0(float %a) {
Sanjay Patel69632442016-03-25 20:12:25 +000040; CHECK-LABEL: @fsub_x_0(
Sanjay Patel2580c952016-12-08 20:23:56 +000041; CHECK-NEXT: ret float %a
Sanjay Patel69632442016-03-25 20:12:25 +000042;
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000043 %ret = fsub float %a, 0.0
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000044 ret float %ret
45}
46
47; fadd X, -0 ==> X
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000048define float @fadd_x_n0(float %a) {
Sanjay Patel69632442016-03-25 20:12:25 +000049; CHECK-LABEL: @fadd_x_n0(
Sanjay Patel2580c952016-12-08 20:23:56 +000050; CHECK-NEXT: ret float %a
Sanjay Patel69632442016-03-25 20:12:25 +000051;
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000052 %ret = fadd float %a, -0.0
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000053 ret float %ret
54}
55
56; fmul X, 1.0 ==> X
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000057define double @fmul_X_1(double %a) {
Sanjay Patel69632442016-03-25 20:12:25 +000058; CHECK-LABEL: @fmul_X_1(
Sanjay Patel2580c952016-12-08 20:23:56 +000059; CHECK-NEXT: ret double %a
Sanjay Patel69632442016-03-25 20:12:25 +000060;
61 %b = fmul double 1.000000e+00, %a
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000062 ret double %b
63}
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000064
Sanjay Patel2580c952016-12-08 20:23:56 +000065; fdiv X, 1.0 ==> X
66define float @fdiv_x_1(float %a) {
67; CHECK-LABEL: @fdiv_x_1(
Zia Ansari394cef82016-12-08 23:27:40 +000068; CHECK-NEXT: ret float %a
Sanjay Patel2580c952016-12-08 20:23:56 +000069;
70 %ret = fdiv float %a, 1.0
71 ret float %ret
72}
73
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000074; We can't optimize away the fadd in this test because the input
Sanjay Patel69632442016-03-25 20:12:25 +000075; value to the function and subsequently to the fadd may be -0.0.
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000076; In that one special case, the result of the fadd should be +0.0
77; rather than the first parameter of the fadd.
78
Sanjay Patel69632442016-03-25 20:12:25 +000079; Fragile test warning: We need 6 sqrt calls to trigger the bug
80; because the internal logic has a magic recursion limit of 6.
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000081; This is presented without any explanation or ability to customize.
82
83declare float @sqrtf(float)
84
85define float @PR22688(float %x) {
Sanjay Patel69632442016-03-25 20:12:25 +000086; CHECK-LABEL: @PR22688(
Sanjay Patel2580c952016-12-08 20:23:56 +000087; CHECK-NEXT: [[TMP1:%.*]] = call float @sqrtf(float %x)
88; CHECK-NEXT: [[TMP2:%.*]] = call float @sqrtf(float [[TMP1]])
89; CHECK-NEXT: [[TMP3:%.*]] = call float @sqrtf(float [[TMP2]])
90; CHECK-NEXT: [[TMP4:%.*]] = call float @sqrtf(float [[TMP3]])
91; CHECK-NEXT: [[TMP5:%.*]] = call float @sqrtf(float [[TMP4]])
92; CHECK-NEXT: [[TMP6:%.*]] = call float @sqrtf(float [[TMP5]])
93; CHECK-NEXT: [[TMP7:%.*]] = fadd float [[TMP6]], 0.000000e+00
Sanjay Patel69632442016-03-25 20:12:25 +000094; CHECK-NEXT: ret float [[TMP7]]
95;
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000096 %1 = call float @sqrtf(float %x)
97 %2 = call float @sqrtf(float %1)
98 %3 = call float @sqrtf(float %2)
99 %4 = call float @sqrtf(float %3)
100 %5 = call float @sqrtf(float %4)
101 %6 = call float @sqrtf(float %5)
102 %7 = fadd float %6, 0.0
103 ret float %7
Sanjay Patel40eaa8d2015-02-25 18:00:15 +0000104}
105
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000106declare float @llvm.fabs.f32(float)
Justin Lebar7e3184c2017-01-26 00:10:26 +0000107declare float @llvm.sqrt.f32(float)
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000108
109; CHECK-LABEL: @fabs_select_positive_constants(
110; CHECK: %select = select i1 %cmp, float 1.000000e+00, float 2.000000e+00
111; CHECK-NEXT: ret float %select
112define float @fabs_select_positive_constants(i32 %c) {
113 %cmp = icmp eq i32 %c, 0
114 %select = select i1 %cmp, float 1.0, float 2.0
115 %fabs = call float @llvm.fabs.f32(float %select)
116 ret float %fabs
117}
118
119; CHECK-LABEL: @fabs_select_constant_variable(
120; CHECK: %select = select i1 %cmp, float 1.000000e+00, float %x
121; CHECK-NEXT: %fabs = call float @llvm.fabs.f32(float %select)
122define float @fabs_select_constant_variable(i32 %c, float %x) {
123 %cmp = icmp eq i32 %c, 0
124 %select = select i1 %cmp, float 1.0, float %x
125 %fabs = call float @llvm.fabs.f32(float %select)
126 ret float %fabs
127}
128
129; CHECK-LABEL: @fabs_select_neg0_pos0(
130; CHECK: %select = select i1 %cmp, float -0.000000e+00, float 0.000000e+00
131; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
132; CHECK-NEXT: ret float %fabs
133define float @fabs_select_neg0_pos0(float addrspace(1)* %out, i32 %c) {
134 %cmp = icmp eq i32 %c, 0
135 %select = select i1 %cmp, float -0.0, float 0.0
136 %fabs = call float @llvm.fabs.f32(float %select)
137 ret float %fabs
138}
139
140; CHECK-LABEL: @fabs_select_neg0_neg1(
141; CHECK: %select = select i1 %cmp, float -0.000000e+00, float -1.000000e+00
142; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
143define float @fabs_select_neg0_neg1(float addrspace(1)* %out, i32 %c) {
144 %cmp = icmp eq i32 %c, 0
145 %select = select i1 %cmp, float -0.0, float -1.0
146 %fabs = call float @llvm.fabs.f32(float %select)
147 ret float %fabs
148}
149
150; CHECK-LABEL: @fabs_select_nan_nan(
151; CHECK: %select = select i1 %cmp, float 0x7FF8000000000000, float 0x7FF8000100000000
152; CHECK-NEXT: ret float %select
153define float @fabs_select_nan_nan(float addrspace(1)* %out, i32 %c) {
154 %cmp = icmp eq i32 %c, 0
155 %select = select i1 %cmp, float 0x7FF8000000000000, float 0x7FF8000100000000
156 %fabs = call float @llvm.fabs.f32(float %select)
157 ret float %fabs
158}
159
160; CHECK-LABEL: @fabs_select_negnan_nan(
161; CHECK: %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000000000000
162; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
163define float @fabs_select_negnan_nan(float addrspace(1)* %out, i32 %c) {
164 %cmp = icmp eq i32 %c, 0
165 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000000000000
166 %fabs = call float @llvm.fabs.f32(float %select)
167 ret float %fabs
168}
169
170; CHECK-LABEL: @fabs_select_negnan_negnan(
171; CHECK: %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000100000000
172; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
173define float @fabs_select_negnan_negnan(float addrspace(1)* %out, i32 %c) {
174 %cmp = icmp eq i32 %c, 0
175 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000100000000
176 %fabs = call float @llvm.fabs.f32(float %select)
177 ret float %fabs
178}
179
180; CHECK-LABEL: @fabs_select_negnan_negzero(
181; CHECK: %select = select i1 %cmp, float 0xFFF8000000000000, float -0.000000e+00
182; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
183define float @fabs_select_negnan_negzero(float addrspace(1)* %out, i32 %c) {
184 %cmp = icmp eq i32 %c, 0
185 %select = select i1 %cmp, float 0xFFF8000000000000, float -0.0
186 %fabs = call float @llvm.fabs.f32(float %select)
187 ret float %fabs
188}
189
190; CHECK-LABEL: @fabs_select_negnan_zero(
191; CHECK: %select = select i1 %cmp, float 0xFFF8000000000000, float 0.000000e+00
192; CHECK: %fabs = call float @llvm.fabs.f32(float %select)
193define float @fabs_select_negnan_zero(float addrspace(1)* %out, i32 %c) {
194 %cmp = icmp eq i32 %c, 0
195 %select = select i1 %cmp, float 0xFFF8000000000000, float 0.0
196 %fabs = call float @llvm.fabs.f32(float %select)
197 ret float %fabs
198}
Justin Lebar7e3184c2017-01-26 00:10:26 +0000199
200; CHECK-LABEL: @fabs_sqrt
201; CHECK: call float @llvm.sqrt.f32
202; CHECK: call float @llvm.fabs.f32
203define float @fabs_sqrt(float %a) {
204; The fabs can't be eliminated because llvm.sqrt.f32 may return -0 or NaN with
205; an arbitrary sign bit.
206 %sqrt = call float @llvm.sqrt.f32(float %a)
207 %fabs = call float @llvm.fabs.f32(float %sqrt)
208 ret float %fabs
209}
210
211; CHECK-LABEL: @fabs_sqrt_nnan
212; CHECK: call nnan float @llvm.sqrt.f32
213; CHECK: call float @llvm.fabs.f32
214define float @fabs_sqrt_nnan(float %a) {
215; The fabs can't be eliminated because the nnan sqrt may still return -0.
216 %sqrt = call nnan float @llvm.sqrt.f32(float %a)
217 %fabs = call float @llvm.fabs.f32(float %sqrt)
218 ret float %fabs
219}
220
221; CHECK-LABEL: @fabs_sqrt_nsz
222; CHECK: call nsz float @llvm.sqrt.f32
223; CHECK: call float @llvm.fabs.f32
224define float @fabs_sqrt_nsz(float %a) {
225; The fabs can't be eliminated because the nsz sqrt may still return NaN.
226 %sqrt = call nsz float @llvm.sqrt.f32(float %a)
227 %fabs = call float @llvm.fabs.f32(float %sqrt)
228 ret float %fabs
229}
230
231; CHECK-LABEL: @fabs_sqrt_nnan_nsz
232; CHECK: call nnan nsz float @llvm.sqrt.f32
233; CHECK-NOT: call float @llvm.fabs.f32
234define float @fabs_sqrt_nnan_nsz(float %a) {
235; The fabs can be eliminated because we're nsz and nnan.
236 %sqrt = call nnan nsz float @llvm.sqrt.f32(float %a)
237 %fabs = call float @llvm.fabs.f32(float %sqrt)
238 ret float %fabs
239}
240
241; CHECK-LABEL: @fabs_sqrt_nnan_fabs
242; CHECK: call float @llvm.fabs.f32
243; CHECK: call nnan float @llvm.sqrt.f32
244; CHECK-NOT: call float @llvm.fabs.f32
245define float @fabs_sqrt_nnan_fabs(float %a) {
246; The second fabs can be eliminated because the operand to sqrt cannot be -0.
247 %b = call float @llvm.fabs.f32(float %a)
248 %sqrt = call nnan float @llvm.sqrt.f32(float %b)
249 %fabs = call float @llvm.fabs.f32(float %sqrt)
250 ret float %fabs
251}