| # 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 |
| ... |