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