[llvm] 40a647f - [IndVarSimplify] Drop samesign flags after narrowing compares (#116263)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Nov 14 17:15:41 PST 2024
Author: Yingwei Zheng
Date: 2024-11-15T09:15:37+08:00
New Revision: 40a647fc7dc6048c92e2d580b61f5feca0785980
URL: https://github.com/llvm/llvm-project/commit/40a647fc7dc6048c92e2d580b61f5feca0785980
DIFF: https://github.com/llvm/llvm-project/commit/40a647fc7dc6048c92e2d580b61f5feca0785980.diff
LOG: [IndVarSimplify] Drop samesign flags after narrowing compares (#116263)
Samesign flag cannot be preserved after narrowing the compare since the
position of the sign bit is changed.
Closes https://github.com/llvm/llvm-project/issues/116249.
Added:
Modified:
llvm/lib/Transforms/Scalar/IndVarSimplify.cpp
llvm/test/Transforms/IndVarSimplify/finite-exit-comparisons.ll
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp
index 2b2d516a707934..8a3e0bc3eb9712 100644
--- a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp
+++ b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp
@@ -1530,6 +1530,8 @@ bool IndVarSimplify::canonicalizeExitCondition(Loop *L) {
L->getLoopPreheader()->getTerminator()->getIterator());
ICmp->setOperand(Swapped ? 1 : 0, LHSOp);
ICmp->setOperand(Swapped ? 0 : 1, NewRHS);
+ // Samesign flag cannot be preserved after narrowing the compare.
+ ICmp->setSameSign(false);
if (LHS->use_empty())
DeadInsts.push_back(LHS);
};
diff --git a/llvm/test/Transforms/IndVarSimplify/finite-exit-comparisons.ll b/llvm/test/Transforms/IndVarSimplify/finite-exit-comparisons.ll
index 038129e9a7cf21..3c6b12dac21191 100644
--- a/llvm/test/Transforms/IndVarSimplify/finite-exit-comparisons.ll
+++ b/llvm/test/Transforms/IndVarSimplify/finite-exit-comparisons.ll
@@ -1052,3 +1052,43 @@ for.end: ; preds = %for.body, %entry
ret void
}
+define i8 @test_drop_icmp_samesign(i1 %cond, i32 range(i32 0, 32) %x) {
+; CHECK-LABEL: @test_drop_icmp_samesign(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: br i1 [[COND:%.*]], label [[FOR_BODY_PREHEADER:%.*]], label [[ELSE:%.*]]
+; CHECK: for.body.preheader:
+; CHECK-NEXT: [[TMP0:%.*]] = trunc i32 [[X:%.*]] to i8
+; CHECK-NEXT: br label [[FOR_BODY:%.*]]
+; CHECK: else:
+; CHECK-NEXT: [[CALL1:%.*]] = call i8 @callee()
+; CHECK-NEXT: br label [[EXIT:%.*]]
+; CHECK: for.body:
+; CHECK-NEXT: [[CALL2:%.*]] = call i8 @callee()
+; CHECK-NEXT: [[COND2:%.*]] = icmp ugt i8 [[TMP0]], [[CALL2]]
+; CHECK-NEXT: br i1 [[COND2]], label [[FOR_BODY]], label [[EXIT_LOOPEXIT:%.*]]
+; CHECK: exit.loopexit:
+; CHECK-NEXT: [[CALL2_LCSSA:%.*]] = phi i8 [ [[CALL2]], [[FOR_BODY]] ]
+; CHECK-NEXT: br label [[EXIT]]
+; CHECK: exit:
+; CHECK-NEXT: [[RES:%.*]] = phi i8 [ [[CALL1]], [[ELSE]] ], [ [[CALL2_LCSSA]], [[EXIT_LOOPEXIT]] ]
+; CHECK-NEXT: ret i8 [[RES]]
+;
+entry:
+ br i1 %cond, label %for.body, label %else
+
+else:
+ %call1 = call i8 @callee()
+ br label %exit
+
+for.body:
+ %call2 = call i8 @callee()
+ %ext = zext i8 %call2 to i32
+ %cond2 = icmp samesign ugt i32 %x, %ext
+ br i1 %cond2, label %for.body, label %exit
+
+exit:
+ %res = phi i8 [ %call1, %else ], [ %call2, %for.body ]
+ ret i8 %res
+}
+
+declare i8 @callee()
More information about the llvm-commits
mailing list