From: Cameron McInally Date: Fri, 10 May 2019 20:01:04 +0000 (+0000) Subject: Add InstCombine::visitFNeg(...) X-Git-Tag: llvmorg-10-init~5794 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=e75412ab4748201328138078c27f1c9bad4b8b79;p=platform%2Fupstream%2Fllvm.git Add InstCombine::visitFNeg(...) Differential Revision: https://reviews.llvm.org/D61784 llvm-svn: 360461 --- diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp index a231380..5f5a94e 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp @@ -1821,6 +1821,15 @@ Instruction *InstCombiner::visitSub(BinaryOperator &I) { return Changed ? &I : nullptr; } +Instruction *InstCombiner::visitFNeg(UnaryOperator &I) { + if (Value *V = SimplifyFNegInst(I.getOperand(0), I.getFastMathFlags(), + SQ.getWithInstruction(&I))) + return replaceInstUsesWith(I, V); + + return nullptr; +} + + Instruction *InstCombiner::visitFSub(BinaryOperator &I) { if (Value *V = SimplifyFSubInst(I.getOperand(0), I.getOperand(1), I.getFastMathFlags(), diff --git a/llvm/lib/Transforms/InstCombine/InstCombineInternal.h b/llvm/lib/Transforms/InstCombine/InstCombineInternal.h index 27b8ea8..c34a71a 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineInternal.h +++ b/llvm/lib/Transforms/InstCombine/InstCombineInternal.h @@ -347,6 +347,7 @@ public: // I - Change was made, I is still valid, I may be dead though // otherwise - Change was made, replace I with returned instruction // + Instruction *visitFNeg(UnaryOperator &I); Instruction *visitAdd(BinaryOperator &I); Instruction *visitFAdd(BinaryOperator &I); Value *OptimizePointerDifference(Value *LHS, Value *RHS, Type *Ty); diff --git a/llvm/test/Transforms/InstCombine/fneg.ll b/llvm/test/Transforms/InstCombine/fneg.ll index 6c1fb11..2fdb194 100644 --- a/llvm/test/Transforms/InstCombine/fneg.ll +++ b/llvm/test/Transforms/InstCombine/fneg.ll @@ -6,9 +6,7 @@ declare void @use(float) define float @fneg_fneg(float %a) { ; ; CHECK-LABEL: @fneg_fneg( -; CHECK-NEXT: [[F:%.*]] = fneg float [[A:%.*]] -; CHECK-NEXT: [[R:%.*]] = fneg float [[F]] -; CHECK-NEXT: ret float [[R]] +; CHECK-NEXT: ret float [[A:%.*]] ; %f = fneg float %a %r = fneg float %f