Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / MachineVerifier / generic-vreg-undef-use.mir
blobaa755ab339f07ff61e2829a54b78245d04030dcd
1 # RUN: not --crash llc -mtriple=aarch64 -o /dev/null -run-pass=none -verify-machineinstrs %s 2>&1 | FileCheck %s
2 # REQUIRES: aarch64-registered-target
4 # Undef uses are illegal for generic vregs.
6 ---
7 name:            test_undef_use
8 liveins:
9 body:             |
10   bb.0:
11     %0:_(s32) = G_CONSTANT i32 0
13     ; Test generic instruction
14     ; CHECK: *** Bad machine code: Generic virtual register use cannot be undef ***
15     G_STORE %0, undef %1:_(p0) :: (store (s32))
17     ; Make sure this fails on a post-isel generic instruction.
18     ; CHECK: *** Bad machine code: Generic virtual register use cannot be undef ***
19     $x0 = COPY undef %2:_(s64)
21     ; Make sure this fails with a target instruction
22     ; CHECK: *** Bad machine code: Generic virtual register use cannot be undef ***
23     RET_ReallyLR implicit $x0, implicit undef %3:_(s32)
24 ...