Files
llvm-project/llvm/test/CodeGen/AMDGPU/multi-use-implicit-def.mir
LU-JOHN c245d764b8 [CodeGen] Do not remove IMPLICIT_DEF unless all uses have undef flag added (#188133)
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>
2026-04-01 10:11:42 -05:00

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