diff options
author | Sanjay Patel <spatel@rotateright.com> | 2019-07-29 13:20:46 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2019-07-29 13:20:46 +0000 |
commit | 5483f4225ee3ab61c417f92b9b15a642ff56487e (patch) | |
tree | 64f3ca4a7a87e62f56353f89f46a34b12265152f /llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp | |
parent | 74c35bd6b0ecec737d73c5ca7d2611df66469da5 (diff) | |
download | bcm5719-llvm-5483f4225ee3ab61c417f92b9b15a642ff56487e.tar.gz bcm5719-llvm-5483f4225ee3ab61c417f92b9b15a642ff56487e.zip |
[InstCombine] reduce code for fadd with fneg operand; NFC
llvm-svn: 367224
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp')
-rw-r--r-- | llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp index 9363a5e63e9..79d9ddde569 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp @@ -1382,17 +1382,14 @@ Instruction *InstCombiner::visitFAdd(BinaryOperator &I) { if (Instruction *FoldedFAdd = foldBinOpIntoSelectOrPhi(I)) return FoldedFAdd; - Value *LHS = I.getOperand(0), *RHS = I.getOperand(1); - Value *X; // (-X) + Y --> Y - X - if (match(LHS, m_FNeg(m_Value(X)))) - return BinaryOperator::CreateFSubFMF(RHS, X, &I); - // Y + (-X) --> Y - X - if (match(RHS, m_FNeg(m_Value(X)))) - return BinaryOperator::CreateFSubFMF(LHS, X, &I); + Value *X, *Y; + if (match(&I, m_c_FAdd(m_FNeg(m_Value(X)), m_Value(Y)))) + return BinaryOperator::CreateFSubFMF(Y, X, &I); // Check for (fadd double (sitofp x), y), see if we can merge this into an // integer add followed by a promotion. + Value *LHS = I.getOperand(0), *RHS = I.getOperand(1); if (SIToFPInst *LHSConv = dyn_cast<SIToFPInst>(LHS)) { Value *LHSIntVal = LHSConv->getOperand(0); Type *FPType = LHSConv->getType(); |