[llvm] [ValueTracking] Add missing check for two-value PN recurrance matching (PR #152700)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 8 06:24:19 PDT 2025
================
@@ -1310,6 +1310,37 @@ TEST_F(ValueTrackingTest, MatchBinaryIntrinsicRecurrenceNegativeFSHR) {
EXPECT_FALSE(matchSimpleBinaryIntrinsicRecurrence(II, PN, Init, OtherOp));
}
+TEST_F(ValueTrackingTest, MatchBinaryIntrinsicRecurrenceNonTwoOperand) {
+ auto M = parseModule(R"(
+ declare noundef i32 @llvm.nvvm.read.ptx.sreg.nctaid.x()
+ declare i32 @llvm.umin.i32(i32, i32)
+
+ define void @foo(i32 %arg) {
+ bb:
+ br i1 false, label %bb1, label %bb2
+
+ bb1: ; preds = %bb
+ br label %bb3
+
+ bb2: ; preds = %bb
+ %i = tail call noundef i32 @llvm.nvvm.read.ptx.sreg.nctaid.x()
+ br label %bb3
+
+ bb3: ; preds = %bb2, %bb1
+ %i4 = phi i32 [ 0, %bb1 ], [ %i, %bb2 ]
+ %i6 = tail call noundef i32 @llvm.umin.i32(i32 %i4, i32 %arg)
+ ret void
+ }
+ )");
----------------
nikic wrote:
Is it possible to reproduce the issue with a lit test? That would be better than a unit test.
https://github.com/llvm/llvm-project/pull/152700
More information about the llvm-commits
mailing list