blob: 788065fd1391d1fbc85bf41f6dea41a51258d321 [file]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 6
# Ensure processing an IMPLICIT_DEF of a physreg updates all uses
# before removing the IMPLICIT_DEF. -verify-machineinstrs will
# fail otherwise.
# RUN: llc -mtriple=amdgcn -mcpu=gfx802 -run-pass processimpdefs -asm-verbose=0 -verify-machineinstrs %s -o - | FileCheck %s
---
name: implicit_def_multiple_use
tracksRegLiveness: true
body: |
bb.0:
; CHECK-LABEL: name: implicit_def_multiple_use
; CHECK: $vgpr1_lo16 = COPY undef $vgpr0_hi16
; CHECK-NEXT: $vgpr1_hi16 = COPY undef $vgpr0_lo16
; CHECK-NEXT: S_ENDPGM 0
$vgpr0 = IMPLICIT_DEF
$vgpr1_lo16 = COPY $vgpr0_hi16
$vgpr1_hi16 = COPY $vgpr0_lo16
S_ENDPGM 0
...
# IMPLICIT_DEF processing Will not search across basic-blocks for uses. IMPLICIT_DEF must not be deleted.
---
name: implicit_def_cannot_find_all_uses
tracksRegLiveness: true
body: |
; CHECK-LABEL: name: implicit_def_cannot_find_all_uses
; CHECK: bb.0:
; CHECK-NEXT: successors: %bb.0(0x40000000), %bb.1(0x40000000)
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: $vgpr0 = IMPLICIT_DEF
; CHECK-NEXT: $vgpr1_lo16 = COPY undef $vgpr0_hi16
; CHECK-NEXT: $vgpr1_hi16 = COPY undef $vgpr0_lo16
; CHECK-NEXT: $scc = IMPLICIT_DEF
; CHECK-NEXT: S_CBRANCH_SCC1 %bb.0, implicit undef $scc
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: bb.1:
bb.0:
$vgpr0 = IMPLICIT_DEF
$vgpr1_lo16 = COPY $vgpr0_hi16
$vgpr1_hi16 = COPY $vgpr0_lo16
$scc = IMPLICIT_DEF
S_CBRANCH_SCC1 %bb.0, implicit $scc
bb.1:
...