Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / tools / llvm-reduce / mir / reduce-instruction-unreachable-block.mir
blob1d625df4cf69e05f30718ec9306962cf552783eb
1 # REQUIRES: amdgpu-registered-target
2 # RUN: llvm-reduce -abort-on-invalid-reduction -simplify-mir -mtriple=amdgcn-amd-amdhsa --delta-passes=instructions --test FileCheck --test-arg --check-prefix=CHECK-INTERESTINGNESS --test-arg %s --test-arg --input-file %s -o %t 2> %t.log
3 # RUN: FileCheck --check-prefix=RESULT %s < %t
5 # Make sure there's no crash with unreachable blocks.
7 # CHECK-INTERESTINGNESS: S_NOP
9 # RESULT: bb.0:
11 # RESULT: %{{[0-9]+}}:vgpr_32 = IMPLICIT_DEF
12 # RESULT-NEXT: %{{[0-9]+}}:sreg_64 = IMPLICIT_DEF
13 # RESULT-NEXT: %{{[0-9]+}}:vreg_64 = IMPLICIT_DEF
14 # RESULT-NEXT: S_CBRANCH_SCC1 %bb.1, implicit undef $scc
15 # RESULT-NEXT: S_BRANCH %bb.3
17 # RESULT: bb.1:
18 # RESULT-NEXT: S_BRANCH %bb.3
20 # RESULT: bb.2:
21 # RESULT-NEXT: S_NOP 0, implicit %{{[0-9]+}}, implicit killed %{{[0-9]+}}, implicit %{{[0-9]+}}
23 ---
24 name: unreachable_block
25 tracksRegLiveness: true
26 body:             |
27   bb.0:
28     %0:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
29     S_CBRANCH_SCC1 %bb.1, implicit undef $scc
30     S_BRANCH %bb.3
32   bb.1:
33     %1:sreg_64 = S_MOV_B64 0
34     S_BRANCH %bb.3
36   bb.2:
37     %2:vreg_64 = IMPLICIT_DEF
38     S_NOP 0, implicit %0, implicit killed %2, implicit %1
39     S_BRANCH %bb.3
41   bb.3:
43 ...