diff options
author | Sanjay Patel <spatel@rotateright.com> | 2019-06-09 13:58:46 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2019-06-09 13:58:46 +0000 |
commit | 866db10228459f758fd703b39d7bb6d1647a326c (patch) | |
tree | d06e4a5c12be5807bd41065dbafb8a85028c671e /llvm/lib/Analysis/InstructionSimplify.cpp | |
parent | 73f5a855b33358b6d44b91d9ac6199a9ce2ba1b6 (diff) | |
download | bcm5719-llvm-866db10228459f758fd703b39d7bb6d1647a326c.tar.gz bcm5719-llvm-866db10228459f758fd703b39d7bb6d1647a326c.zip |
[InstSimplify] reduce code duplication for fcmp folds; NFC
llvm-svn: 362904
Diffstat (limited to 'llvm/lib/Analysis/InstructionSimplify.cpp')
-rw-r--r-- | llvm/lib/Analysis/InstructionSimplify.cpp | 17 |
1 files changed, 7 insertions, 10 deletions
diff --git a/llvm/lib/Analysis/InstructionSimplify.cpp b/llvm/lib/Analysis/InstructionSimplify.cpp index ad9d40b6c12..d0b9549d3ae 100644 --- a/llvm/lib/Analysis/InstructionSimplify.cpp +++ b/llvm/lib/Analysis/InstructionSimplify.cpp @@ -3477,22 +3477,19 @@ static Value *SimplifyFCmpInst(unsigned Predicate, Value *LHS, Value *RHS, if (match(RHS, m_AnyZeroFP())) { switch (Pred) { case FCmpInst::FCMP_OGE: - if ((FMF.noNaNs() || isKnownNeverNaN(LHS, Q.TLI)) && - CannotBeOrderedLessThanZero(LHS, Q.TLI)) - return getTrue(RetTy); - break; - case FCmpInst::FCMP_UGE: - if (CannotBeOrderedLessThanZero(LHS, Q.TLI)) - return getTrue(RetTy); - break; case FCmpInst::FCMP_ULT: + // Positive or zero X >= 0.0 --> true + // Positive or zero X < 0.0 --> false if ((FMF.noNaNs() || isKnownNeverNaN(LHS, Q.TLI)) && CannotBeOrderedLessThanZero(LHS, Q.TLI)) - return getFalse(RetTy); + return Pred == FCmpInst::FCMP_OGE ? getTrue(RetTy) : getFalse(RetTy); break; + case FCmpInst::FCMP_UGE: case FCmpInst::FCMP_OLT: + // Positive or zero or nan X >= 0.0 --> true + // Positive or zero or nan X < 0.0 --> false if (CannotBeOrderedLessThanZero(LHS, Q.TLI)) - return getFalse(RetTy); + return Pred == FCmpInst::FCMP_UGE ? getTrue(RetTy) : getFalse(RetTy); break; default: break; |