[llvm] f4950f6 - AMDGPU: Add missing verifier tests for load/store AGPR case (#155815)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Aug 28 05:23:30 PDT 2025
Author: Matt Arsenault
Date: 2025-08-28T21:23:26+09:00
New Revision: f4950f624b3061d155be6280402ad04f5b069132
URL: https://github.com/llvm/llvm-project/commit/f4950f624b3061d155be6280402ad04f5b069132
DIFF: https://github.com/llvm/llvm-project/commit/f4950f624b3061d155be6280402ad04f5b069132.diff
LOG: AMDGPU: Add missing verifier tests for load/store AGPR case (#155815)
Added:
llvm/test/MachineVerifier/AMDGPU/verify-ds-vdata-vdst-both-agpr-or-vgpr.mir
Modified:
Removed:
################################################################################
diff --git a/llvm/test/MachineVerifier/AMDGPU/verify-ds-vdata-vdst-both-agpr-or-vgpr.mir b/llvm/test/MachineVerifier/AMDGPU/verify-ds-vdata-vdst-both-agpr-or-vgpr.mir
new file mode 100644
index 0000000000000..956a8b80e4082
--- /dev/null
+++ b/llvm/test/MachineVerifier/AMDGPU/verify-ds-vdata-vdst-both-agpr-or-vgpr.mir
@@ -0,0 +1,92 @@
+# RUN: not --crash llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx90a -run-pass=none -filetype=null %s 2>&1 | FileCheck -implicit-check-not=Bad %s
+
+---
+name: invalid_mixed_agpr_vgpr_ops_ds_atomic
+tracksRegLiveness: true
+body: |
+ bb.0:
+
+ %addr:vgpr_32 = IMPLICIT_DEF
+ %vgpr:vgpr_32 = IMPLICIT_DEF
+ %agpr:agpr_32 = IMPLICIT_DEF
+ %a_or_v:av_32 = IMPLICIT_DEF
+
+ ; CHECK: Bad machine code: Invalid register class: vdata and vdst should be both VGPR or AGPR
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %4:agpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %vgpr, %vgpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: Bad machine code: Invalid register class: vdata and vdst should be both VGPR or AGPR
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %5:vgpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %agpr, %vgpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %6:vgpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %vgpr, %agpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %7:av_32 = DS_CMPST_RTN_B32_gfx9 %addr, %vgpr, %vgpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %8:vgpr_32 = DS_CMPST_RTN_B32_gfx9 %vgpr, %a_or_v, %vgpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %9:vgpr_32 = DS_CMPST_RTN_B32_gfx9 %vgpr, %vgpr, %a_or_v, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: vdata and vdst should be both VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %10:av_32 = DS_CMPST_RTN_B32_gfx9 %addr, %agpr, %agpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: vdata and vdst should be both VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %11:agpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %a_or_v, %agpr, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %12:agpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %agpr, %a_or_v, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: vdata and vdst should be both VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %13:agpr_32 = DS_CMPST_RTN_B32_gfx9 %addr, %a_or_v, %a_or_v, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ %14:av_32 = DS_CMPST_RTN_B32_gfx9 %addr, %a_or_v, %a_or_v, 0, 0, implicit $exec :: (load store seq_cst monotonic (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %a_or_v, %a_or_v, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %agpr, %vgpr, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %vgpr, %agpr, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %vgpr, %a_or_v, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %a_or_v, %vgpr, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %agpr, %a_or_v, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+ ; CHECK: *** Bad machine code: Invalid register class: both data operands should be VGPR or AGPR ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ ; CHECK: *** Bad machine code: Illegal virtual register for instruction ***
+ DS_WRITE2_B32_gfx9 %addr, %a_or_v, %agpr, 10, 24, 0, implicit $exec :: (store (s32), addrspace 3), (store (s32), addrspace 3)
+
+...
More information about the llvm-commits
mailing list