[llvm] [GISel][AArch64] Allow G_SEXT_INREG patterns to be imported. (PR #115576)
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Fri Nov 8 19:13:53 PST 2024
https://github.com/topperc created https://github.com/llvm/llvm-project/pull/115576
SelectionDAG uses VTSDNode to store the extension type. GlobalISel uses a literal constant operand.
For vectors, SelectionDAG uses a type with the same number of elements as other operand of the sext_inreg. I assume for GISel we would just use the scalar size.
>From e29f4c14233ac480413d1be9bdeb8d0e589742c5 Mon Sep 17 00:00:00 2001
From: Craig Topper <craig.topper at sifive.com>
Date: Fri, 8 Nov 2024 19:08:10 -0800
Subject: [PATCH] [GISel][AArch64] Allow G_SEXT_INREG to be patterns to be
imported.
SelectionDAG uses VTSDNode to store the extension type. GlobalISel
uses a literal constant operand.
For vectors, SelectionDAG uses a type with the same number of
elements as other operand of the sext_inreg. I assume for GISel we
would just use the scalar size.
---
.../Target/GlobalISel/SelectionDAGCompat.td | 1 +
.../RISCV/GISel/RISCVInstructionSelector.cpp | 28 -------------
llvm/test/CodeGen/AArch64/aarch64-dup-ext.ll | 9 ++---
.../AArch64/aarch64-matrix-umull-smull.ll | 3 +-
llvm/test/CodeGen/AArch64/arm64-mul.ll | 40 ++++++-------------
llvm/test/CodeGen/AArch64/sadd_sat.ll | 8 ++--
llvm/test/CodeGen/AArch64/sadd_sat_plus.ll | 8 ++--
llvm/test/CodeGen/AArch64/sadd_sat_vec.ll | 8 ++--
llvm/test/CodeGen/AArch64/sext.ll | 22 ++++------
llvm/test/CodeGen/AArch64/ssub_sat.ll | 8 ++--
llvm/test/CodeGen/AArch64/ssub_sat_plus.ll | 8 ++--
llvm/test/CodeGen/AArch64/ssub_sat_vec.ll | 8 ++--
llvm/utils/TableGen/GlobalISelEmitter.cpp | 9 +++++
13 files changed, 58 insertions(+), 102 deletions(-)
diff --git a/llvm/include/llvm/Target/GlobalISel/SelectionDAGCompat.td b/llvm/include/llvm/Target/GlobalISel/SelectionDAGCompat.td
index 79c07bc2fc9204..2148f5be4c41aa 100644
--- a/llvm/include/llvm/Target/GlobalISel/SelectionDAGCompat.td
+++ b/llvm/include/llvm/Target/GlobalISel/SelectionDAGCompat.td
@@ -48,6 +48,7 @@ class GINodeEquiv<Instruction i, SDNode node> {
// These are defined in the same order as the G_* instructions.
def : GINodeEquiv<G_ANYEXT, anyext>;
def : GINodeEquiv<G_SEXT, sext>;
+def : GINodeEquiv<G_SEXT_INREG, sext_inreg>;
def : GINodeEquiv<G_ZEXT, zext>;
def : GINodeEquiv<G_TRUNC, trunc>;
def : GINodeEquiv<G_BITCAST, bitconvert>;
diff --git a/llvm/lib/Target/RISCV/GISel/RISCVInstructionSelector.cpp b/llvm/lib/Target/RISCV/GISel/RISCVInstructionSelector.cpp
index 27f15e07e47b8a..bff2356ef5fdd2 100644
--- a/llvm/lib/Target/RISCV/GISel/RISCVInstructionSelector.cpp
+++ b/llvm/lib/Target/RISCV/GISel/RISCVInstructionSelector.cpp
@@ -76,7 +76,6 @@ class RISCVInstructionSelector : public InstructionSelector {
bool materializeImm(Register Reg, int64_t Imm, MachineIRBuilder &MIB) const;
bool selectAddr(MachineInstr &MI, MachineIRBuilder &MIB, bool IsLocal = true,
bool IsExternWeak = false) const;
- bool selectSExtInreg(MachineInstr &MI, MachineIRBuilder &MIB) const;
bool selectSelect(MachineInstr &MI, MachineIRBuilder &MIB) const;
bool selectFPCompare(MachineInstr &MI, MachineIRBuilder &MIB) const;
void emitFence(AtomicOrdering FenceOrdering, SyncScope::ID FenceSSID,
@@ -761,8 +760,6 @@ bool RISCVInstructionSelector::select(MachineInstr &MI) {
MI.setDesc(TII.get(RISCV::PseudoBRIND));
MI.addOperand(MachineOperand::CreateImm(0));
return constrainSelectedInstRegOperands(MI, TII, TRI, RBI);
- case TargetOpcode::G_SEXT_INREG:
- return selectSExtInreg(MI, MIB);
case TargetOpcode::G_FRAME_INDEX: {
// TODO: We may want to replace this code with the SelectionDAG patterns,
// which fail to get imported because it uses FrameAddrRegImm, which is a
@@ -1160,31 +1157,6 @@ bool RISCVInstructionSelector::selectAddr(MachineInstr &MI,
return false;
}
-bool RISCVInstructionSelector::selectSExtInreg(MachineInstr &MI,
- MachineIRBuilder &MIB) const {
- Register DstReg = MI.getOperand(0).getReg();
- Register SrcReg = MI.getOperand(1).getReg();
- unsigned SrcSize = MI.getOperand(2).getImm();
-
- MachineInstr *NewMI;
- if (SrcSize == 32) {
- assert(Subtarget->is64Bit() && "Unexpected extend");
- // addiw rd, rs, 0 (i.e. sext.w rd, rs)
- NewMI = MIB.buildInstr(RISCV::ADDIW, {DstReg}, {SrcReg}).addImm(0U);
- } else {
- assert(Subtarget->hasStdExtZbb() && "Unexpected extension");
- assert((SrcSize == 8 || SrcSize == 16) && "Unexpected size");
- unsigned Opc = SrcSize == 16 ? RISCV::SEXT_H : RISCV::SEXT_B;
- NewMI = MIB.buildInstr(Opc, {DstReg}, {SrcReg});
- }
-
- if (!constrainSelectedInstRegOperands(*NewMI, TII, TRI, RBI))
- return false;
-
- MI.eraseFromParent();
- return true;
-}
-
bool RISCVInstructionSelector::selectSelect(MachineInstr &MI,
MachineIRBuilder &MIB) const {
auto &SelectMI = cast<GSelect>(MI);
diff --git a/llvm/test/CodeGen/AArch64/aarch64-dup-ext.ll b/llvm/test/CodeGen/AArch64/aarch64-dup-ext.ll
index a39c2b5d14dddd..0ce92a20fb3a17 100644
--- a/llvm/test/CodeGen/AArch64/aarch64-dup-ext.ll
+++ b/llvm/test/CodeGen/AArch64/aarch64-dup-ext.ll
@@ -15,8 +15,7 @@ define <8 x i16> @dupsext_v8i8_v8i16(i8 %src, <8 x i8> %b) {
; CHECK-GI: // %bb.0: // %entry
; CHECK-GI-NEXT: lsl w8, w0, #8
; CHECK-GI-NEXT: sshll v0.8h, v0.8b, #0
-; CHECK-GI-NEXT: sxth w8, w8
-; CHECK-GI-NEXT: asr w8, w8, #8
+; CHECK-GI-NEXT: sbfx w8, w8, #8, #8
; CHECK-GI-NEXT: dup v1.8h, w8
; CHECK-GI-NEXT: mul v0.8h, v1.8h, v0.8h
; CHECK-GI-NEXT: ret
@@ -175,9 +174,8 @@ define <2 x i16> @dupsext_v2i8_v2i16(i8 %src, <2 x i8> %b) {
; CHECK-GI: // %bb.0: // %entry
; CHECK-GI-NEXT: lsl w8, w0, #8
; CHECK-GI-NEXT: shl v0.2s, v0.2s, #24
-; CHECK-GI-NEXT: sxth w8, w8
+; CHECK-GI-NEXT: sbfx w8, w8, #8, #8
; CHECK-GI-NEXT: sshr v0.2s, v0.2s, #24
-; CHECK-GI-NEXT: asr w8, w8, #8
; CHECK-GI-NEXT: dup v1.4h, w8
; CHECK-GI-NEXT: ushll v1.4s, v1.4h, #0
; CHECK-GI-NEXT: mul v0.2s, v1.2s, v0.2s
@@ -254,8 +252,7 @@ define <8 x i16> @nonsplat_shuffleinsert(i8 %src, <8 x i8> %b) {
; CHECK-GI: // %bb.0: // %entry
; CHECK-GI-NEXT: lsl w8, w0, #8
; CHECK-GI-NEXT: sshll v0.8h, v0.8b, #0
-; CHECK-GI-NEXT: sxth w8, w8
-; CHECK-GI-NEXT: asr w8, w8, #8
+; CHECK-GI-NEXT: sbfx w8, w8, #8, #8
; CHECK-GI-NEXT: mov v1.h[1], w8
; CHECK-GI-NEXT: ext v1.16b, v1.16b, v1.16b, #4
; CHECK-GI-NEXT: mul v0.8h, v1.8h, v0.8h
diff --git a/llvm/test/CodeGen/AArch64/aarch64-matrix-umull-smull.ll b/llvm/test/CodeGen/AArch64/aarch64-matrix-umull-smull.ll
index 99dfac807dcd15..2a2f304b23e9b4 100644
--- a/llvm/test/CodeGen/AArch64/aarch64-matrix-umull-smull.ll
+++ b/llvm/test/CodeGen/AArch64/aarch64-matrix-umull-smull.ll
@@ -652,8 +652,7 @@ define i16 @red_mla_dup_ext_u8_s8_s16(ptr noalias nocapture noundef readonly %A,
; CHECK-GI-NEXT: movi v0.2d, #0000000000000000
; CHECK-GI-NEXT: movi v1.2d, #0000000000000000
; CHECK-GI-NEXT: add x10, x0, #8
-; CHECK-GI-NEXT: sxth w9, w9
-; CHECK-GI-NEXT: asr w9, w9, #8
+; CHECK-GI-NEXT: sbfx w9, w9, #8, #8
; CHECK-GI-NEXT: dup v2.8h, w9
; CHECK-GI-NEXT: and x9, x8, #0xfffffff0
; CHECK-GI-NEXT: mov x11, x9
diff --git a/llvm/test/CodeGen/AArch64/arm64-mul.ll b/llvm/test/CodeGen/AArch64/arm64-mul.ll
index e4d2ce7ccdabc8..5ae2722693f898 100644
--- a/llvm/test/CodeGen/AArch64/arm64-mul.ll
+++ b/llvm/test/CodeGen/AArch64/arm64-mul.ll
@@ -152,20 +152,12 @@ entry:
; Check the sext_inreg case.
define i64 @t11(i64 %a) nounwind {
-; CHECK-SD-LABEL: t11:
-; CHECK-SD: // %bb.0: // %entry
-; CHECK-SD-NEXT: mov w8, #29594 // =0x739a
-; CHECK-SD-NEXT: movk w8, #65499, lsl #16
-; CHECK-SD-NEXT: smnegl x0, w0, w8
-; CHECK-SD-NEXT: ret
-;
-; CHECK-GI-LABEL: t11:
-; CHECK-GI: // %bb.0: // %entry
-; CHECK-GI-NEXT: sxtw x8, w0
-; CHECK-GI-NEXT: mov x9, #-35942 // =0xffffffffffff739a
-; CHECK-GI-NEXT: movk x9, #65499, lsl #16
-; CHECK-GI-NEXT: mneg x0, x8, x9
-; CHECK-GI-NEXT: ret
+; CHECK-LABEL: t11:
+; CHECK: // %bb.0: // %entry
+; CHECK-NEXT: mov w8, #29594 // =0x739a
+; CHECK-NEXT: movk w8, #65499, lsl #16
+; CHECK-NEXT: smnegl x0, w0, w8
+; CHECK-NEXT: ret
entry:
%tmp1 = trunc i64 %a to i32
%tmp2 = sext i32 %tmp1 to i64
@@ -175,20 +167,12 @@ entry:
}
define i64 @t12(i64 %a, i64 %b) nounwind {
-; CHECK-SD-LABEL: t12:
-; CHECK-SD: // %bb.0: // %entry
-; CHECK-SD-NEXT: mov w8, #35118 // =0x892e
-; CHECK-SD-NEXT: movk w8, #65008, lsl #16
-; CHECK-SD-NEXT: smaddl x0, w0, w8, x1
-; CHECK-SD-NEXT: ret
-;
-; CHECK-GI-LABEL: t12:
-; CHECK-GI: // %bb.0: // %entry
-; CHECK-GI-NEXT: sxtw x8, w0
-; CHECK-GI-NEXT: mov x9, #-30418 // =0xffffffffffff892e
-; CHECK-GI-NEXT: movk x9, #65008, lsl #16
-; CHECK-GI-NEXT: madd x0, x8, x9, x1
-; CHECK-GI-NEXT: ret
+; CHECK-LABEL: t12:
+; CHECK: // %bb.0: // %entry
+; CHECK-NEXT: mov w8, #35118 // =0x892e
+; CHECK-NEXT: movk w8, #65008, lsl #16
+; CHECK-NEXT: smaddl x0, w0, w8, x1
+; CHECK-NEXT: ret
entry:
%tmp1 = trunc i64 %a to i32
%tmp2 = sext i32 %tmp1 to i64
diff --git a/llvm/test/CodeGen/AArch64/sadd_sat.ll b/llvm/test/CodeGen/AArch64/sadd_sat.ll
index 789fd7b20a7f99..cb52c17e2531c8 100644
--- a/llvm/test/CodeGen/AArch64/sadd_sat.ll
+++ b/llvm/test/CodeGen/AArch64/sadd_sat.ll
@@ -71,9 +71,9 @@ define i16 @func16(i16 %x, i16 %y) nounwind {
; CHECK-GI-NEXT: sxth w8, w1
; CHECK-GI-NEXT: add w8, w8, w0, sxth
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%tmp = call i16 @llvm.sadd.sat.i16(i16 %x, i16 %y);
@@ -98,9 +98,9 @@ define i8 @func8(i8 %x, i8 %y) nounwind {
; CHECK-GI-NEXT: sxtb w8, w1
; CHECK-GI-NEXT: add w8, w8, w0, sxtb
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%tmp = call i8 @llvm.sadd.sat.i8(i8 %x, i8 %y);
diff --git a/llvm/test/CodeGen/AArch64/sadd_sat_plus.ll b/llvm/test/CodeGen/AArch64/sadd_sat_plus.ll
index ecc8cbaeeecae4..f6fb4dd5e4b417 100644
--- a/llvm/test/CodeGen/AArch64/sadd_sat_plus.ll
+++ b/llvm/test/CodeGen/AArch64/sadd_sat_plus.ll
@@ -76,9 +76,9 @@ define i16 @func16(i16 %x, i16 %y, i16 %z) nounwind {
; CHECK-GI-NEXT: sxth w8, w8
; CHECK-GI-NEXT: add w8, w8, w0, sxth
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%a = mul i16 %y, %z
@@ -106,9 +106,9 @@ define i8 @func8(i8 %x, i8 %y, i8 %z) nounwind {
; CHECK-GI-NEXT: sxtb w8, w8
; CHECK-GI-NEXT: add w8, w8, w0, sxtb
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%a = mul i8 %y, %z
diff --git a/llvm/test/CodeGen/AArch64/sadd_sat_vec.ll b/llvm/test/CodeGen/AArch64/sadd_sat_vec.ll
index 6d331d9413f913..29318bd28c45d4 100644
--- a/llvm/test/CodeGen/AArch64/sadd_sat_vec.ll
+++ b/llvm/test/CodeGen/AArch64/sadd_sat_vec.ll
@@ -332,9 +332,9 @@ define void @v1i8(ptr %px, ptr %py, ptr %pz) nounwind {
; CHECK-GI-NEXT: ldrsb w9, [x1]
; CHECK-GI-NEXT: add w8, w8, w9
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w8, w10, w8, ne
; CHECK-GI-NEXT: strb w8, [x2]
; CHECK-GI-NEXT: ret
@@ -360,9 +360,9 @@ define void @v1i16(ptr %px, ptr %py, ptr %pz) nounwind {
; CHECK-GI-NEXT: ldrsh w9, [x1]
; CHECK-GI-NEXT: add w8, w8, w9
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w8, w10, w8, ne
; CHECK-GI-NEXT: strh w8, [x2]
; CHECK-GI-NEXT: ret
diff --git a/llvm/test/CodeGen/AArch64/sext.ll b/llvm/test/CodeGen/AArch64/sext.ll
index 853ed92c91fbcd..3604db33d5c4b3 100644
--- a/llvm/test/CodeGen/AArch64/sext.ll
+++ b/llvm/test/CodeGen/AArch64/sext.ll
@@ -221,14 +221,11 @@ define <3 x i16> @sext_v3i8_v3i16(<3 x i8> %a) {
; CHECK-GI: // %bb.0: // %entry
; CHECK-GI-NEXT: lsl w8, w0, #8
; CHECK-GI-NEXT: lsl w9, w1, #8
-; CHECK-GI-NEXT: lsl w10, w2, #8
-; CHECK-GI-NEXT: sxth w8, w8
-; CHECK-GI-NEXT: sxth w9, w9
-; CHECK-GI-NEXT: asr w8, w8, #8
-; CHECK-GI-NEXT: asr w9, w9, #8
+; CHECK-GI-NEXT: sbfx w8, w8, #8, #8
+; CHECK-GI-NEXT: sbfx w9, w9, #8, #8
; CHECK-GI-NEXT: fmov s0, w8
-; CHECK-GI-NEXT: sxth w8, w10
-; CHECK-GI-NEXT: asr w8, w8, #8
+; CHECK-GI-NEXT: lsl w8, w2, #8
+; CHECK-GI-NEXT: sbfx w8, w8, #8, #8
; CHECK-GI-NEXT: mov v0.h[1], w9
; CHECK-GI-NEXT: mov v0.h[2], w8
; CHECK-GI-NEXT: // kill: def $d0 killed $d0 killed $q0
@@ -386,14 +383,11 @@ define <3 x i16> @sext_v3i10_v3i16(<3 x i10> %a) {
; CHECK-GI: // %bb.0: // %entry
; CHECK-GI-NEXT: lsl w8, w0, #6
; CHECK-GI-NEXT: lsl w9, w1, #6
-; CHECK-GI-NEXT: lsl w10, w2, #6
-; CHECK-GI-NEXT: sxth w8, w8
-; CHECK-GI-NEXT: sxth w9, w9
-; CHECK-GI-NEXT: asr w8, w8, #6
-; CHECK-GI-NEXT: asr w9, w9, #6
+; CHECK-GI-NEXT: sbfx w8, w8, #6, #10
+; CHECK-GI-NEXT: sbfx w9, w9, #6, #10
; CHECK-GI-NEXT: fmov s0, w8
-; CHECK-GI-NEXT: sxth w8, w10
-; CHECK-GI-NEXT: asr w8, w8, #6
+; CHECK-GI-NEXT: lsl w8, w2, #6
+; CHECK-GI-NEXT: sbfx w8, w8, #6, #10
; CHECK-GI-NEXT: mov v0.h[1], w9
; CHECK-GI-NEXT: mov v0.h[2], w8
; CHECK-GI-NEXT: // kill: def $d0 killed $d0 killed $q0
diff --git a/llvm/test/CodeGen/AArch64/ssub_sat.ll b/llvm/test/CodeGen/AArch64/ssub_sat.ll
index 4d755f480c3fc9..cf201d628b7e1e 100644
--- a/llvm/test/CodeGen/AArch64/ssub_sat.ll
+++ b/llvm/test/CodeGen/AArch64/ssub_sat.ll
@@ -71,9 +71,9 @@ define i16 @func16(i16 %x, i16 %y) nounwind {
; CHECK-GI-NEXT: sxth w8, w0
; CHECK-GI-NEXT: sub w8, w8, w1, sxth
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%tmp = call i16 @llvm.ssub.sat.i16(i16 %x, i16 %y);
@@ -98,9 +98,9 @@ define i8 @func8(i8 %x, i8 %y) nounwind {
; CHECK-GI-NEXT: sxtb w8, w0
; CHECK-GI-NEXT: sub w8, w8, w1, sxtb
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%tmp = call i8 @llvm.ssub.sat.i8(i8 %x, i8 %y);
diff --git a/llvm/test/CodeGen/AArch64/ssub_sat_plus.ll b/llvm/test/CodeGen/AArch64/ssub_sat_plus.ll
index 25d615f6451ba1..cabd580e20d504 100644
--- a/llvm/test/CodeGen/AArch64/ssub_sat_plus.ll
+++ b/llvm/test/CodeGen/AArch64/ssub_sat_plus.ll
@@ -76,9 +76,9 @@ define i16 @func16(i16 %x, i16 %y, i16 %z) nounwind {
; CHECK-GI-NEXT: sxth w9, w0
; CHECK-GI-NEXT: sub w8, w9, w8, sxth
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%a = mul i16 %y, %z
@@ -106,9 +106,9 @@ define i8 @func8(i8 %x, i8 %y, i8 %z) nounwind {
; CHECK-GI-NEXT: sxtb w9, w0
; CHECK-GI-NEXT: sub w8, w9, w8, sxtb
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w0, w10, w8, ne
; CHECK-GI-NEXT: ret
%a = mul i8 %y, %z
diff --git a/llvm/test/CodeGen/AArch64/ssub_sat_vec.ll b/llvm/test/CodeGen/AArch64/ssub_sat_vec.ll
index dddda7e9ba64cd..30e2a70ace0722 100644
--- a/llvm/test/CodeGen/AArch64/ssub_sat_vec.ll
+++ b/llvm/test/CodeGen/AArch64/ssub_sat_vec.ll
@@ -333,9 +333,9 @@ define void @v1i8(ptr %px, ptr %py, ptr %pz) nounwind {
; CHECK-GI-NEXT: ldrsb w9, [x1]
; CHECK-GI-NEXT: sub w8, w8, w9
; CHECK-GI-NEXT: sxtb w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #7
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #7, #1
; CHECK-GI-NEXT: sub w10, w10, #128
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w8, w10, w8, ne
; CHECK-GI-NEXT: strb w8, [x2]
; CHECK-GI-NEXT: ret
@@ -361,9 +361,9 @@ define void @v1i16(ptr %px, ptr %py, ptr %pz) nounwind {
; CHECK-GI-NEXT: ldrsh w9, [x1]
; CHECK-GI-NEXT: sub w8, w8, w9
; CHECK-GI-NEXT: sxth w9, w8
-; CHECK-GI-NEXT: asr w10, w9, #15
-; CHECK-GI-NEXT: cmp w8, w9
+; CHECK-GI-NEXT: sbfx w10, w8, #15, #1
; CHECK-GI-NEXT: sub w10, w10, #8, lsl #12 // =32768
+; CHECK-GI-NEXT: cmp w8, w9
; CHECK-GI-NEXT: csel w8, w10, w8, ne
; CHECK-GI-NEXT: strh w8, [x2]
; CHECK-GI-NEXT: ret
diff --git a/llvm/utils/TableGen/GlobalISelEmitter.cpp b/llvm/utils/TableGen/GlobalISelEmitter.cpp
index 1e5d28f8ce95b7..895743ad8230c8 100644
--- a/llvm/utils/TableGen/GlobalISelEmitter.cpp
+++ b/llvm/utils/TableGen/GlobalISelEmitter.cpp
@@ -1015,6 +1015,15 @@ Error GlobalISelEmitter::importChildMatcher(
return Error::success();
}
}
+ } else if (auto *ChildDefInit = dyn_cast<DefInit>(SrcChild.getLeafValue())) {
+ auto *ChildRec = ChildDefInit->getDef();
+ if (ChildRec->isSubClassOf("ValueType") && !SrcChild.hasName()) {
+ // An unnamed ValueType as in (sext_inreg GPR:$foo, i8). GISel represents
+ // this as a literal constant with the scalar size.
+ MVT::SimpleValueType VT = llvm::getValueType(ChildRec);
+ OM.addPredicate<LiteralIntOperandMatcher>(MVT(VT).getScalarSizeInBits());
+ return Error::success();
+ }
}
// Immediate arguments have no meaningful type to check as they don't have
More information about the llvm-commits
mailing list