diff --git a/llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp b/llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp --- a/llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp @@ -2859,7 +2859,12 @@ match(TrueVal, m_FSub(m_PosZeroFP(), m_Specific(FalseVal))) && match(TrueVal, m_Instruction(FSub)) && FSub->hasNoNaNs() && (Pred == FCmpInst::FCMP_OLE || Pred == FCmpInst::FCMP_ULE)) { - Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, FSub); + Instruction *Fabs = + Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, FSub); + if (!SI.hasNoNaNs()) + Fabs->setHasNoNaNs(false); + if (!SI.hasNoInfs()) + Fabs->setHasNoInfs(false); return replaceInstUsesWith(SI, Fabs); } // (X > +/-0.0) ? X : (0.0 - X) --> fabs(X) @@ -2867,7 +2872,12 @@ match(FalseVal, m_FSub(m_PosZeroFP(), m_Specific(TrueVal))) && match(FalseVal, m_Instruction(FSub)) && FSub->hasNoNaNs() && (Pred == FCmpInst::FCMP_OGT || Pred == FCmpInst::FCMP_UGT)) { - Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, FSub); + Instruction *Fabs = + Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, FSub); + if (!SI.hasNoNaNs()) + Fabs->setHasNoNaNs(false); + if (!SI.hasNoInfs()) + Fabs->setHasNoInfs(false); return replaceInstUsesWith(SI, Fabs); } // With nnan and nsz: @@ -2880,7 +2890,12 @@ FNeg->hasNoNaNs() && FNeg->hasNoSignedZeros() && (Pred == FCmpInst::FCMP_OLT || Pred == FCmpInst::FCMP_OLE || Pred == FCmpInst::FCMP_ULT || Pred == FCmpInst::FCMP_ULE)) { - Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, FNeg); + Instruction *Fabs = + Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, FNeg); + if (!SI.hasNoNaNs()) + Fabs->setHasNoNaNs(false); + if (!SI.hasNoInfs()) + Fabs->setHasNoInfs(false); return replaceInstUsesWith(SI, Fabs); } // With nnan and nsz: @@ -2892,7 +2907,12 @@ FNeg->hasNoNaNs() && FNeg->hasNoSignedZeros() && (Pred == FCmpInst::FCMP_OGT || Pred == FCmpInst::FCMP_OGE || Pred == FCmpInst::FCMP_UGT || Pred == FCmpInst::FCMP_UGE)) { - Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, FNeg); + Instruction *Fabs = + Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, FNeg); + if (!SI.hasNoNaNs()) + Fabs->setHasNoNaNs(false); + if (!SI.hasNoInfs()) + Fabs->setHasNoInfs(false); return replaceInstUsesWith(SI, Fabs); } diff --git a/llvm/test/Transforms/InstCombine/fabs.ll b/llvm/test/Transforms/InstCombine/fabs.ll --- a/llvm/test/Transforms/InstCombine/fabs.ll +++ b/llvm/test/Transforms/InstCombine/fabs.ll @@ -269,7 +269,7 @@ define double @select_fcmp_nnan_ole_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_ole_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ole double %x, 0.0 @@ -278,11 +278,35 @@ ret double %fabs } +; nnan, ninf flag is propagted to fabs if present in select. + +define double @select_nnan_fcmp_nnan_ole_zero(double %x) { +; CHECK-LABEL: @select_nnan_fcmp_nnan_ole_zero( +; CHECK-NEXT: [[TMP1:%.*]] = call nnan double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: ret double [[TMP1]] +; + %lezero = fcmp ole double %x, 0.0 + %negx = fsub nnan double 0.0, %x + %fabs = select nnan i1 %lezero, double %negx, double %x + ret double %fabs +} + +define double @select_nnan_ninf_fcmp_nnan_ninf_ole_zero(double %x) { +; CHECK-LABEL: @select_nnan_ninf_fcmp_nnan_ninf_ole_zero( +; CHECK-NEXT: [[TMP1:%.*]] = call nnan ninf double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: ret double [[TMP1]] +; + %lezero = fcmp ole double %x, 0.0 + %negx = fsub nnan ninf double 0.0, %x + %fabs = select nnan ninf i1 %lezero, double %negx, double %x + ret double %fabs +} + ; Repeat with unordered predicate - nnan allows us to treat ordered/unordered identically. define double @select_fcmp_nnan_ule_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_ule_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ule double %x, 0.0 @@ -310,7 +334,7 @@ define <2 x float> @select_fcmp_nnan_ole_negzero(<2 x float> %x) { ; CHECK-LABEL: @select_fcmp_nnan_ole_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) ; CHECK-NEXT: ret <2 x float> [[TMP1]] ; %lezero = fcmp ole <2 x float> %x, @@ -323,7 +347,7 @@ define fp128 @select_fcmp_nnan_ogt_zero(fp128 %x) { ; CHECK-LABEL: @select_fcmp_nnan_ogt_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan fp128 @llvm.fabs.f128(fp128 [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call fp128 @llvm.fabs.f128(fp128 [[X:%.*]]) ; CHECK-NEXT: ret fp128 [[TMP1]] ; %gtzero = fcmp ogt fp128 %x, zeroinitializer @@ -336,7 +360,7 @@ define half @select_fcmp_nnan_ogt_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_ogt_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gtzero = fcmp ogt half %x, -0.0 @@ -349,7 +373,7 @@ define half @select_fcmp_nnan_ugt_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_ugt_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gtzero = fcmp ugt half %x, -0.0 @@ -377,7 +401,7 @@ define double @select_fcmp_nnan_nsz_olt_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_olt_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %ltzero = fcmp olt double %x, 0.0 @@ -390,7 +414,7 @@ define double @select_fcmp_nnan_nsz_ult_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ult_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %ltzero = fcmp ult double %x, 0.0 @@ -401,7 +425,7 @@ define double @select_fcmp_nnan_nsz_olt_zero_unary_fneg(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_olt_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %ltzero = fcmp olt double %x, 0.0 @@ -414,7 +438,7 @@ define double @select_fcmp_nnan_nsz_ult_zero_unary_fneg(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ult_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %ltzero = fcmp ult double %x, 0.0 @@ -427,7 +451,7 @@ define float @select_fcmp_nnan_nsz_olt_negzero(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_olt_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan ninf nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %ltzero = fcmp olt float %x, -0.0 @@ -440,7 +464,7 @@ define float @select_fcmp_nnan_nsz_ult_negzero(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ult_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan ninf nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %ltzero = fcmp ult float %x, -0.0 @@ -451,7 +475,7 @@ define float @select_fcmp_nnan_nsz_olt_negzero_unary_fneg(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_olt_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan ninf nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %ltzero = fcmp olt float %x, -0.0 @@ -464,7 +488,7 @@ define float @select_fcmp_nnan_nsz_ult_negzero_unary_fneg(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ult_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan ninf nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %ltzero = fcmp ult float %x, -0.0 @@ -477,7 +501,7 @@ define double @select_fcmp_nnan_nsz_ole_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ole_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ole double %x, 0.0 @@ -490,7 +514,7 @@ define double @select_fcmp_nnan_nsz_ule_zero(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ule_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ule double %x, 0.0 @@ -501,7 +525,7 @@ define double @select_fcmp_nnan_nsz_ole_zero_unary_fneg(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ole_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ole double %x, 0.0 @@ -514,7 +538,7 @@ define double @select_fcmp_nnan_nsz_ule_zero_unary_fneg(double %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ule_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call fast double @llvm.fabs.f64(double [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn double @llvm.fabs.f64(double [[X:%.*]]) ; CHECK-NEXT: ret double [[TMP1]] ; %lezero = fcmp ule double %x, 0.0 @@ -527,7 +551,7 @@ define float @select_fcmp_nnan_nsz_ole_negzero(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ole_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %lezero = fcmp ole float %x, -0.0 @@ -540,7 +564,7 @@ define float @select_fcmp_nnan_nsz_ule_negzero(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ule_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %lezero = fcmp ule float %x, -0.0 @@ -551,7 +575,7 @@ define float @select_fcmp_nnan_nsz_ole_negzero_unary_fneg(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ole_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %lezero = fcmp ole float %x, -0.0 @@ -564,7 +588,7 @@ define float @select_fcmp_nnan_nsz_ule_negzero_unary_fneg(float %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ule_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz float @llvm.fabs.f32(float [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz float @llvm.fabs.f32(float [[X:%.*]]) ; CHECK-NEXT: ret float [[TMP1]] ; %lezero = fcmp ule float %x, -0.0 @@ -577,7 +601,7 @@ define <2 x float> @select_fcmp_nnan_nsz_ogt_zero(<2 x float> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ogt_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) ; CHECK-NEXT: ret <2 x float> [[TMP1]] ; %gtzero = fcmp ogt <2 x float> %x, zeroinitializer @@ -590,7 +614,7 @@ define <2 x float> @select_fcmp_nnan_nsz_ugt_zero(<2 x float> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ugt_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) ; CHECK-NEXT: ret <2 x float> [[TMP1]] ; %gtzero = fcmp ugt <2 x float> %x, zeroinitializer @@ -601,7 +625,7 @@ define <2 x float> @select_fcmp_nnan_nsz_ogt_zero_unary_fneg(<2 x float> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ogt_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) ; CHECK-NEXT: ret <2 x float> [[TMP1]] ; %gtzero = fcmp ogt <2 x float> %x, zeroinitializer @@ -614,7 +638,7 @@ define <2 x float> @select_fcmp_nnan_nsz_ugt_zero_unary_fneg(<2 x float> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ugt_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz arcp <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]]) ; CHECK-NEXT: ret <2 x float> [[TMP1]] ; %gtzero = fcmp ugt <2 x float> %x, zeroinitializer @@ -627,7 +651,7 @@ define half @select_fcmp_nnan_nsz_ogt_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ogt_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call fast half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gtzero = fcmp ogt half %x, -0.0 @@ -640,7 +664,7 @@ define half @select_fcmp_nnan_nsz_ugt_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_ugt_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call fast half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz arcp contract afn half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gtzero = fcmp ugt half %x, -0.0 @@ -653,7 +677,7 @@ define <2 x double> @select_fcmp_nnan_nsz_oge_zero(<2 x double> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_oge_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nnan nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) ; CHECK-NEXT: ret <2 x double> [[TMP1]] ; %gezero = fcmp oge <2 x double> %x, zeroinitializer @@ -666,7 +690,7 @@ define <2 x double> @select_fcmp_nnan_nsz_uge_zero(<2 x double> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_uge_zero( -; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nnan nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) ; CHECK-NEXT: ret <2 x double> [[TMP1]] ; %gezero = fcmp uge <2 x double> %x, zeroinitializer @@ -677,7 +701,7 @@ define <2 x double> @select_fcmp_nnan_nsz_oge_zero_unary_fneg(<2 x double> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_oge_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nnan nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) ; CHECK-NEXT: ret <2 x double> [[TMP1]] ; %gezero = fcmp oge <2 x double> %x, zeroinitializer @@ -690,7 +714,7 @@ define <2 x double> @select_fcmp_nnan_nsz_uge_zero_unary_fneg(<2 x double> %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_uge_zero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nnan nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call reassoc nsz <2 x double> @llvm.fabs.v2f64(<2 x double> [[X:%.*]]) ; CHECK-NEXT: ret <2 x double> [[TMP1]] ; %gezero = fcmp uge <2 x double> %x, zeroinitializer @@ -703,7 +727,7 @@ define half @select_fcmp_nnan_nsz_oge_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_oge_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gezero = fcmp oge half %x, -0.0 @@ -716,7 +740,7 @@ define half @select_fcmp_nnan_nsz_uge_negzero(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_uge_negzero( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gezero = fcmp uge half %x, -0.0 @@ -727,7 +751,7 @@ define half @select_fcmp_nnan_nsz_oge_negzero_unary_fneg(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_oge_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gezero = fcmp oge half %x, -0.0 @@ -740,7 +764,7 @@ define half @select_fcmp_nnan_nsz_uge_negzero_unary_fneg(half %x) { ; CHECK-LABEL: @select_fcmp_nnan_nsz_uge_negzero_unary_fneg( -; CHECK-NEXT: [[TMP1:%.*]] = call nnan nsz half @llvm.fabs.f16(half [[X:%.*]]) +; CHECK-NEXT: [[TMP1:%.*]] = call nsz half @llvm.fabs.f16(half [[X:%.*]]) ; CHECK-NEXT: ret half [[TMP1]] ; %gezero = fcmp uge half %x, -0.0