blob: 8121f4281dbfa90c57fbbd10e6b38368edbad76c [file]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 6
# RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx950 -run-pass=machine-sink -o - %s | FileCheck %s
# machine-sink must not sink MFMA instructions.
# Ensure that MFMA instructions are marked as convergent to prevent
# machine-sink from sinking them.
---
name: test_V_MFMA_F32_32X32X64_F8F6F4_f4_f4_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_32X32X64_F8F6F4_f4_f4_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: early-clobber %vdst:areg_512_align2 = nofpexcept V_MFMA_F32_32X32X64_F8F6F4_f4_f4_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:av_128_align2 = IMPLICIT_DEF
%vsrc1:av_128_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc2:areg_512_align2 = IMPLICIT_DEF
%vdst:areg_512_align2 = nofpexcept V_MFMA_F32_32X32X64_F8F6F4_f4_f4_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2:
S_ENDPGM 0
...
---
name: test_V_MFMA_F32_16X16X128_F8F6F4_f4_f4_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_16X16X128_F8F6F4_f4_f4_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:areg_128_align2 = nofpexcept V_MFMA_F32_16X16X128_F8F6F4_f4_f4_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:av_128_align2 = IMPLICIT_DEF
%vsrc1:av_128_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc2:areg_128_align2 = IMPLICIT_DEF
%vdst:areg_128_align2 = nofpexcept V_MFMA_F32_16X16X128_F8F6F4_f4_f4_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2:
S_ENDPGM 0
...
---
name: test_V_MFMA_SCALE_F32_16X16X128_F8F6F4_f4_f4_vgprcd_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_SCALE_F32_16X16X128_F8F6F4_f4_f4_vgprcd_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:vreg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %scale_vsrc0:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %scale_vsrc2:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:vreg_128_align2 = nofpexcept V_MFMA_SCALE_F32_16X16X128_F8F6F4_f4_f4_vgprcd_e64 %vsrc0, %vsrc1, %vsrc2, 4, 4, %scale_vsrc0, %scale_vsrc2, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:av_128_align2 = IMPLICIT_DEF
%vsrc1:av_128_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc2:vreg_128_align2 = IMPLICIT_DEF
%scale_vsrc0:vgpr_32 = IMPLICIT_DEF
%scale_vsrc2:vgpr_32 = IMPLICIT_DEF
%vdst:vreg_128_align2 = nofpexcept V_MFMA_SCALE_F32_16X16X128_F8F6F4_f4_f4_vgprcd_e64 %vsrc0, %vsrc1, %vsrc2, 4, 4, %scale_vsrc0, %scale_vsrc2, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2:
S_ENDPGM 0
...
---
name: test_V_MFMA_SCALE_F32_32X32X64_F8F6F4_f4_f4_mac_vgprcd_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_SCALE_F32_32X32X64_F8F6F4_f4_f4_mac_vgprcd_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:av_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:vreg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: %scale_vsrc0:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %scale_vsrc2:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:vreg_512_align2 = nofpexcept V_MFMA_SCALE_F32_32X32X64_F8F6F4_f4_f4_mac_vgprcd_e64 %vsrc0, %vsrc1, %vsrc2, 4, 4, %scale_vsrc0, %scale_vsrc2, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:av_128_align2 = IMPLICIT_DEF
%vsrc1:av_128_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc2:vreg_512_align2 = IMPLICIT_DEF
%scale_vsrc0:vgpr_32 = IMPLICIT_DEF
%scale_vsrc2:vgpr_32 = IMPLICIT_DEF
%vdst:vreg_512_align2 = nofpexcept V_MFMA_SCALE_F32_32X32X64_F8F6F4_f4_f4_mac_vgprcd_e64 %vsrc0, %vsrc1, %vsrc2, 4, 4, %scale_vsrc0, %scale_vsrc2, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2:
S_ENDPGM 0
...
---
name: test_V_MFMA_F32_4X4X1F32_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_4X4X1F32_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:areg_128_align2 = V_MFMA_F32_4X4X1F32_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vgpr_32 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%vsrc2:areg_128_align2 = IMPLICIT_DEF
%vdst:areg_128_align2 = V_MFMA_F32_4X4X1F32_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F32_32X32X1F32_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_32X32X1F32_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_1024_align2 = IMPLICIT_DEF
; CHECK-NEXT: early-clobber %vdst:areg_1024_align2 = V_MFMA_F32_32X32X1F32_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vgpr_32 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%vsrc2:areg_1024_align2 = IMPLICIT_DEF
%vdst:areg_1024_align2 = V_MFMA_F32_32X32X1F32_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F32_32X32X8F16_mac_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_32X32X8F16_mac_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:areg_512_align2 = V_MFMA_F32_32X32X8F16_mac_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vreg_64_align2 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%vsrc2:areg_512_align2 = IMPLICIT_DEF
%vdst:areg_512_align2 = V_MFMA_F32_32X32X8F16_mac_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F64_4X4X4F64_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F64_4X4X4F64_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:areg_64_align2 = V_MFMA_F64_4X4X4F64_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vreg_64_align2 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%vsrc2:areg_64_align2 = IMPLICIT_DEF
%vdst:areg_64_align2 = V_MFMA_F64_4X4X4F64_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F32_32X32X16_F16_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_32X32X16_F16_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vreg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: early-clobber %vdst:areg_512_align2 = V_MFMA_F32_32X32X16_F16_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vreg_128_align2 = IMPLICIT_DEF
%vsrc1:vreg_128_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vreg_128_align2 = IMPLICIT_DEF
%vsrc2:areg_512_align2 = IMPLICIT_DEF
%vdst:areg_512_align2 = V_MFMA_F32_32X32X16_F16_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F32_32X32X16_BF8_BF8_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_32X32X16_BF8_BF8_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: early-clobber %vdst:areg_512_align2 = V_MFMA_F32_32X32X16_BF8_BF8_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vreg_64_align2 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%vsrc2:areg_512_align2 = IMPLICIT_DEF
%vdst:areg_512_align2 = V_MFMA_F32_32X32X16_BF8_BF8_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_F32_16X16X16F16_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_F32_16X16X16F16_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vreg_64_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_128_align2 = IMPLICIT_DEF
; CHECK-NEXT: %vdst:areg_128_align2 = V_MFMA_F32_16X16X16F16_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vreg_64_align2 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vreg_64_align2 = IMPLICIT_DEF
%vsrc2:areg_128_align2 = IMPLICIT_DEF
%vdst:areg_128_align2 = V_MFMA_F32_16X16X16F16_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
---
name: test_V_MFMA_I32_32X32X8I8_e64
body: |
; CHECK-LABEL: name: test_V_MFMA_I32_32X32X8I8_e64
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: %vsrc0:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %ssrc:sreg_64 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc1:vgpr_32 = IMPLICIT_DEF
; CHECK-NEXT: %vsrc2:areg_512_align2 = IMPLICIT_DEF
; CHECK-NEXT: early-clobber %vdst:areg_512_align2 = V_MFMA_I32_32X32X8I8_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
; CHECK-NEXT: %sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
; CHECK-NEXT: S_BRANCH %bb.1
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
; CHECK-NEXT: successors: %bb.2(0x80000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: S_BRANCH %bb.2
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.2:
; CHECK-NEXT: S_ENDPGM 0
bb.0:
%vsrc0:vgpr_32 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%ssrc:sreg_64 = IMPLICIT_DEF
%vsrc1:vgpr_32 = IMPLICIT_DEF
%vsrc2:areg_512_align2 = IMPLICIT_DEF
%vdst:areg_512_align2 = V_MFMA_I32_32X32X8I8_e64 %vsrc0, %vsrc1, %vsrc2, 0, 0, 0, implicit $mode, implicit $exec
%sdst:sreg_64 = SI_IF %ssrc, %bb.2, implicit-def dead $exec, implicit-def dead $scc, implicit $exec
S_BRANCH %bb.1
bb.1:
S_BRANCH %bb.2
bb.2: S_ENDPGM 0
...
## NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
# CHECK: {{.*}}