blob: 21c9fdde15069ede72a60715a2313b52c2c85add [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