[PATCH] D62013: [InstSimplify] Add unary fneg to `fsub 0.0, (fneg X) ==> X` transform
Cameron McInally via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu May 16 09:40:43 PDT 2019
cameron.mcinally updated this revision to Diff 199850.
cameron.mcinally added a comment.
Fix another test I botched in r360808.
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D62013/new/
https://reviews.llvm.org/D62013
Files:
llvm/lib/Analysis/InstructionSimplify.cpp
llvm/test/Transforms/InstSimplify/fast-math.ll
Index: llvm/test/Transforms/InstSimplify/fast-math.ll
===================================================================
--- llvm/test/Transforms/InstSimplify/fast-math.ll
+++ llvm/test/Transforms/InstSimplify/fast-math.ll
@@ -219,12 +219,10 @@
; fsub nsz 0.0, (fneg X) ==> X
define float @fneg_x(float %a) {
; CHECK-LABEL: @fneg_x(
-; CHECK-NEXT: [[T1:%.*]] = fsub float 0.000000e+00, [[A:%.*]]
-; CHECK-NEXT: [[RET:%.*]] = fneg nsz float [[T1]]
-; CHECK-NEXT: ret float [[RET]]
+; CHECK-NEXT: ret float [[A:%.*]]
;
- %t1 = fsub float 0.0, %a
- %ret = fneg nsz float %t1
+ %t1 = fneg float %a
+ %ret = fsub nsz float 0.0, %t1
ret float %ret
}
@@ -239,12 +237,10 @@
define <2 x float> @fneg_x_vec_undef1(<2 x float> %a) {
; CHECK-LABEL: @fneg_x_vec_undef1(
-; CHECK-NEXT: [[T1:%.*]] = fsub <2 x float> <float 0.000000e+00, float undef>, [[A:%.*]]
-; CHECK-NEXT: [[RET:%.*]] = fneg nsz <2 x float> [[T1]]
-; CHECK-NEXT: ret <2 x float> [[RET]]
+; CHECK-NEXT: ret <2 x float> [[A:%.*]]
;
- %t1 = fsub <2 x float> <float 0.0, float undef>, %a
- %ret = fneg nsz <2 x float> %t1
+ %t1 = fneg <2 x float> %a
+ %ret = fsub nsz <2 x float> <float 0.0, float undef>, %t1
ret <2 x float> %ret
}
Index: llvm/lib/Analysis/InstructionSimplify.cpp
===================================================================
--- llvm/lib/Analysis/InstructionSimplify.cpp
+++ llvm/lib/Analysis/InstructionSimplify.cpp
@@ -4369,9 +4369,10 @@
match(Op1, m_FSub(m_NegZeroFP(), m_Value(X))))
return X;
- // fsub 0.0, (fsub 0.0, X) ==> X if signed zeros are ignored.
+ // fsub 0.0, (fneg X) ==> X if signed zeros are ignored.
if (FMF.noSignedZeros() && match(Op0, m_AnyZeroFP()) &&
- match(Op1, m_FSub(m_AnyZeroFP(), m_Value(X))))
+ (match(Op1, m_FSub(m_AnyZeroFP(), m_Value(X))) ||
+ match(Op1, m_FNeg(m_Value(X)))))
return X;
// fsub nnan x, x ==> 0.0
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D62013.199850.patch
Type: text/x-patch
Size: 1924 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190516/f03a9e91/attachment.bin>
More information about the llvm-commits
mailing list