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