blob: 641c33d0df1dea93c06d0382552d93936600d7ce [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)
Justin Lebar7e3184c2017-01-26 00:10:26 +0000116declare float @llvm.sqrt.f32(float)
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000117
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000118define float @fabs_select_positive_constants(i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000119; CHECK-LABEL: @fabs_select_positive_constants(
120; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
121; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 1.000000e+00, float 2.000000e+00
122; CHECK-NEXT: ret float [[SELECT]]
123;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000124 %cmp = icmp eq i32 %c, 0
125 %select = select i1 %cmp, float 1.0, float 2.0
126 %fabs = call float @llvm.fabs.f32(float %select)
127 ret float %fabs
128}
129
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000130define float @fabs_select_constant_variable(i32 %c, float %x) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000131; CHECK-LABEL: @fabs_select_constant_variable(
132; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
133; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 1.000000e+00, float [[X:%.*]]
134; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
135; CHECK-NEXT: ret float [[FABS]]
136;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000137 %cmp = icmp eq i32 %c, 0
138 %select = select i1 %cmp, float 1.0, float %x
139 %fabs = call float @llvm.fabs.f32(float %select)
140 ret float %fabs
141}
142
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000143define float @fabs_select_neg0_pos0(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000144; CHECK-LABEL: @fabs_select_neg0_pos0(
145; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
146; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float -0.000000e+00, float 0.000000e+00
147; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
148; CHECK-NEXT: ret float [[FABS]]
149;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000150 %cmp = icmp eq i32 %c, 0
151 %select = select i1 %cmp, float -0.0, float 0.0
152 %fabs = call float @llvm.fabs.f32(float %select)
153 ret float %fabs
154}
155
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000156define float @fabs_select_neg0_neg1(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000157; CHECK-LABEL: @fabs_select_neg0_neg1(
158; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
159; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float -0.000000e+00, float -1.000000e+00
160; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
161; CHECK-NEXT: ret float [[FABS]]
162;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000163 %cmp = icmp eq i32 %c, 0
164 %select = select i1 %cmp, float -0.0, float -1.0
165 %fabs = call float @llvm.fabs.f32(float %select)
166 ret float %fabs
167}
168
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000169define float @fabs_select_nan_nan(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000170; CHECK-LABEL: @fabs_select_nan_nan(
171; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
172; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0x7FF8000000000000, float 0x7FF8000100000000
173; CHECK-NEXT: ret float [[SELECT]]
174;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000175 %cmp = icmp eq i32 %c, 0
176 %select = select i1 %cmp, float 0x7FF8000000000000, float 0x7FF8000100000000
177 %fabs = call float @llvm.fabs.f32(float %select)
178 ret float %fabs
179}
180
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000181define float @fabs_select_negnan_nan(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000182; CHECK-LABEL: @fabs_select_negnan_nan(
183; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
184; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0x7FF8000000000000
185; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
186; CHECK-NEXT: ret float [[FABS]]
187;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000188 %cmp = icmp eq i32 %c, 0
189 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000000000000
190 %fabs = call float @llvm.fabs.f32(float %select)
191 ret float %fabs
192}
193
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000194define float @fabs_select_negnan_negnan(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000195; CHECK-LABEL: @fabs_select_negnan_negnan(
196; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
197; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0x7FF8000100000000
198; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
199; CHECK-NEXT: ret float [[FABS]]
200;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000201 %cmp = icmp eq i32 %c, 0
202 %select = select i1 %cmp, float 0xFFF8000000000000, float 0x7FF8000100000000
203 %fabs = call float @llvm.fabs.f32(float %select)
204 ret float %fabs
205}
206
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000207define float @fabs_select_negnan_negzero(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000208; CHECK-LABEL: @fabs_select_negnan_negzero(
209; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
210; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float -0.000000e+00
211; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
212; CHECK-NEXT: ret float [[FABS]]
213;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000214 %cmp = icmp eq i32 %c, 0
215 %select = select i1 %cmp, float 0xFFF8000000000000, float -0.0
216 %fabs = call float @llvm.fabs.f32(float %select)
217 ret float %fabs
218}
219
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000220define float @fabs_select_negnan_zero(float addrspace(1)* %out, i32 %c) {
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000221; CHECK-LABEL: @fabs_select_negnan_zero(
222; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[C:%.*]], 0
223; CHECK-NEXT: [[SELECT:%.*]] = select i1 [[CMP]], float 0xFFF8000000000000, float 0.000000e+00
224; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SELECT]])
225; CHECK-NEXT: ret float [[FABS]]
226;
Matt Arsenault1e0edbf2017-01-11 00:33:24 +0000227 %cmp = icmp eq i32 %c, 0
228 %select = select i1 %cmp, float 0xFFF8000000000000, float 0.0
229 %fabs = call float @llvm.fabs.f32(float %select)
230 ret float %fabs
231}
Justin Lebar7e3184c2017-01-26 00:10:26 +0000232
Justin Lebar7e3184c2017-01-26 00:10:26 +0000233; The fabs can't be eliminated because llvm.sqrt.f32 may return -0 or NaN with
234; an arbitrary sign bit.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000235define float @fabs_sqrt(float %a) {
236; CHECK-LABEL: @fabs_sqrt(
237; CHECK-NEXT: [[SQRT:%.*]] = call float @llvm.sqrt.f32(float [[A:%.*]])
238; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
239; CHECK-NEXT: ret float [[FABS]]
240;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000241 %sqrt = call float @llvm.sqrt.f32(float %a)
242 %fabs = call float @llvm.fabs.f32(float %sqrt)
243 ret float %fabs
244}
245
Justin Lebar7e3184c2017-01-26 00:10:26 +0000246; The fabs can't be eliminated because the nnan sqrt may still return -0.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000247define float @fabs_sqrt_nnan(float %a) {
248; CHECK-LABEL: @fabs_sqrt_nnan(
249; CHECK-NEXT: [[SQRT:%.*]] = call nnan float @llvm.sqrt.f32(float [[A:%.*]])
250; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
251; CHECK-NEXT: ret float [[FABS]]
252;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000253 %sqrt = call nnan float @llvm.sqrt.f32(float %a)
254 %fabs = call float @llvm.fabs.f32(float %sqrt)
255 ret float %fabs
256}
257
Justin Lebar7e3184c2017-01-26 00:10:26 +0000258; The fabs can't be eliminated because the nsz sqrt may still return NaN.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000259define float @fabs_sqrt_nsz(float %a) {
260; CHECK-LABEL: @fabs_sqrt_nsz(
261; CHECK-NEXT: [[SQRT:%.*]] = call nsz float @llvm.sqrt.f32(float [[A:%.*]])
262; CHECK-NEXT: [[FABS:%.*]] = call float @llvm.fabs.f32(float [[SQRT]])
263; CHECK-NEXT: ret float [[FABS]]
264;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000265 %sqrt = call nsz float @llvm.sqrt.f32(float %a)
266 %fabs = call float @llvm.fabs.f32(float %sqrt)
267 ret float %fabs
268}
269
Justin Lebar7e3184c2017-01-26 00:10:26 +0000270; The fabs can be eliminated because we're nsz and nnan.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000271define float @fabs_sqrt_nnan_nsz(float %a) {
272; CHECK-LABEL: @fabs_sqrt_nnan_nsz(
273; CHECK-NEXT: [[SQRT:%.*]] = call nnan nsz float @llvm.sqrt.f32(float [[A:%.*]])
274; CHECK-NEXT: ret float [[SQRT]]
275;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000276 %sqrt = call nnan nsz float @llvm.sqrt.f32(float %a)
277 %fabs = call float @llvm.fabs.f32(float %sqrt)
278 ret float %fabs
279}
280
Justin Lebar7e3184c2017-01-26 00:10:26 +0000281; The second fabs can be eliminated because the operand to sqrt cannot be -0.
Sanjay Patelb13fcd52018-02-13 18:22:53 +0000282define float @fabs_sqrt_nnan_fabs(float %a) {
283; CHECK-LABEL: @fabs_sqrt_nnan_fabs(
284; CHECK-NEXT: [[B:%.*]] = call float @llvm.fabs.f32(float [[A:%.*]])
285; CHECK-NEXT: [[SQRT:%.*]] = call nnan float @llvm.sqrt.f32(float [[B]])
286; CHECK-NEXT: ret float [[SQRT]]
287;
Justin Lebar7e3184c2017-01-26 00:10:26 +0000288 %b = call float @llvm.fabs.f32(float %a)
289 %sqrt = call nnan float @llvm.sqrt.f32(float %b)
290 %fabs = call float @llvm.fabs.f32(float %sqrt)
291 ret float %fabs
292}