| # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5 |
| # RUN: llc -mtriple=amdgcn -mcpu=gfx1150 -run-pass=post-RA-hazard-rec %s -o - | FileCheck -check-prefixes=GFX1150 %s |
| # RUN: llc -mtriple=amdgcn -mcpu=gfx11-generic -run-pass=post-RA-hazard-rec %s -o - | FileCheck -check-prefixes=GFX1150 %s |
| |
| --- | |
| define amdgpu_ps void @end_of_shader() { |
| ret void |
| } |
| define amdgpu_ps void @end_of_shader_return_to_epilogue() { |
| ret void |
| } |
| define amdgpu_ps void @end_of_block() { |
| ret void |
| } |
| define amdgpu_ps void @start_of_block() { |
| ret void |
| } |
| define amdgpu_ps void @block_of_exports() { |
| ret void |
| } |
| define amdgpu_ps void @sparse_exports() { |
| ret void |
| } |
| define amdgpu_ps void @existing_setprio_1() { |
| ret void |
| } |
| define amdgpu_ps void @existing_setprio_2() { |
| ret void |
| } |
| ... |
| |
| --- |
| name: end_of_shader |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| bb.0: |
| liveins: $vgpr0 |
| ; GFX1150-LABEL: name: end_of_shader |
| ; GFX1150: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: end_of_shader_return_to_epilogue |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| bb.0: |
| liveins: $vgpr0 |
| ; GFX1150-LABEL: name: end_of_shader_return_to_epilogue |
| ; GFX1150: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: SI_RETURN_TO_EPILOG $vgpr0 |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| SI_RETURN_TO_EPILOG $vgpr0 |
| ... |
| |
| --- |
| name: end_of_block |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| ; GFX1150-LABEL: name: end_of_block |
| ; GFX1150: bb.0: |
| ; GFX1150-NEXT: successors: %bb.1(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.1: |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| bb.0: |
| liveins: $vgpr0 |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| |
| bb.1: |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: start_of_block |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| ; GFX1150-LABEL: name: start_of_block |
| ; GFX1150: bb.0: |
| ; GFX1150-NEXT: successors: %bb.1(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.1: |
| ; GFX1150-NEXT: successors: %bb.2(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.2: |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| bb.0: |
| liveins: $vgpr0 |
| |
| bb.1: |
| liveins: $vgpr0 |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| |
| bb.2: |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: block_of_exports |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| bb.0: |
| liveins: $vgpr0 |
| ; GFX1150-LABEL: name: block_of_exports |
| ; GFX1150: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: EXP 2, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| EXP 2, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: sparse_exports |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| bb.0: |
| liveins: $vgpr0 |
| ; GFX1150-LABEL: name: sparse_exports |
| ; GFX1150: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: EXP 2, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: $vgpr0 = V_AND_B32_e32 1, $vgpr0, implicit $exec |
| ; GFX1150-NEXT: EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: $vgpr0 = V_OR_B32_e32 2, $vgpr0, implicit $exec |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| EXP 2, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| $vgpr0 = V_AND_B32_e32 1, $vgpr0, implicit $exec |
| EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| $vgpr0 = V_OR_B32_e32 2, $vgpr0, implicit $exec |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: existing_setprio_1 |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| ; GFX1150-LABEL: name: existing_setprio_1 |
| ; GFX1150: bb.0: |
| ; GFX1150-NEXT: successors: %bb.1(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: $vgpr0 = V_AND_B32_e32 1, $vgpr0, implicit $exec |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.1: |
| ; GFX1150-NEXT: successors: %bb.2(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 3 |
| ; GFX1150-NEXT: $vgpr0 = V_OR_B32_e32 2, $vgpr0, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.2: |
| ; GFX1150-NEXT: successors: %bb.3(0x80000000) |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 3 |
| ; GFX1150-NEXT: $vgpr0 = V_OR_B32_e32 3, $vgpr0, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: bb.3: |
| ; GFX1150-NEXT: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| bb.0: |
| liveins: $vgpr0 |
| $vgpr0 = V_AND_B32_e32 1, $vgpr0, implicit $exec |
| |
| bb.1: |
| liveins: $vgpr0 |
| S_SETPRIO 3 |
| $vgpr0 = V_OR_B32_e32 2, $vgpr0, implicit $exec |
| S_SETPRIO 0 |
| |
| bb.2: |
| liveins: $vgpr0 |
| S_SETPRIO 1 |
| $vgpr0 = V_OR_B32_e32 3, $vgpr0, implicit $exec |
| S_SETPRIO 0 |
| |
| bb.3: |
| liveins: $vgpr0 |
| EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| S_ENDPGM 0 |
| ... |
| |
| --- |
| name: existing_setprio_2 |
| tracksRegLiveness: true |
| liveins: |
| - { reg: '$vgpr0' } |
| body: | |
| bb.0: |
| liveins: $vgpr0 |
| ; GFX1150-LABEL: name: existing_setprio_2 |
| ; GFX1150: liveins: $vgpr0 |
| ; GFX1150-NEXT: {{ $}} |
| ; GFX1150-NEXT: S_SETPRIO 3 |
| ; GFX1150-NEXT: EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| ; GFX1150-NEXT: S_SETPRIO 0 |
| ; GFX1150-NEXT: S_WAITCNT_EXPCNT $sgpr_null, 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_NOP 0 |
| ; GFX1150-NEXT: S_SETPRIO 2 |
| ; GFX1150-NEXT: S_SETPRIO 3 |
| ; GFX1150-NEXT: S_ENDPGM 0 |
| S_SETPRIO 3 |
| EXP 1, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| EXP_DONE 0, $vgpr0, $vgpr0, $vgpr0, $vgpr0, -1, -1, 15, implicit $exec |
| S_SETPRIO 3 |
| S_ENDPGM 0 |
| ... |