|  | # RUN: llc -mtriple=amdgcn--amdpal --start-after=greedy -mcpu=gfx90a -show-mc-encoding  -o - %s | FileCheck %s | 
|  | # RUN: llc -mtriple=amdgcn--amdpal --start-after=greedy -mcpu=gfx802 -show-mc-encoding  -o - %s | FileCheck %s | 
|  |  | 
|  |  | 
|  | # CHECK: indirect_mov:                           ; @indirect_mov | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: v_mov_b32_e32 v16, v1                   ; encoding: [0x01,0x03,0x20,0x7e] | 
|  | # CHECK: v_mov_b32_e32 v0, v3                    ; encoding: [0x03,0x03,0x00,0x7e] | 
|  | # CHECK: ; codeLenInByte = 12 | 
|  |  | 
|  | --- | 
|  | name:            indirect_mov | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  | liveins: $vgpr1, $vgpr0_vgpr1_vgpr2_vgpr3_vgpr4_vgpr5_vgpr6_vgpr7_vgpr8_vgpr9_vgpr10_vgpr11_vgpr12_vgpr13_vgpr14_vgpr15 | 
|  |  | 
|  | $vgpr16 = V_MOV_B32_indirect_read undef $vgpr1, implicit $exec, implicit $m0, implicit $vgpr0_vgpr1_vgpr2_vgpr3_vgpr4_vgpr5_vgpr6_vgpr7_vgpr8_vgpr9_vgpr10_vgpr11_vgpr12_vgpr13_vgpr14_vgpr15 | 
|  | V_MOV_B32_indirect_write undef $vgpr0, undef $vgpr3, implicit $exec, implicit $m0, implicit-def $vgpr0_vgpr1_vgpr2_vgpr3, implicit killed $vgpr0_vgpr1_vgpr2_vgpr3(tied-def 4) | 
|  | ... | 
|  |  | 
|  | # CHECK: meta:                                   ; @meta | 
|  | # CHECK: ; wave barrier | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: ; codeLenInByte = 4 | 
|  | --- | 
|  | name:            meta | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  |  | 
|  | WAVE_BARRIER | 
|  | ... | 
|  |  | 
|  | # CHECK: align4:                                 ; @align4 | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: s_cbranch_scc1 .LBB{{[0-9_]+}}          ; encoding: [A,A,0x85,0xbf] | 
|  | # CHECK: s_barrier                               ; encoding: [0x00,0x00,0x8a,0xbf] | 
|  | # CHECK: .p2align        2 | 
|  | # CHECK: s_endpgm                                ; encoding: [0x00,0x00,0x81,0xbf] | 
|  | # CHECK: ; codeLenInByte = 16 | 
|  |  | 
|  | --- | 
|  | name:            align4 | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  | $scc = IMPLICIT_DEF | 
|  | S_CBRANCH_SCC1 %bb.2, implicit $scc | 
|  |  | 
|  | bb.1: | 
|  | S_BARRIER | 
|  |  | 
|  | bb.2 (align 4): | 
|  | S_ENDPGM 0 | 
|  | ... | 
|  |  | 
|  | # CHECK: align8:                                 ; @align8 | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: s_cbranch_scc1 .LBB{{[0-9_]+}}          ; encoding: [A,A,0x85,0xbf] | 
|  | # CHECK: s_barrier                               ; encoding: [0x00,0x00,0x8a,0xbf] | 
|  | # CHECK: .p2align        3 | 
|  | # CHECK: s_endpgm                                ; encoding: [0x00,0x00,0x81,0xbf] | 
|  | # CHECK: ; codeLenInByte = 20 | 
|  | --- | 
|  | name:            align8 | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  | $scc = IMPLICIT_DEF | 
|  | S_CBRANCH_SCC1 %bb.2, implicit $scc | 
|  |  | 
|  | bb.1: | 
|  | S_BARRIER | 
|  |  | 
|  | bb.2 (align 8): | 
|  | S_ENDPGM 0 | 
|  | ... | 
|  |  | 
|  | # CHECK: align16:                                ; @align16 | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: s_cbranch_scc1 .LBB{{[0-9_]+}}          ; encoding: [A,A,0x85,0xbf] | 
|  | # CHECK: s_barrier                               ; encoding: [0x00,0x00,0x8a,0xbf] | 
|  | # CHECK: .p2align        4 | 
|  | # CHECK: s_endpgm                                ; encoding: [0x00,0x00,0x81,0xbf] | 
|  | # CHECK: ; codeLenInByte = 20 | 
|  | --- | 
|  | name:            align16 | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  | $scc = IMPLICIT_DEF | 
|  | S_CBRANCH_SCC1 %bb.2, implicit $scc | 
|  |  | 
|  | bb.1: | 
|  | S_BARRIER | 
|  |  | 
|  | bb.2 (align 16): | 
|  | S_ENDPGM 0 | 
|  | ... | 
|  |  | 
|  | # CHECK: align32:                                ; @align32 | 
|  | # CHECK: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0) ; encoding: [0x00,0x00,0x8c,0xbf] | 
|  | # CHECK: s_cbranch_scc1 .LBB{{[0-9_]+}}          ; encoding: [A,A,0x85,0xbf] | 
|  | # CHECK: s_barrier                               ; encoding: [0x00,0x00,0x8a,0xbf] | 
|  | # CHECK: .p2align        5 | 
|  | # CHECK: s_endpgm                                ; encoding: [0x00,0x00,0x81,0xbf] | 
|  | # CHECK: ; codeLenInByte = 36 | 
|  | --- | 
|  | name:            align32 | 
|  | tracksRegLiveness: true | 
|  | body:             | | 
|  | bb.0: | 
|  | $scc = IMPLICIT_DEF | 
|  | S_CBRANCH_SCC1 %bb.2, implicit $scc | 
|  |  | 
|  | bb.1: | 
|  | S_BARRIER | 
|  |  | 
|  | bb.2 (align 32): | 
|  | S_ENDPGM 0 | 
|  | ... |