blob: 956a8b80e40828403a69a598fbd0300e8c434dea [file] [log] [blame] [edit]
# 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)
...