|  | # RUN: llc -mtriple=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 | 
|  | ... |