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 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 }