Skip to content

Commit 946fd4e

Browse files
committed
Revert "[InstCombine] Remove nnan requirement for transformation to fabs from select"
This reverts commit 6180ce2.
1 parent d992606 commit 946fd4e

File tree

2 files changed

+25
-13
lines changed

2 files changed

+25
-13
lines changed

llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -2863,20 +2863,22 @@ Instruction *InstCombinerImpl::visitSelectInst(SelectInst &SI) {
28632863
}
28642864

28652865
// Canonicalize select with fcmp to fabs(). -0.0 makes this tricky. We need
2866-
// fast-math-flags (nsz) or fsub with +0.0 (not fneg) for this to work.
2866+
// fast-math-flags (nsz) or fsub with +0.0 (not fneg) for this to work. We
2867+
// also require nnan because we do not want to unintentionally change the
2868+
// sign of a NaN value.
28672869
// (X <= +/-0.0) ? (0.0 - X) : X --> fabs(X)
28682870
Instruction *FSub;
28692871
if (match(CondVal, m_FCmp(Pred, m_Specific(FalseVal), m_AnyZeroFP())) &&
28702872
match(TrueVal, m_FSub(m_PosZeroFP(), m_Specific(FalseVal))) &&
2871-
match(TrueVal, m_Instruction(FSub)) &&
2873+
match(TrueVal, m_Instruction(FSub)) && FSub->hasNoNaNs() &&
28722874
(Pred == FCmpInst::FCMP_OLE || Pred == FCmpInst::FCMP_ULE)) {
28732875
Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, &SI);
28742876
return replaceInstUsesWith(SI, Fabs);
28752877
}
28762878
// (X > +/-0.0) ? X : (0.0 - X) --> fabs(X)
28772879
if (match(CondVal, m_FCmp(Pred, m_Specific(TrueVal), m_AnyZeroFP())) &&
28782880
match(FalseVal, m_FSub(m_PosZeroFP(), m_Specific(TrueVal))) &&
2879-
match(FalseVal, m_Instruction(FSub)) &&
2881+
match(FalseVal, m_Instruction(FSub)) && FSub->hasNoNaNs() &&
28802882
(Pred == FCmpInst::FCMP_OGT || Pred == FCmpInst::FCMP_UGT)) {
28812883
Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, &SI);
28822884
return replaceInstUsesWith(SI, Fabs);
@@ -2887,7 +2889,8 @@ Instruction *InstCombinerImpl::visitSelectInst(SelectInst &SI) {
28872889
Instruction *FNeg;
28882890
if (match(CondVal, m_FCmp(Pred, m_Specific(FalseVal), m_AnyZeroFP())) &&
28892891
match(TrueVal, m_FNeg(m_Specific(FalseVal))) &&
2890-
match(TrueVal, m_Instruction(FNeg)) && SI.hasNoSignedZeros() &&
2892+
match(TrueVal, m_Instruction(FNeg)) && FNeg->hasNoNaNs() &&
2893+
FNeg->hasNoSignedZeros() && SI.hasNoSignedZeros() &&
28912894
(Pred == FCmpInst::FCMP_OLT || Pred == FCmpInst::FCMP_OLE ||
28922895
Pred == FCmpInst::FCMP_ULT || Pred == FCmpInst::FCMP_ULE)) {
28932896
Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, FalseVal, &SI);
@@ -2898,7 +2901,8 @@ Instruction *InstCombinerImpl::visitSelectInst(SelectInst &SI) {
28982901
// (X >= +/-0.0) ? X : -X --> fabs(X)
28992902
if (match(CondVal, m_FCmp(Pred, m_Specific(TrueVal), m_AnyZeroFP())) &&
29002903
match(FalseVal, m_FNeg(m_Specific(TrueVal))) &&
2901-
match(FalseVal, m_Instruction(FNeg)) && SI.hasNoSignedZeros() &&
2904+
match(FalseVal, m_Instruction(FNeg)) && FNeg->hasNoNaNs() &&
2905+
FNeg->hasNoSignedZeros() && SI.hasNoSignedZeros() &&
29022906
(Pred == FCmpInst::FCMP_OGT || Pred == FCmpInst::FCMP_OGE ||
29032907
Pred == FCmpInst::FCMP_UGT || Pred == FCmpInst::FCMP_UGE)) {
29042908
Value *Fabs = Builder.CreateUnaryIntrinsic(Intrinsic::fabs, TrueVal, &SI);

llvm/test/Transforms/InstCombine/fabs.ll

Lines changed: 16 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -254,8 +254,10 @@ define double @multi_use_fabs_fpext(float %x) {
254254

255255
define double @select_fcmp_ole_zero(double %x) {
256256
; CHECK-LABEL: @select_fcmp_ole_zero(
257-
; CHECK-NEXT: [[TMP1:%.*]] = call double @llvm.fabs.f64(double [[X:%.*]])
258-
; CHECK-NEXT: ret double [[TMP1]]
257+
; CHECK-NEXT: [[LEZERO:%.*]] = fcmp ole double [[X:%.*]], 0.000000e+00
258+
; CHECK-NEXT: [[NEGX:%.*]] = fsub double 0.000000e+00, [[X]]
259+
; CHECK-NEXT: [[FABS:%.*]] = select i1 [[LEZERO]], double [[NEGX]], double [[X]]
260+
; CHECK-NEXT: ret double [[FABS]]
259261
;
260262
%lezero = fcmp ole double %x, 0.0
261263
%negx = fsub double 0.0, %x
@@ -343,8 +345,10 @@ define <2 x float> @select_nnan_fcmp_nnan_ole_negzero(<2 x float> %x) {
343345

344346
define fp128 @select_fcmp_ogt_zero(fp128 %x) {
345347
; CHECK-LABEL: @select_fcmp_ogt_zero(
346-
; CHECK-NEXT: [[TMP1:%.*]] = call fp128 @llvm.fabs.f128(fp128 [[X:%.*]])
347-
; CHECK-NEXT: ret fp128 [[TMP1]]
348+
; CHECK-NEXT: [[GTZERO:%.*]] = fcmp ogt fp128 [[X:%.*]], 0xL00000000000000000000000000000000
349+
; CHECK-NEXT: [[NEGX:%.*]] = fsub fp128 0xL00000000000000000000000000000000, [[X]]
350+
; CHECK-NEXT: [[FABS:%.*]] = select i1 [[GTZERO]], fp128 [[X]], fp128 [[NEGX]]
351+
; CHECK-NEXT: ret fp128 [[FABS]]
348352
;
349353
%gtzero = fcmp ogt fp128 %x, zeroinitializer
350354
%negx = fsub fp128 zeroinitializer, %x
@@ -430,8 +434,10 @@ define half @select_fcmp_nnan_oge_negzero(half %x) {
430434

431435
define double @select_fcmp_olt_zero_unary_fneg(double %x) {
432436
; CHECK-LABEL: @select_fcmp_olt_zero_unary_fneg(
433-
; CHECK-NEXT: [[TMP1:%.*]] = call nsz double @llvm.fabs.f64(double [[X:%.*]])
434-
; CHECK-NEXT: ret double [[TMP1]]
437+
; CHECK-NEXT: [[LTZERO:%.*]] = fcmp olt double [[X:%.*]], 0.000000e+00
438+
; CHECK-NEXT: [[NEGX:%.*]] = fneg double [[X]]
439+
; CHECK-NEXT: [[FABS:%.*]] = select nsz i1 [[LTZERO]], double [[NEGX]], double [[X]]
440+
; CHECK-NEXT: ret double [[FABS]]
435441
;
436442
%ltzero = fcmp olt double %x, 0.0
437443
%negx = fneg double %x
@@ -717,8 +723,10 @@ define float @select_fcmp_nnan_nsz_ule_negzero_unary_fneg(float %x) {
717723

718724
define <2 x float> @select_fcmp_ogt_zero_unary_fneg(<2 x float> %x) {
719725
; CHECK-LABEL: @select_fcmp_ogt_zero_unary_fneg(
720-
; CHECK-NEXT: [[TMP1:%.*]] = call nsz <2 x float> @llvm.fabs.v2f32(<2 x float> [[X:%.*]])
721-
; CHECK-NEXT: ret <2 x float> [[TMP1]]
726+
; CHECK-NEXT: [[GTZERO:%.*]] = fcmp ogt <2 x float> [[X:%.*]], zeroinitializer
727+
; CHECK-NEXT: [[NEGX:%.*]] = fneg <2 x float> [[X]]
728+
; CHECK-NEXT: [[FABS:%.*]] = select nsz <2 x i1> [[GTZERO]], <2 x float> [[X]], <2 x float> [[NEGX]]
729+
; CHECK-NEXT: ret <2 x float> [[FABS]]
722730
;
723731
%gtzero = fcmp ogt <2 x float> %x, zeroinitializer
724732
%negx = fneg <2 x float> %x

0 commit comments

Comments
 (0)