[llvm] 72768d9 - [ConstraintElim] Teach checkAndReplaceCondition about samesign (#128168)
via llvm-commits
llvm-commits at lists.llvm.org
Mon Feb 24 05:07:51 PST 2025
Author: Marina Taylor
Date: 2025-02-24T13:07:47Z
New Revision: 72768d9bb8ad3e97a852270726f04d7167d9ef50
URL: https://github.com/llvm/llvm-project/commit/72768d9bb8ad3e97a852270726f04d7167d9ef50
DIFF: https://github.com/llvm/llvm-project/commit/72768d9bb8ad3e97a852270726f04d7167d9ef50.diff
LOG: [ConstraintElim] Teach checkAndReplaceCondition about samesign (#128168)
`samesign upred` is equivalent to `spred`:
https://alive2.llvm.org/ce/z/57iaEC
Added:
Modified:
llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
llvm/test/Transforms/ConstraintElimination/transfer-samesign-facts.ll
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp b/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
index 6dd26910f6846..79f6858463d7e 100644
--- a/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
+++ b/llvm/lib/Transforms/Scalar/ConstraintElimination.cpp
@@ -1427,7 +1427,7 @@ static std::optional<bool> checkCondition(CmpInst::Predicate Pred, Value *A,
}
static bool checkAndReplaceCondition(
- CmpInst *Cmp, ConstraintInfo &Info, unsigned NumIn, unsigned NumOut,
+ ICmpInst *Cmp, ConstraintInfo &Info, unsigned NumIn, unsigned NumOut,
Instruction *ContextInst, Module *ReproducerModule,
ArrayRef<ReproducerEntry> ReproducerCondStack, DominatorTree &DT,
SmallVectorImpl<Instruction *> &ToRemove) {
@@ -1460,6 +1460,15 @@ static bool checkAndReplaceCondition(
checkCondition(Cmp->getPredicate(), Cmp->getOperand(0),
Cmp->getOperand(1), Cmp, Info))
return ReplaceCmpWithConstant(Cmp, *ImpliedCondition);
+
+ // When the predicate is samesign and unsigned, we can also make use of the
+ // signed predicate information.
+ if (Cmp->hasSameSign() && Cmp->isUnsigned())
+ if (auto ImpliedCondition =
+ checkCondition(Cmp->getSignedPredicate(), Cmp->getOperand(0),
+ Cmp->getOperand(1), Cmp, Info))
+ return ReplaceCmpWithConstant(Cmp, *ImpliedCondition);
+
return false;
}
diff --git a/llvm/test/Transforms/ConstraintElimination/transfer-samesign-facts.ll b/llvm/test/Transforms/ConstraintElimination/transfer-samesign-facts.ll
index 1b155e050de29..44565f8d1341f 100644
--- a/llvm/test/Transforms/ConstraintElimination/transfer-samesign-facts.ll
+++ b/llvm/test/Transforms/ConstraintElimination/transfer-samesign-facts.ll
@@ -303,3 +303,64 @@ define i1 @ugt_assumed_positive_values(i8 %a, i8 %b) {
ret i1 %result
}
+
+define i1 @implied_condition_sgt_ugt(i8 %a, i8 %b) {
+; CHECK-LABEL: @implied_condition_sgt_ugt(
+; CHECK-NEXT: [[CMP_SGT:%.*]] = icmp sgt i8 [[A:%.*]], [[B:%.*]]
+; CHECK-NEXT: br i1 [[CMP_SGT]], label [[GREATER:%.*]], label [[EXIT:%.*]]
+; CHECK: greater:
+; CHECK-NEXT: ret i1 true
+; CHECK: exit:
+; CHECK-NEXT: ret i1 false
+;
+ %cmp_sgt = icmp sgt i8 %a, %b
+ br i1 %cmp_sgt, label %greater, label %exit
+
+greater:
+ %cmp_ugt = icmp samesign ugt i8 %a, %b
+ ret i1 %cmp_ugt
+
+exit:
+ ret i1 false
+}
+
+define i1 @implied_condition_sle_ule(i8 %a) {
+; CHECK-LABEL: @implied_condition_sle_ule(
+; CHECK-NEXT: [[CMP_SLE:%.*]] = icmp sle i8 [[A:%.*]], 42
+; CHECK-NEXT: br i1 [[CMP_SLE]], label [[LESS_OR_EQUAL:%.*]], label [[EXIT:%.*]]
+; CHECK: less_or_equal:
+; CHECK-NEXT: ret i1 true
+; CHECK: exit:
+; CHECK-NEXT: ret i1 false
+;
+ %cmp_sle = icmp sle i8 %a, 42
+ br i1 %cmp_sle, label %less_or_equal, label %exit
+
+less_or_equal:
+ %cmp_ule = icmp samesign ule i8 %a, 42
+ ret i1 %cmp_ule
+
+exit:
+ ret i1 false
+}
+
+define i1 @implied_condition_cannot_simplify(i8 %a, i8 %b) {
+; CHECK-LABEL: @implied_condition_cannot_simplify(
+; CHECK-NEXT: [[CMP_SGT:%.*]] = icmp ne i8 [[A:%.*]], [[B:%.*]]
+; CHECK-NEXT: br i1 [[CMP_SGT]], label [[GREATER:%.*]], label [[EXIT:%.*]]
+; CHECK: not_equal:
+; CHECK-NEXT: [[CMP_UGT:%.*]] = icmp samesign ugt i8 [[A]], [[B]]
+; CHECK-NEXT: ret i1 [[CMP_UGT]]
+; CHECK: exit:
+; CHECK-NEXT: ret i1 false
+;
+ %cmp_ne = icmp ne i8 %a, %b
+ br i1 %cmp_ne, label %not_equal, label %exit
+
+not_equal:
+ %cmp_ugt = icmp samesign ugt i8 %a, %b
+ ret i1 %cmp_ugt
+
+exit:
+ ret i1 false
+}
More information about the llvm-commits
mailing list