Do not remove IMPLICIT_DEF of a physreg unless all uses have an undef flag added. Previously, only the first use instruction had undef flags added. This will cause a failure in machine instruction verification. Multi-instruction uses tested in AMDGPU/multi-use-implicit-def.mir and X86/multi-use-implicit-def.mir. --------- Signed-off-by: John Lu <John.Lu@amd.com>
50 lines
1.6 KiB
YAML
50 lines
1.6 KiB
YAML
# 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:
|
|
...
|