[llvm-branch-commits] [llvm] release/22.x: [Hexagon] Fix extractHvxSubvectorPred shuffle mask for small predicates (#181364) (PR #182955)
via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Mon Feb 23 14:54:16 PST 2026
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-backend-hexagon
Author: None (llvmbot)
<details>
<summary>Changes</summary>
Backport c3a86ff2d0b397d757345fad7e29c2a6e7dbc823
Requested by: @<!-- -->androm3da
---
Full diff: https://github.com/llvm/llvm-project/pull/182955.diff
2 Files Affected:
- (modified) llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp (+1-1)
- (added) llvm/test/CodeGen/Hexagon/extract-hvx-subvector-pred-small.ll (+28)
``````````diff
diff --git a/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp b/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp
index 9a0e5cc684b65..cbe1498bb24a9 100644
--- a/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp
+++ b/llvm/lib/Target/Hexagon/HexagonISelLoweringHVX.cpp
@@ -1428,7 +1428,7 @@ HexagonTargetLowering::extractHvxSubvectorPred(SDValue VecV, SDValue IdxV,
unsigned Rep = 8 / ResLen;
// Make sure the output fill the entire vector register, so repeat the
// 8-byte groups as many times as necessary.
- for (unsigned r = 0; r != HwLen/ResLen; ++r) {
+ for (unsigned r = 0; r != HwLen / 8; ++r) {
// This will generate the indexes of the 8 interesting bytes.
for (unsigned i = 0; i != ResLen; ++i) {
for (unsigned j = 0; j != Rep; ++j)
diff --git a/llvm/test/CodeGen/Hexagon/extract-hvx-subvector-pred-small.ll b/llvm/test/CodeGen/Hexagon/extract-hvx-subvector-pred-small.ll
new file mode 100644
index 0000000000000..2e88dab7e496e
--- /dev/null
+++ b/llvm/test/CodeGen/Hexagon/extract-hvx-subvector-pred-small.ll
@@ -0,0 +1,28 @@
+; RUN: llc -mtriple=hexagon -mcpu=hexagonv73 -mattr=+hvxv73,+hvx-length128b \
+; RUN: < %s | FileCheck %s
+;
+; Check that extracting a small predicate subvector (<8 x i1) from an HVX
+; predicate compiles correctly. The bug was in extractHvxSubvectorPred where
+; the loop generating the shuffle mask used HwLen/ResLen instead of HwLen/8,
+; producing a mask of wrong size for ResLen < 8.
+
+target datalayout = "e-m:e-p:32:32:32-a:0-n16:32-i64:64:64-i32:32:32-i16:16:16-i1:8:8-f32:32:32-f64:64:64-v32:32:32-v64:64:64-v512:512:512-v1024:1024:1024-v2048:2048:2048"
+target triple = "hexagon-unknown-linux-musl"
+
+; CHECK-LABEL: test_extract_v4i1:
+; CHECK-DAG: vand(v{{[0-9]+}},r{{[0-9]+}})
+; CHECK-DAG: vdelta(v{{[0-9]+}},v{{[0-9]+}})
+; CHECK: dealloc_return
+define <4 x i1> @test_extract_v4i1(<128 x i1> %pred) {
+ %r = shufflevector <128 x i1> %pred, <128 x i1> poison, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
+ ret <4 x i1> %r
+}
+
+; CHECK-LABEL: test_extract_v2i1:
+; CHECK-DAG: vand(v{{[0-9]+}},r{{[0-9]+}})
+; CHECK-DAG: vdelta(v{{[0-9]+}},v{{[0-9]+}})
+; CHECK: dealloc_return
+define <2 x i1> @test_extract_v2i1(<128 x i1> %pred) {
+ %r = shufflevector <128 x i1> %pred, <128 x i1> poison, <2 x i32> <i32 0, i32 1>
+ ret <2 x i1> %r
+}
``````````
</details>
https://github.com/llvm/llvm-project/pull/182955
More information about the llvm-branch-commits
mailing list