blob: 5ec820f8cfc5a136d674c0198bbd081c5a4f3d33 [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 Patelb13fcd52018-02-13 18:22:53 +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 Patelb13fcd52018-02-13 18:22:53 +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 Patelb13fcd52018-02-13 18:22:53 +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 Patelb13fcd52018-02-13 18:22:53 +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 Patelb13fcd52018-02-13 18:22:53 +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 Patelb13fcd52018-02-13 18:22:53 +000059; CHECK-NEXT: ret double [[A:%.*]]
Sanjay Patel69632442016-03-25 20:12:25 +000060;
Sanjay Patelb13fcd52018-02-13 18:22:53 +000061 %b = fmul double 1.0, %a
Michael Ilsemanbb6f6912012-12-12 00:27:46 +000062 ret double %b
63}
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000064
Sanjay Patelb13fcd52018-02-13 18:22:53 +000065; PR2642
66define <4 x float> @fmul_X_1_vec(<4 x float> %x) {
67; CHECK-LABEL: @fmul_X_1_vec(
68; CHECK-NEXT: ret <4 x float> [[X:%.*]]
69;
70 %m = fmul <4 x float> %x, <float 1.0, float 1.0, float 1.0, float 1.0>
71 ret <4 x float> %m
72}
73
Sanjay Patel2580c952016-12-08 20:23:56 +000074; fdiv X, 1.0 ==> X
75define float @fdiv_x_1(float %a) {
76; CHECK-LABEL: @fdiv_x_1(
Sanjay Patelb13fcd52018-02-13 18:22:53 +000077; CHECK-NEXT: ret float [[A:%.*]]
Sanjay Patel2580c952016-12-08 20:23:56 +000078;
79 %ret = fdiv float %a, 1.0
80 ret float %ret
81}
82
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000083; We can't optimize away the fadd in this test because the input
Sanjay Patel69632442016-03-25 20:12:25 +000084; value to the function and subsequently to the fadd may be -0.0.
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000085; In that one special case, the result of the fadd should be +0.0
86; rather than the first parameter of the fadd.
87
Sanjay Patel69632442016-03-25 20:12:25 +000088; Fragile test warning: We need 6 sqrt calls to trigger the bug
89; because the internal logic has a magic recursion limit of 6.
Sanjay Patel40eaa8d2015-02-25 18:00:15 +000090; This is presented without any explanation or ability to customize.
91
92declare float @sqrtf(float)
93
94define float @PR22688(float %x) {
Sanjay Patel69632442016-03-25 20:12:25 +000095; CHECK-LABEL: @PR22688(
Sanjay Patelb13fcd52018-02-13 18:22:53 +000096; CHECK-NEXT: [[TMP1:%.*]] = call float @sqrtf(float [[X:%.*]])
Sanjay Patel2580c952016-12-08 20:23:56 +000097; CHECK-NEXT: [[TMP2:%.*]] = call float @sqrtf(float [[TMP1]])
98; CHECK-NEXT: [[TMP3:%.*]] = call float @sqrtf(float [[TMP2]])
99; CHECK-NEXT: [[TMP4:%.*]] = call float @sqrtf(float [[TMP3]])
100; CHECK-NEXT: [[TMP5:%.*]] = call float @sqrtf(float [[TMP4]])
101; CHECK-NEXT: [[TMP6:%.*]] = call float @sqrtf(float [[TMP5]])
102; CHECK-NEXT: [[TMP7:%.*]] = fadd float [[TMP6]], 0.000000e+00
Sanjay Patel69632442016-03-25 20:12:25 +0000103; CHECK-NEXT: ret float [[TMP7]]
104;
Sanjay Patel40eaa8d2015-02-25 18:00:15 +0000105 %1 = call float @sqrtf(float %x)
106 %2 = call float @sqrtf(float %1)
107 %3 = call float @sqrtf(float %2)
108 %4 = call float @sqrtf(float %3)
109 %5 = call float @sqrtf(float %4)
110 %6 = call float @sqrtf(float %5)
111 %7 = fadd float %6, 0.0
112 ret float %7
Sanjay Patel40eaa8d2015-02-25 18:00:15 +0000113}
114
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000115declare float @llvm.fabs.f32(float)
Craig Topperaee341e2018-02-25 06:51:52 +0000116declare <2 x float> @llvm.fabs.v2f32(<2 x float>)
Justin Lebar7e3184c2017-01-26 00:10:26 +0000117declare float @llvm.sqrt.f32(float)
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000118
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000119define float @fabs_select_positive_constants(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000120; CHECK-LABEL: @fabs_select_positive_constants(
121; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
122; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 1.000000e+00, float 2.000000e+00
123; CHECK-NEXT: ret float [[SELECT]]
124;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000125 %cmp = icmp eq i32 %c, 0
126 %select = select i1 %cmp, float 1.0, float 2.0
127 %fabs = call float @llvm.fabs.f32(float %select)
128 ret float %fabs
129}
130
Craig Topperaee341e2018-02-25 06:51:52 +0000131define <2 x float> @fabs_select_positive_constants_vector(i32 %c) {
132; CHECK-LABEL: @fabs_select_positive_constants_vector(
133; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
134; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 1.000000e+00, float 1.000000e+00>, <2 x float> <float 2.000000e+00, float 2.000000e+00>
135; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
136; CHECK-NEXT: ret <2 x float> [[FABS]]
137;
138 %cmp = icmp eq i32 %c, 0
139 %select = select i1 %cmp, <2 x float> <float 1.0, float 1.0>, <2 x float> <float 2.0, float 2.0>
140 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
141 ret <2 x float> %fabs
142}
143
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000144define float @fabs_select_constant_variable(i32 %c, float %x) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000145; CHECK-LABEL: @fabs_select_constant_variable(
146; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
147; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 1.000000e+00, float [[X:%.*]]
148; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
149; CHECK-NEXT: ret float [[FABS]]
150;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000151 %cmp = icmp eq i32 %c, 0
152 %select = select i1 %cmp, float 1.0, float %x
153 %fabs = call float @llvm.fabs.f32(float %select)
154 ret float %fabs
155}
156
Craig Topperaee341e2018-02-25 06:51:52 +0000157define <2 x float> @fabs_select_constant_variable_vector(i32 %c, <2 x float> %x) {
158; CHECK-LABEL: @fabs_select_constant_variable_vector(
159; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
160; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 1.000000e+00, float 1.000000e+00>, <2 x float> [[X:%.*]]
161; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
162; CHECK-NEXT: ret <2 x float> [[FABS]]
163;
164 %cmp = icmp eq i32 %c, 0
165 %select = select i1 %cmp, <2 x float> <float 1.0, float 1.0>, <2 x float> %x
166 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
167 ret <2 x float> %fabs
168}
169
Craig Topper2b8f0512018-02-25 06:51:51 +0000170define float @fabs_select_neg0_pos0(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000171; CHECK-LABEL: @fabs_select_neg0_pos0(
172; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
173; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float -0.000000e+00, float 0.000000e+00
174; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
175; CHECK-NEXT: ret float [[FABS]]
176;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000177 %cmp = icmp eq i32 %c, 0
178 %select = select i1 %cmp, float -0.0, float 0.0
179 %fabs = call float @llvm.fabs.f32(float %select)
180 ret float %fabs
181}
182
Craig Topperaee341e2018-02-25 06:51:52 +0000183define <2 x float> @fabs_select_neg0_pos0_vector(i32 %c) {
184; CHECK-LABEL: @fabs_select_neg0_pos0_vector(
185; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
186; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float -0.000000e+00, float -0.000000e+00>, <2 x float> zeroinitializer
187; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
188; CHECK-NEXT: ret <2 x float> [[FABS]]
189;
190 %cmp = icmp eq i32 %c, 0
191 %select = select i1 %cmp, <2 x float> <float -0.0, float -0.0>, <2 x float> <float 0.0, float 0.0>
192 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
193 ret <2 x float> %fabs
194}
195
Craig Topper2b8f0512018-02-25 06:51:51 +0000196define float @fabs_select_neg0_neg1(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000197; CHECK-LABEL: @fabs_select_neg0_neg1(
198; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
199; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float -0.000000e+00, float -1.000000e+00
200; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
201; CHECK-NEXT: ret float [[FABS]]
202;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000203 %cmp = icmp eq i32 %c, 0
204 %select = select i1 %cmp, float -0.0, float -1.0
205 %fabs = call float @llvm.fabs.f32(float %select)
206 ret float %fabs
207}
208
Craig Topperaee341e2018-02-25 06:51:52 +0000209define <2 x float> @fabs_select_neg0_neg1_vector(i32 %c) {
210; CHECK-LABEL: @fabs_select_neg0_neg1_vector(
211; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
212; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float -0.000000e+00, float -0.000000e+00>, <2 x float> <float -1.000000e+00, float -1.000000e+00>
213; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
214; CHECK-NEXT: ret <2 x float> [[FABS]]
215;
216 %cmp = icmp eq i32 %c, 0
217 %select = select i1 %cmp, <2 x float> <float -0.0, float -0.0>, <2 x float> <float -1.0, float -1.0>
218 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
219 ret <2 x float> %fabs
220}
221
Craig Topper2b8f0512018-02-25 06:51:51 +0000222define float @fabs_select_nan_nan(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000223; CHECK-LABEL: @fabs_select_nan_nan(
224; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
225; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0x7FF8000000000000, float 0x7FF8000100000000
226; CHECK-NEXT: ret float [[SELECT]]
227;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000228 %cmp = icmp eq i32 %c, 0
229 %select = select i1 %cmp, float 0x7FF8000000000000, float 0x7FF8000100000000
230 %fabs = call float @llvm.fabs.f32(float %select)
231 ret float %fabs
232}
233
Craig Topperaee341e2018-02-25 06:51:52 +0000234define <2 x float> @fabs_select_nan_nan_vector(i32 %c) {
235; CHECK-LABEL: @fabs_select_nan_nan_vector(
236; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
237; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>, <2 x float> <float 0x7FF8000100000000, float 0x7FF8000100000000>
238; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
239; CHECK-NEXT: ret <2 x float> [[FABS]]
240;
241 %cmp = icmp eq i32 %c, 0
242 %select = select i1 %cmp, <2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>, <2 x float> <float 0x7FF8000100000000, float 0x7FF8000100000000>
243 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
244 ret <2 x float> %fabs
245}
246
Craig Topper2b8f0512018-02-25 06:51:51 +0000247define float @fabs_select_negnan_nan(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000248; CHECK-LABEL: @fabs_select_negnan_nan(
249; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
250; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0x7FF8000000000000
251; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
252; CHECK-NEXT: ret float [[FABS]]
253;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000254 %cmp = icmp eq i32 %c, 0
255 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000000000000
256 %fabs = call float @llvm.fabs.f32(float %select)
257 ret float %fabs
258}
259
Craig Topperaee341e2018-02-25 06:51:52 +0000260define <2 x float> @fabs_select_negnan_nan_vector(i32 %c) {
261; CHECK-LABEL: @fabs_select_negnan_nan_vector(
262; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
263; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>
264; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
265; CHECK-NEXT: ret <2 x float> [[FABS]]
266;
267 %cmp = icmp eq i32 %c, 0
268 %select = select i1 %cmp, <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>
269 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
270 ret <2 x float> %fabs
271}
272
Craig Topper2b8f0512018-02-25 06:51:51 +0000273define float @fabs_select_negnan_negnan(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000274; CHECK-LABEL: @fabs_select_negnan_negnan(
275; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
276; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0x7FF8000100000000
277; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
278; CHECK-NEXT: ret float [[FABS]]
279;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000280 %cmp = icmp eq i32 %c, 0
281 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000100000000
282 %fabs = call float @llvm.fabs.f32(float %select)
283 ret float %fabs
284}
285
Craig Topperaee341e2018-02-25 06:51:52 +0000286define <2 x float> @fabs_select_negnan_negnan_vector(i32 %c) {
287; CHECK-LABEL: @fabs_select_negnan_negnan_vector(
288; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
289; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float 0x7FF8000100000000, float 0x7FF8000100000000>
290; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
291; CHECK-NEXT: ret <2 x float> [[FABS]]
292;
293 %cmp = icmp eq i32 %c, 0
294 %select = select i1 %cmp, <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float 0x7FF8000100000000, float 0x7FF8000100000000>
295 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
296 ret <2 x float> %fabs
297}
298
Craig Topper2b8f0512018-02-25 06:51:51 +0000299define float @fabs_select_negnan_negzero(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000300; CHECK-LABEL: @fabs_select_negnan_negzero(
301; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
302; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float -0.000000e+00
303; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
304; CHECK-NEXT: ret float [[FABS]]
305;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000306 %cmp = icmp eq i32 %c, 0
307 %select = select i1 %cmp, float 0xFFF8000000000000, float -0.0
308 %fabs = call float @llvm.fabs.f32(float %select)
309 ret float %fabs
310}
311
Craig Topperaee341e2018-02-25 06:51:52 +0000312define <2 x float> @fabs_select_negnan_negzero_vector(i32 %c) {
313; CHECK-LABEL: @fabs_select_negnan_negzero_vector(
314; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
315; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float -0.000000e+00, float -0.000000e+00>
316; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
317; CHECK-NEXT: ret <2 x float> [[FABS]]
318;
319 %cmp = icmp eq i32 %c, 0
320 %select = select i1 %cmp, <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float -0.0, float -0.0>
321 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
322 ret <2 x float> %fabs
323}
324
Craig Topper2b8f0512018-02-25 06:51:51 +0000325define float @fabs_select_negnan_zero(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000326; CHECK-LABEL: @fabs_select_negnan_zero(
327; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
328; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0.000000e+00
329; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
330; CHECK-NEXT: ret float [[FABS]]
331;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000332 %cmp = icmp eq i32 %c, 0
333 %select = select i1 %cmp, float 0xFFF8000000000000, float 0.0
334 %fabs = call float @llvm.fabs.f32(float %select)
335 ret float %fabs
336}
Justin Lebar7e3184c2017-01-26 00:10:26 +0000337
Craig Topperaee341e2018-02-25 06:51:52 +0000338define <2 x float> @fabs_select_negnan_zero_vector(i32 %c) {
339; CHECK-LABEL: @fabs_select_negnan_zero_vector(
340; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
341; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> zeroinitializer
342; CHECK-NEXT: [[FABS:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[SELECT]])
343; CHECK-NEXT: ret <2 x float> [[FABS]]
344;
345 %cmp = icmp eq i32 %c, 0
346 %select = select i1 %cmp, <2 x float> <float 0xFFF8000000000000, float 0xFFF8000000000000>, <2 x float> <float 0.0, float 0.0>
347 %fabs = call <2 x float> @llvm.fabs.v2f32(<2 x float> %select)
348 ret <2 x float> %fabs
349}
350
Justin Lebar7e3184c2017-01-26 00:10:26 +0000351; The fabs can't be eliminated because llvm.sqrt.f32 may return -0 or NaN with
352; an arbitrary sign bit.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000353define float @fabs_sqrt(float %a) {
354; CHECK-LABEL: @fabs_sqrt(
355; CHECK-NEXT: [[SQRT:%.*]] = call float @llvm.sqrt.f32(float [[A:%.*]])
356; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
357; CHECK-NEXT: ret float [[FABS]]
358;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000359 %sqrt = call float @llvm.sqrt.f32(float %a)
360 %fabs = call float @llvm.fabs.f32(float %sqrt)
361 ret float %fabs
362}
363
Justin Lebar7e3184c2017-01-26 00:10:26 +0000364; The fabs can't be eliminated because the nnan sqrt may still return -0.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000365define float @fabs_sqrt_nnan(float %a) {
366; CHECK-LABEL: @fabs_sqrt_nnan(
367; CHECK-NEXT: [[SQRT:%.*]] = call nnan float @llvm.sqrt.f32(float [[A:%.*]])
368; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
369; CHECK-NEXT: ret float [[FABS]]
370;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000371 %sqrt = call nnan float @llvm.sqrt.f32(float %a)
372 %fabs = call float @llvm.fabs.f32(float %sqrt)
373 ret float %fabs
374}
375
Justin Lebar7e3184c2017-01-26 00:10:26 +0000376; The fabs can't be eliminated because the nsz sqrt may still return NaN.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000377define float @fabs_sqrt_nsz(float %a) {
378; CHECK-LABEL: @fabs_sqrt_nsz(
379; CHECK-NEXT: [[SQRT:%.*]] = call nsz float @llvm.sqrt.f32(float [[A:%.*]])
380; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
381; CHECK-NEXT: ret float [[FABS]]
382;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000383 %sqrt = call nsz float @llvm.sqrt.f32(float %a)
384 %fabs = call float @llvm.fabs.f32(float %sqrt)
385 ret float %fabs
386}
387
Justin Lebar7e3184c2017-01-26 00:10:26 +0000388; The fabs can be eliminated because we're nsz and nnan.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000389define float @fabs_sqrt_nnan_nsz(float %a) {
390; CHECK-LABEL: @fabs_sqrt_nnan_nsz(
391; CHECK-NEXT: [[SQRT:%.*]] = call nnan nsz float @llvm.sqrt.f32(float [[A:%.*]])
392; CHECK-NEXT: ret float [[SQRT]]
393;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000394 %sqrt = call nnan nsz float @llvm.sqrt.f32(float %a)
395 %fabs = call float @llvm.fabs.f32(float %sqrt)
396 ret float %fabs
397}
398
Justin Lebar7e3184c2017-01-26 00:10:26 +0000399; The second fabs can be eliminated because the operand to sqrt cannot be -0.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000400define float @fabs_sqrt_nnan_fabs(float %a) {
401; CHECK-LABEL: @fabs_sqrt_nnan_fabs(
402; CHECK-NEXT: [[B:%.*]] = call float @llvm.fabs.f32(float [[A:%.*]])
403; CHECK-NEXT: [[SQRT:%.*]] = call nnan float @llvm.sqrt.f32(float [[B]])
404; CHECK-NEXT: ret float [[SQRT]]
405;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000406 %b = call float @llvm.fabs.f32(float %a)
407 %sqrt = call nnan float @llvm.sqrt.f32(float %b)
408 %fabs = call float @llvm.fabs.f32(float %sqrt)
409 ret float %fabs
410}