[llvm-branch-commits] [llvm] release/22.x: [AArch64] Fix sign-extend-inreg combine for i1 types (#177976) (PR #184777)
via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Thu Mar 5 03:54:35 PST 2026
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-backend-aarch64
Author: None (llvmbot)
<details>
<summary>Changes</summary>
Backport ffb7a9f0ec80d5b12aa440d8446d2379827100f4
Requested by: @<!-- -->sdesmalen-arm
---
Full diff: https://github.com/llvm/llvm-project/pull/184777.diff
2 Files Affected:
- (modified) llvm/lib/Target/AArch64/AArch64ISelLowering.cpp (+3-3)
- (modified) llvm/test/CodeGen/AArch64/sve-sext-zext.ll (+28)
``````````diff
diff --git a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
index 5dfa65fca4f4a..a55b1facb103f 100644
--- a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
+++ b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
@@ -27658,10 +27658,10 @@ performSignExtendInRegCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI,
SDValue ExtOp = Src->getOperand(0);
auto VT = cast<VTSDNode>(N->getOperand(1))->getVT();
EVT EltTy = VT.getVectorElementType();
- (void)EltTy;
- assert((EltTy == MVT::i8 || EltTy == MVT::i16 || EltTy == MVT::i32) &&
- "Sign extending from an invalid type");
+ if (EltTy.getSizeInBits() >
+ ExtOp.getValueType().getScalarType().getSizeInBits())
+ return SDValue();
EVT ExtVT = VT.getDoubleNumVectorElementsVT(*DAG.getContext());
diff --git a/llvm/test/CodeGen/AArch64/sve-sext-zext.ll b/llvm/test/CodeGen/AArch64/sve-sext-zext.ll
index 845628a91498b..54dd83eaec507 100644
--- a/llvm/test/CodeGen/AArch64/sve-sext-zext.ll
+++ b/llvm/test/CodeGen/AArch64/sve-sext-zext.ll
@@ -584,3 +584,31 @@ define <vscale x 2 x i64> @zext_inreg_i64_from_i32(<vscale x 4 x i32> %a) {
%zext = zext <vscale x 2 x i32> %subvec to <vscale x 2 x i64>
ret <vscale x 2 x i64> %zext
}
+
+; Sign-extend-inreg from i8 -> i1 -> i16
+define <vscale x 16 x i16> @sext_inreg_i1_to_i16_from_i8(<vscale x 16 x i8> %a) {
+; CHECK-LABEL: sext_inreg_i1_to_i16_from_i8:
+; CHECK: // %bb.0:
+; CHECK-NEXT: lsl z0.b, z0.b, #7
+; CHECK-NEXT: asr z1.b, z0.b, #7
+; CHECK-NEXT: sunpklo z0.h, z1.b
+; CHECK-NEXT: sunpkhi z1.h, z1.b
+; CHECK-NEXT: ret
+ %a.trunc = trunc <vscale x 16 x i8> %a to <vscale x 16 x i1>
+ %a.sextinreg = sext <vscale x 16 x i1> %a.trunc to <vscale x 16 x i16>
+ ret <vscale x 16 x i16> %a.sextinreg
+}
+
+; Sign-extend-inreg from i8 -> i2 -> i16
+define <vscale x 16 x i16> @sext_inreg_i2_to_i16_from_i8(<vscale x 16 x i8> %a) {
+; CHECK-LABEL: sext_inreg_i2_to_i16_from_i8:
+; CHECK: // %bb.0:
+; CHECK-NEXT: lsl z0.b, z0.b, #6
+; CHECK-NEXT: asr z1.b, z0.b, #6
+; CHECK-NEXT: sunpklo z0.h, z1.b
+; CHECK-NEXT: sunpkhi z1.h, z1.b
+; CHECK-NEXT: ret
+ %a.trunc = trunc <vscale x 16 x i8> %a to <vscale x 16 x i2>
+ %a.sextinreg = sext <vscale x 16 x i2> %a.trunc to <vscale x 16 x i16>
+ ret <vscale x 16 x i16> %a.sextinreg
+}
``````````
</details>
https://github.com/llvm/llvm-project/pull/184777
More information about the llvm-branch-commits
mailing list