blob: 7fe6aa924cc21f3b1ac75d53b6a46bf7ddc14424 [file] [log] [blame] [edit]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5
# RUN: llc -mtriple=amdgcn -mcpu=gfx1200 -run-pass=none -o - %s | FileCheck %s
--- |
define void @test_parsing_printing(ptr %ptr, float %data) {
%1 = atomicrmw fadd ptr %ptr, float %data syncscope("agent") seq_cst, align 4, !noalias.addrspace !0
ret void
}
!0 = !{i32 5, i32 6}
...
---
name: test_parsing_printing
body: |
bb.1 (%ir-block.0):
liveins: $vgpr0, $vgpr1, $vgpr2
; CHECK-LABEL: name: test_parsing_printing
; CHECK: liveins: $vgpr0, $vgpr1, $vgpr2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: [[COPY:%[0-9]+]]:vgpr_32 = COPY $vgpr0
; CHECK-NEXT: [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr1
; CHECK-NEXT: [[REG_SEQUENCE:%[0-9]+]]:vreg_64 = REG_SEQUENCE [[COPY]], %subreg.sub0, [[COPY1]], %subreg.sub1
; CHECK-NEXT: [[COPY2:%[0-9]+]]:vgpr_32 = COPY $vgpr2
; CHECK-NEXT: FLAT_ATOMIC_ADD_F32 [[REG_SEQUENCE]], [[COPY2]], 0, 0, implicit $exec, implicit $flat_scr :: (load store syncscope("agent") seq_cst (s32) on %ir.ptr, !noalias.addrspace !0)
; CHECK-NEXT: S_ENDPGM 0
%2:vgpr_32 = COPY $vgpr0
%3:vgpr_32 = COPY $vgpr1
%0:vreg_64 = REG_SEQUENCE %2, %subreg.sub0, %3, %subreg.sub1
%1:vgpr_32 = COPY $vgpr2
FLAT_ATOMIC_ADD_F32 %0, %1, 0, 0, implicit $exec, implicit $flat_scr :: (load store syncscope("agent") seq_cst (s32) on %ir.ptr, !noalias.addrspace !0)
S_ENDPGM 0
...