[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