Index: llvm/lib/Analysis/InstructionSimplify.cpp =================================================================== --- llvm/lib/Analysis/InstructionSimplify.cpp +++ llvm/lib/Analysis/InstructionSimplify.cpp @@ -4394,9 +4394,10 @@ return Op0; // fsub -0.0, (fsub -0.0, X) ==> X + // fsub -0.0, (fneg X) ==> X Value *X; if (match(Op0, m_NegZeroFP()) && - match(Op1, m_FSub(m_NegZeroFP(), m_Value(X)))) + match(Op1, m_FNeg(m_Value(X)))) return X; // fsub 0.0, (fsub 0.0, X) ==> X if signed zeros are ignored. Index: llvm/test/Transforms/InstSimplify/floating-point-arithmetic.ll =================================================================== --- llvm/test/Transforms/InstSimplify/floating-point-arithmetic.ll +++ llvm/test/Transforms/InstSimplify/floating-point-arithmetic.ll @@ -31,9 +31,7 @@ ; fsub -0.0, (fneg X) ==> X define float @fneg_x(float %a) { ; CHECK-LABEL: @fneg_x( -; CHECK-NEXT: %t1 = fneg float %a -; CHECK-NEXT: %ret = fsub float -0.000000e+00, %t1 -; CHECK-NEXT: ret float %ret +; CHECK-NEXT: ret float [[A:%.*]] ; %t1 = fneg float %a %ret = fsub float -0.0, %t1 @@ -51,9 +49,7 @@ define <2 x float> @fneg_x_vec(<2 x float> %a) { ; CHECK-LABEL: @fneg_x_vec( -; CHECK-NEXT: %t1 = fneg <2 x float> %a -; CHECK-NEXT: %ret = fsub <2 x float> , %t1 -; CHECK-NEXT: ret <2 x float> %ret +; CHECK-NEXT: ret <2 x float> [[A:%.*]] ; %t1 = fneg <2 x float> %a %ret = fsub <2 x float> , %t1 @@ -71,9 +67,7 @@ define <2 x float> @fneg_x_vec_undef_elts(<2 x float> %a) { ; CHECK-LABEL: @fneg_x_vec_undef_elts( -; CHECK-NEXT: %t1 = fneg <2 x float> %a -; CHECK-NEXT: %ret = fsub <2 x float> , %t1 -; CHECK-NEXT: ret <2 x float> %ret +; CHECK-NEXT: ret <2 x float> [[A:%.*]] ; %t1 = fneg <2 x float> %a %ret = fsub <2 x float> , %t1