[llvm] [InstCombine] Fold expression using basic properties of floor and ceiling function (PR #107107)
Yingwei Zheng via llvm-commits
llvm-commits at lists.llvm.org
Mon Sep 9 18:18:49 PDT 2024
================
@@ -8178,6 +8178,81 @@ static Instruction *foldFCmpFSubIntoFCmp(FCmpInst &I, Instruction *LHSI,
return nullptr;
}
+static Instruction *foldFCmpWithFloorAndCeil(FCmpInst &I,
+ InstCombinerImpl &CI) {
+ Value *LHS = I.getOperand(0), *RHS = I.getOperand(1);
+ Type *OpType = LHS->getType();
+ CmpInst::Predicate Pred = I.getPredicate();
+
+ bool FloorX = match(LHS, m_Intrinsic<Intrinsic::floor>(m_Specific(RHS)));
+ bool CeilX = match(LHS, m_Intrinsic<Intrinsic::ceil>(m_Specific(RHS)));
+
+ if (!FloorX && !CeilX) {
+ if ((FloorX = match(RHS, m_Intrinsic<Intrinsic::floor>(m_Specific(LHS)))) ||
+ (CeilX = match(RHS, m_Intrinsic<Intrinsic::ceil>(m_Specific(LHS))))) {
+ std::swap(LHS, RHS);
+ Pred = I.getSwappedPredicate();
+ }
+ }
+
+ switch (Pred) {
+ case FCmpInst::FCMP_OLE:
+ // fcmp ole floor(x), x => fcmp ord x, 0
+ if (FloorX)
+ return new FCmpInst(FCmpInst::FCMP_ORD, RHS, ConstantFP::getZero(OpType),
+ "", &I);
+ break;
+ case FCmpInst::FCMP_OGT:
+ // fcmp ogt floor(x), x => false
+ if (FloorX)
+ return CI.replaceInstUsesWith(I, ConstantInt::getFalse(I.getType()));
+ break;
+ case FCmpInst::FCMP_OGE:
+ // fcmp oge ceil(x), x => fcmp ord x, 0
+ if (CeilX)
+ return new FCmpInst(FCmpInst::FCMP_ORD, RHS, ConstantFP::getZero(OpType),
+ "", &I);
+ break;
+ case FCmpInst::FCMP_OLT:
+ // fcmp olt ceil(x), x => false
+ if (CeilX)
+ return CI.replaceInstUsesWith(I, ConstantInt::getFalse(I.getType()));
+ break;
+ case FCmpInst::FCMP_ULE:
+ // fcmp ule floor(x), x => fcmp ule -inf, x
+ if (FloorX)
+ return new FCmpInst(FCmpInst::FCMP_ULE,
+ ConstantFP::getInfinity(RHS->getType(), true), RHS,
+ "", &I);
+ break;
+ case FCmpInst::FCMP_UGT:
+ // fcmp ugt floor(x), x => fcmp ugt -inf, x
----------------
dtcxzyw wrote:
I mean you should modify both the comment and the transform below.
https://github.com/llvm/llvm-project/pull/107107
More information about the llvm-commits
mailing list