You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
681 lines
16 KiB
681 lines
16 KiB
# RUN: llc -march=amdgcn -amdgpu-enable-merge-m0 -verify-machineinstrs -run-pass si-fix-sgpr-copies %s -o - | FileCheck -check-prefix=GCN %s
|
|
|
|
# GCN-LABEL: name: merge-m0-many-init
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 65536
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 65536
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.2:
|
|
# GCN: SI_INIT_M0 65536
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.3:
|
|
# GCN: SI_INIT_M0 3
|
|
|
|
# GCN: bb.4:
|
|
# GCN-NOT: SI_INIT_M0
|
|
# GCN: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 4
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.5:
|
|
# GCN-NOT: SI_INIT_M0
|
|
# GCN: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 4
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.6:
|
|
# GCN: SI_INIT_M0 -1,
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN: SI_INIT_M0 %2
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 %2
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
---
|
|
name: merge-m0-many-init
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sreg_32_xm0 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1, %bb.2
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.1:
|
|
successors: %bb.2
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
successors: %bb.3
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.3
|
|
|
|
bb.3:
|
|
successors: %bb.4, %bb.5
|
|
S_CBRANCH_VCCZ %bb.4, implicit undef $vcc
|
|
S_BRANCH %bb.5
|
|
|
|
bb.4:
|
|
successors: %bb.6
|
|
SI_INIT_M0 3, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 4, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.6
|
|
|
|
bb.5:
|
|
successors: %bb.6
|
|
SI_INIT_M0 3, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 4, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.6
|
|
|
|
bb.6:
|
|
successors: %bb.0.entry, %bb.6
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 %2, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 %2, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.6, implicit undef $vcc
|
|
S_BRANCH %bb.0.entry
|
|
|
|
...
|
|
|
|
# GCN-LABEL: name: merge-m0-dont-hoist-past-init-with-different-initializer
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 65536
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN-NOT: SI_INIT_M0 65536
|
|
# GCN-NOT: SI_INIT_M0 -1
|
|
|
|
# GCN: bb.2:
|
|
# GCN: SI_INIT_M0 -1
|
|
|
|
# GCN: bb.3:
|
|
# GCN: SI_INIT_M0 -1
|
|
---
|
|
name: merge-m0-dont-hoist-past-init-with-different-initializer
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.2, %bb.3
|
|
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.2, implicit undef $vcc
|
|
S_BRANCH %bb.3
|
|
|
|
bb.2:
|
|
successors: %bb.4
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.4
|
|
|
|
bb.3:
|
|
successors: %bb.4
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.4
|
|
|
|
bb.4:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: merge-m0-after-prologue
|
|
# GCN: bb.0.entry:
|
|
# GCN-NOT: SI_INIT_M0
|
|
# GCN: S_OR_B64
|
|
# GCN-NEXT: SI_INIT_M0
|
|
|
|
# GCN: bb.1:
|
|
# GCN-NOT: SI_INIT_M0 -1
|
|
|
|
# GCN: bb.2:
|
|
# GCN-NOT: SI_INIT_MO -1
|
|
---
|
|
name: merge-m0-after-prologue
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1, %bb.2
|
|
liveins: $sgpr0_sgpr1
|
|
|
|
$exec = S_OR_B64 $exec, killed $sgpr0_sgpr1, implicit-def $scc
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.1:
|
|
successors: %bb.3
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.3
|
|
|
|
bb.2:
|
|
successors: %bb.3
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.3
|
|
|
|
bb.3:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: move-m0-avoid-hazard
|
|
# GCN: $m0 = S_MOV_B32 -1
|
|
# GCN-NEXT: $vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
# GCN-NEXT: DS_GWS_INIT $vgpr0, 0, implicit $m0, implicit $exec
|
|
---
|
|
name: move-m0-avoid-hazard
|
|
body: |
|
|
bb.0:
|
|
$vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
$m0 = S_MOV_B32 -1
|
|
DS_GWS_INIT $vgpr0, 0, implicit $m0, implicit $exec
|
|
...
|
|
|
|
# GCN-LABEL: name: move-m0-with-prologue
|
|
# GCN: $exec = S_OR_B64 $exec, killed $sgpr0_sgpr1, implicit-def $scc
|
|
# GCN: $m0 = S_MOV_B32 -1
|
|
# GCN-NEXT: $vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
# GCN-NEXT: DS_GWS_INIT $vgpr0, 0, implicit $m0, implicit $exec
|
|
---
|
|
name: move-m0-with-prologue
|
|
body: |
|
|
bb.0:
|
|
liveins: $sgpr0_sgpr1
|
|
|
|
$exec = S_OR_B64 $exec, killed $sgpr0_sgpr1, implicit-def $scc
|
|
$vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
$m0 = S_MOV_B32 -1
|
|
DS_GWS_INIT $vgpr0, 0, implicit $m0, implicit $exec
|
|
...
|
|
|
|
# GCN-LABEL: name: move-m0-different-initializer
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: %0:vgpr_32 = IMPLICIT_DEF
|
|
# GCN: SI_INIT_M0 65536
|
|
# GCN-NEXT: S_NOP
|
|
---
|
|
name: move-m0-different-initializer
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
body: |
|
|
bb.0:
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_NOP 0
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
...
|
|
|
|
# GCN-LABEL: name: move-m0-schedule-boundary
|
|
# GCN: S_SETREG
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
---
|
|
name: move-m0-schedule-boundary
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
body: |
|
|
bb.0:
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
S_SETREG_IMM32_B32 0, 1, implicit-def $mode, implicit $mode
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
...
|
|
|
|
|
|
# GCN-LABEL: name: m0-in-loop-0
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: $m0 = COPY %2
|
|
|
|
---
|
|
name: m0-in-loop-0
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-1
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN-NOT: SI_INIT_M0 -1
|
|
# GCN: DS_WRITE_B32
|
|
|
|
---
|
|
name: m0-in-loop-1
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-2
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
---
|
|
name: m0-in-loop-2
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-3
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
---
|
|
name: m0-in-loop-3
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-4
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
|
|
---
|
|
name: m0-in-loop-4
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-5
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 65536
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
|
|
---
|
|
name: m0-in-loop-5
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.1, %bb.2
|
|
|
|
SI_INIT_M0 65536, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-6
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
|
|
---
|
|
name: m0-in-loop-6
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.2
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
successors: %bb.3, %bb.1
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.3
|
|
|
|
|
|
bb.3:
|
|
S_ENDPGM 0
|
|
...
|
|
|
|
# GCN-LABEL: name: m0-in-loop-7
|
|
# GCN: bb.0.entry:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: IMPLICIT_DEF
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.1:
|
|
# GCN: SI_INIT_M0 -1
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
# GCN-NEXT: DS_WRITE_B32
|
|
|
|
# GCN: bb.2:
|
|
# GCN: $m0 = COPY %2
|
|
# GCN-NEXT: SENDMSG
|
|
|
|
---
|
|
name: m0-in-loop-7
|
|
registers:
|
|
- { id: 0, class: vgpr_32 }
|
|
- { id: 1, class: vgpr_32 }
|
|
- { id: 2, class: sgpr_32 }
|
|
body: |
|
|
bb.0.entry:
|
|
successors: %bb.1
|
|
|
|
%0 = IMPLICIT_DEF
|
|
%1 = IMPLICIT_DEF
|
|
%2 = IMPLICIT_DEF
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.1
|
|
|
|
bb.1:
|
|
successors: %bb.2
|
|
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
SI_INIT_M0 -1, implicit-def $m0
|
|
DS_WRITE_B32 %0, %1, 0, 0, implicit $m0, implicit $exec
|
|
S_BRANCH %bb.2
|
|
|
|
bb.2:
|
|
successors: %bb.3, %bb.1
|
|
$m0 = COPY %2:sgpr_32
|
|
S_SENDMSG 34, implicit $exec, implicit $m0
|
|
S_CBRANCH_VCCZ %bb.1, implicit undef $vcc
|
|
S_BRANCH %bb.3
|
|
|
|
bb.3:
|
|
S_ENDPGM 0
|
|
...
|