diff --git a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp --- a/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineAddSub.cpp @@ -1821,6 +1821,15 @@ 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 --- a/llvm/lib/Transforms/InstCombine/InstCombineInternal.h +++ b/llvm/lib/Transforms/InstCombine/InstCombineInternal.h @@ -347,6 +347,7 @@ // 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 --- a/llvm/test/Transforms/InstCombine/fneg.ll +++ b/llvm/test/Transforms/InstCombine/fneg.ll @@ -6,9 +6,7 @@ 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