[llvm] [RISCV] Add DAG combine to convert (iX ctpop (bitcast (vXi1 A))) into vcpop.m. (PR #117062)
Philip Reames via llvm-commits
llvm-commits at lists.llvm.org
Wed Nov 20 14:52:48 PST 2024
================
@@ -844,12 +850,9 @@ define <128 x i16> @test_expandload_v128i16_all_ones(ptr %base, <128 x i16> %pas
; CHECK-RV64-NEXT: vsetvli zero, a1, e16, m8, ta, ma
; CHECK-RV64-NEXT: vle16.v v8, (a0)
; CHECK-RV64-NEXT: vmset.m v16
-; CHECK-RV64-NEXT: vsetvli zero, a1, e64, m1, ta, ma
-; CHECK-RV64-NEXT: vmv.x.s a2, v16
-; CHECK-RV64-NEXT: cpop a2, a2
-; CHECK-RV64-NEXT: slli a2, a2, 1
-; CHECK-RV64-NEXT: add a0, a0, a2
-; CHECK-RV64-NEXT: vsetvli zero, a1, e16, m8, ta, ma
+; CHECK-RV64-NEXT: vcpop.m a1, v16
----------------
preames wrote:
This idiom is a bit weird. Probably off topic. Why are we doing a vmset.m followed by a vcpop? In the source, the size should be a constant, so we shouldn't be worried about the tail bits?
https://github.com/llvm/llvm-project/pull/117062
More information about the llvm-commits
mailing list