[llvm] InstCombine/test: cover samesign addition to ctpop (PR #117159)
Ramkumar Ramachandra via llvm-commits
llvm-commits at lists.llvm.org
Thu Nov 21 05:18:04 PST 2024
https://github.com/artagnon created https://github.com/llvm/llvm-project/pull/117159
One of the effects of 095d49d ([InstCombine] Set `samesign` when converting signed predicates into unsigned) is that samesign flag is added to compares post a ctpop call. The tests in ispow2.ll were written prior to this, and the compares post ctpop in the IR they are testing get a samesign on them before they're operated on by the tested functions. To increase the coverage of samesign, and make the tests more faithful, add samesign-variants of some of the tests.
>From cce7d6dd9a0246b34fd960c72977c2b21ae0ef2a Mon Sep 17 00:00:00 2001
From: Ramkumar Ramachandra <ramkumar.ramachandra at codasip.com>
Date: Thu, 21 Nov 2024 12:45:50 +0000
Subject: [PATCH] InstCombine/test: cover samesign addition to ctpop
One of the effects of 095d49d ([InstCombine] Set `samesign` when
converting signed predicates into unsigned) is that samesign flag is
added to compares post a ctpop call. The tests in ispow2.ll were written
prior to this, and the compares post ctpop in the IR they are testing
get a samesign on them before they're operated on by the tested
functions. To increase the coverage of samesign, and make the tests more
faithful, add samesign-variants of some of the tests.
---
llvm/test/Transforms/InstCombine/ispow2.ll | 69 ++++++++++++++++++++++
1 file changed, 69 insertions(+)
diff --git a/llvm/test/Transforms/InstCombine/ispow2.ll b/llvm/test/Transforms/InstCombine/ispow2.ll
index df697e686d986c..0128b71f5a769f 100644
--- a/llvm/test/Transforms/InstCombine/ispow2.ll
+++ b/llvm/test/Transforms/InstCombine/ispow2.ll
@@ -461,6 +461,19 @@ define i1 @isnot_pow2_ctpop(i32 %x) {
ret i1 %r
}
+define i1 @isnot_pow2_ctpop_samesign(i32 %x) {
+; CHECK-LABEL: @isnot_pow2_ctpop_samesign(
+; CHECK-NEXT: [[T0:%.*]] = tail call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
+; CHECK-NEXT: [[R:%.*]] = icmp ne i32 [[T0]], 1
+; CHECK-NEXT: ret i1 [[R]]
+;
+ %t0 = tail call i32 @llvm.ctpop.i32(i32 %x)
+ %cmp = icmp samesign ugt i32 %t0, 1
+ %iszero = icmp eq i32 %x, 0
+ %r = or i1 %iszero, %cmp
+ ret i1 %r
+}
+
define i1 @isnot_pow2_ctpop_logical(i32 %x) {
; CHECK-LABEL: @isnot_pow2_ctpop_logical(
; CHECK-NEXT: [[T0:%.*]] = tail call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
@@ -474,6 +487,19 @@ define i1 @isnot_pow2_ctpop_logical(i32 %x) {
ret i1 %r
}
+define i1 @isnot_pow2_ctpop_logical_samesign(i32 %x) {
+; CHECK-LABEL: @isnot_pow2_ctpop_logical_samesign(
+; CHECK-NEXT: [[T0:%.*]] = tail call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
+; CHECK-NEXT: [[R:%.*]] = icmp ne i32 [[T0]], 1
+; CHECK-NEXT: ret i1 [[R]]
+;
+ %t0 = tail call i32 @llvm.ctpop.i32(i32 %x)
+ %cmp = icmp samesign ugt i32 %t0, 1
+ %iszero = icmp eq i32 %x, 0
+ %r = select i1 %iszero, i1 true, i1 %cmp
+ ret i1 %r
+}
+
; Extra uses don't change the fold.
define i1 @isnot_pow2_ctpop_extra_uses(i32 %x) {
@@ -529,6 +555,19 @@ define <2 x i1> @isnot_pow2_ctpop_commute_vec(<2 x i8> %x) {
ret <2 x i1> %r
}
+define <2 x i1> @isnot_pow2_ctpop_commute_vec_samesign(<2 x i8> %x) {
+; CHECK-LABEL: @isnot_pow2_ctpop_commute_vec_samesign(
+; CHECK-NEXT: [[T0:%.*]] = tail call range(i8 0, 9) <2 x i8> @llvm.ctpop.v2i8(<2 x i8> [[X:%.*]])
+; CHECK-NEXT: [[R:%.*]] = icmp ne <2 x i8> [[T0]], splat (i8 1)
+; CHECK-NEXT: ret <2 x i1> [[R]]
+;
+ %t0 = tail call <2 x i8> @llvm.ctpop.v2i8(<2 x i8> %x)
+ %cmp = icmp samesign ugt <2 x i8> %t0, <i8 1, i8 1>
+ %iszero = icmp eq <2 x i8> %x, zeroinitializer
+ %r = or <2 x i1> %cmp, %iszero
+ ret <2 x i1> %r
+}
+
; Negative test - wrong constant.
define i1 @isnot_pow2_ctpop_wrong_cmp_op1(i32 %x) {
@@ -1532,6 +1571,21 @@ entry:
ret i1 %sel
}
+define i1 @has_single_bit_samesign(i32 %x) {
+; CHECK-LABEL: @has_single_bit_samesign(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[POPCNT:%.*]] = call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
+; CHECK-NEXT: [[SEL:%.*]] = icmp eq i32 [[POPCNT]], 1
+; CHECK-NEXT: ret i1 [[SEL]]
+;
+entry:
+ %cmp1 = icmp ne i32 %x, 0
+ %popcnt = call range(i32 1, 33) i32 @llvm.ctpop.i32(i32 %x)
+ %cmp2 = icmp samesign ult i32 %popcnt, 2
+ %sel = select i1 %cmp1, i1 %cmp2, i1 false
+ ret i1 %sel
+}
+
define i1 @has_single_bit_inv(i32 %x) {
; CHECK-LABEL: @has_single_bit_inv(
; CHECK-NEXT: entry:
@@ -1547,6 +1601,21 @@ entry:
ret i1 %sel
}
+define i1 @has_single_bit_inv_samesign(i32 %x) {
+; CHECK-LABEL: @has_single_bit_inv_samesign(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[POPCNT:%.*]] = call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
+; CHECK-NEXT: [[SEL:%.*]] = icmp ne i32 [[POPCNT]], 1
+; CHECK-NEXT: ret i1 [[SEL]]
+;
+entry:
+ %cmp1 = icmp eq i32 %x, 0
+ %popcnt = call range(i32 1, 33) i32 @llvm.ctpop.i32(i32 %x)
+ %cmp2 = icmp samesign ugt i32 %popcnt, 1
+ %sel = select i1 %cmp1, i1 true, i1 %cmp2
+ ret i1 %sel
+}
+
define i1 @is_power2_or_zero_with_range(i32 %x) {
; CHECK-LABEL: @is_power2_or_zero_with_range(
; CHECK-NEXT: [[CTPOP:%.*]] = call range(i32 0, 33) i32 @llvm.ctpop.i32(i32 [[X:%.*]])
More information about the llvm-commits
mailing list