[llvm] [AMDGPU] Verify SdwaSel value range (PR #128898)
Frederik Harwath via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 26 08:01:15 PST 2025
https://github.com/frederik-h created https://github.com/llvm/llvm-project/pull/128898
Ensure that the MachineVerifier verifies that the value provided for an SDWA selection is a valid value for the SdwaSel enum.
>From b0e07eec61a665513221536ac9889986a57aa286 Mon Sep 17 00:00:00 2001
From: Frederik Harwath <fharwath at amd.com>
Date: Wed, 26 Feb 2025 10:30:48 -0500
Subject: [PATCH] [AMDGPU] Verify SdwaSel value range
Ensure that the MachineVerifier verifies that the
value provided for an SDWA selection is a valid
value for the SdwaSel enum.
---
llvm/lib/Target/AMDGPU/SIInstrInfo.cpp | 12 ++++++++++
.../AMDGPU/verifier-sdwa-selection.mir | 22 +++++++++++++++++++
2 files changed, 34 insertions(+)
create mode 100644 llvm/test/CodeGen/AMDGPU/verifier-sdwa-selection.mir
diff --git a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
index 2ef628a7c569c..ceadc81aa56ac 100644
--- a/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
+++ b/llvm/lib/Target/AMDGPU/SIInstrInfo.cpp
@@ -4916,6 +4916,18 @@ bool SIInstrInfo::verifyInstruction(const MachineInstr &MI,
return false;
}
+ for (auto Op : {AMDGPU::OpName::src0_sel, AMDGPU::OpName::src1_sel,
+ AMDGPU::OpName::dst_sel}) {
+ const MachineOperand *MO = getNamedOperand(MI, Op);
+ if (!MO)
+ continue;
+ int64_t Imm = MO->getImm();
+ if (Imm < 0 || Imm > AMDGPU::SDWA::SdwaSel::DWORD) {
+ ErrInfo = "Invalid SDWA selection";
+ return false;
+ }
+ }
+
int DstIdx = AMDGPU::getNamedOperandIdx(Opcode, AMDGPU::OpName::vdst);
for (int OpIdx : {DstIdx, Src0Idx, Src1Idx, Src2Idx}) {
diff --git a/llvm/test/CodeGen/AMDGPU/verifier-sdwa-selection.mir b/llvm/test/CodeGen/AMDGPU/verifier-sdwa-selection.mir
new file mode 100644
index 0000000000000..8517b0ad53458
--- /dev/null
+++ b/llvm/test/CodeGen/AMDGPU/verifier-sdwa-selection.mir
@@ -0,0 +1,22 @@
+# RUN: not --crash llc -mtriple=amdgcn -mcpu=gfx1030 --verify-machineinstrs -o - %s 2>&1 | FileCheck %s
+
+# CHECK-COUNT-6: *** Bad machine code: Invalid SDWA selection ***
+# CHECK-NOT: *** Bad machine code
+# CHECK: LLVM ERROR: Found 6 machine code errors
+
+---
+name: invalid_sdwa_selection
+tracksRegLiveness: true
+body: |
+ bb.0:
+ liveins: $vgpr0
+ %0:vgpr_32 = COPY $vgpr0
+ %1:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, 1, 0, 7, 0, implicit $exec
+ %2:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, 1, 0, -1, 0, implicit $exec
+ %3:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, 7, 0, 6, 0, implicit $exec
+ %4:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, -1, 0, 6, 0, implicit $exec
+ %5:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, 0, 0, 0, 7, implicit $exec
+ %6:vgpr_32 = V_LSHRREV_B32_sdwa 0, %0:vgpr_32, 0, %0:vgpr_32, 0, 0, 0, 0, -1, implicit $exec
+
+ S_ENDPGM 0
+...
More information about the llvm-commits
mailing list