2019-06-07 08:14:45 +08:00
|
|
|
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
|
2021-03-20 09:29:08 +08:00
|
|
|
# RUN: llc -march=amdgcn -mcpu=polaris10 -run-pass si-pre-emit-peephole -amdgpu-skip-threshold=1 -verify-machineinstrs %s -o - | FileCheck %s
|
2019-06-07 08:14:45 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
name: skip_execz_flat
|
|
|
|
body: |
|
|
|
|
; CHECK-LABEL: name: skip_execz_flat
|
|
|
|
; CHECK: bb.0:
|
2019-06-08 01:55:07 +08:00
|
|
|
; CHECK: successors: %bb.1(0x40000000), %bb.2(0x40000000)
|
2019-06-07 08:14:45 +08:00
|
|
|
; CHECK: S_CBRANCH_EXECZ %bb.2, implicit $exec
|
|
|
|
; CHECK: bb.1:
|
|
|
|
; CHECK: successors: %bb.2(0x80000000)
|
|
|
|
; CHECK: $vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; CHECK: FLAT_STORE_DWORD undef $vgpr1_vgpr2, $vgpr0, 0, 0, implicit $exec, implicit $flat_scr
|
2019-06-07 08:14:45 +08:00
|
|
|
; CHECK: bb.2:
|
|
|
|
; CHECK: S_ENDPGM 0
|
|
|
|
bb.0:
|
2019-06-08 01:55:07 +08:00
|
|
|
successors: %bb.1, %bb.2
|
2021-02-25 09:19:37 +08:00
|
|
|
S_CBRANCH_EXECZ %bb.2, implicit $exec
|
2019-06-07 08:14:45 +08:00
|
|
|
|
|
|
|
bb.1:
|
|
|
|
successors: %bb.2
|
|
|
|
$vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
FLAT_STORE_DWORD undef $vgpr1_vgpr2, $vgpr0, 0, 0, implicit $exec, implicit $flat_scr
|
2019-06-07 08:14:45 +08:00
|
|
|
|
|
|
|
bb.2:
|
|
|
|
S_ENDPGM 0
|
|
|
|
...
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
name: skip_execz_mubuf
|
|
|
|
body: |
|
|
|
|
; CHECK-LABEL: name: skip_execz_mubuf
|
|
|
|
; CHECK: bb.0:
|
2019-06-08 01:55:07 +08:00
|
|
|
; CHECK: successors: %bb.1(0x40000000), %bb.2(0x40000000)
|
2019-06-07 08:14:45 +08:00
|
|
|
; CHECK: S_CBRANCH_EXECZ %bb.2, implicit $exec
|
|
|
|
; CHECK: bb.1:
|
|
|
|
; CHECK: successors: %bb.2(0x80000000)
|
|
|
|
; CHECK: $vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
; CHECK: BUFFER_STORE_DWORD_OFFSET $vgpr0, undef $sgpr0_sgpr1_sgpr2_sgpr3, undef $sgpr4, 0, 0, 0, 0, implicit $exec
|
2019-06-07 08:14:45 +08:00
|
|
|
; CHECK: bb.2:
|
|
|
|
; CHECK: S_ENDPGM 0
|
|
|
|
bb.0:
|
2019-06-08 01:55:07 +08:00
|
|
|
successors: %bb.1, %bb.2
|
2021-02-25 09:19:37 +08:00
|
|
|
S_CBRANCH_EXECZ %bb.2, implicit $exec
|
2019-06-07 08:14:45 +08:00
|
|
|
|
|
|
|
bb.1:
|
|
|
|
successors: %bb.2
|
|
|
|
$vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
2021-02-09 08:36:10 +08:00
|
|
|
BUFFER_STORE_DWORD_OFFSET $vgpr0, undef $sgpr0_sgpr1_sgpr2_sgpr3, undef $sgpr4, 0, 0, 0, 0, implicit $exec
|
2019-06-07 08:14:45 +08:00
|
|
|
|
|
|
|
bb.2:
|
|
|
|
S_ENDPGM 0
|
|
|
|
...
|
2021-03-04 17:39:42 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
name: skip_execz_ds
|
|
|
|
body: |
|
|
|
|
; CHECK-LABEL: name: skip_execz_ds
|
|
|
|
; CHECK: bb.0:
|
|
|
|
; CHECK: successors: %bb.1(0x40000000), %bb.2(0x40000000)
|
|
|
|
; CHECK: S_CBRANCH_EXECZ %bb.2, implicit $exec
|
|
|
|
; CHECK: bb.1:
|
|
|
|
; CHECK: successors: %bb.2(0x80000000)
|
|
|
|
; CHECK: $vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
|
|
; CHECK: DS_WRITE_B32 $vgpr0, $vgpr0, 0, 0, implicit $m0, implicit $exec
|
|
|
|
; CHECK: bb.2:
|
|
|
|
; CHECK: S_ENDPGM 0
|
|
|
|
bb.0:
|
|
|
|
successors: %bb.1, %bb.2
|
2021-02-25 09:19:37 +08:00
|
|
|
S_CBRANCH_EXECZ %bb.2, implicit $exec
|
2021-03-04 17:39:42 +08:00
|
|
|
|
|
|
|
bb.1:
|
|
|
|
successors: %bb.2
|
|
|
|
$vgpr0 = V_MOV_B32_e32 0, implicit $exec
|
|
|
|
DS_WRITE_B32 $vgpr0, $vgpr0, 0, 0, implicit $m0, implicit $exec
|
|
|
|
|
|
|
|
bb.2:
|
|
|
|
S_ENDPGM 0
|
|
|
|
...
|