Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / tools / llvm-reduce / mir / subreg-def1.mir
blob31084ad5b739ab7a15fcea0d46b8844b532f7cc6
1 # REQUIRES: amdgpu-registered-target
2 # RUN: llvm-reduce -abort-on-invalid-reduction --delta-passes=instructions -mtriple=amdgcn-amd-amdhsa --test FileCheck --test-arg --check-prefix=CHECK-INTERESTINGNESS --test-arg %s --test-arg --input-file %s -o %t 2> %t.log
3 # RUN: FileCheck --match-full-lines --check-prefix=RESULT %s < %t
5 # CHECK-INTERESTINGNESS: %{{[0-9]+}}.sub0:vreg_64 = V_ADD_U32_e32 %{{[0-9]+}}.sub1, %{{[0-9]+}}.sub0, implicit $exec
6 # CHECK-INTERESTINGNESS: %{{[0-9]+}}.sub0:vreg_64 = V_ADD_U32_e32 4, %{{[0-9]+}}.sub0, implicit $exec
8 # RESULT: undef %{{[0-9]+}}.sub1:vreg_64 = IMPLICIT_DEF
9 # RESULT-NEXT: %0.sub0:vreg_64 = V_ADD_U32_e32 %{{[0-9]+}}.sub1, %{{[0-9]+}}.sub0, implicit $exec
10 # RESULT-NEXT: %1.sub0:vreg_64 = V_ADD_U32_e32 4, %{{[0-9]+}}.sub0, implicit $exec
11 # RESULT-NEXT: S_ENDPGM 0, implicit %{{[0-9]+}}, implicit %{{[0-9]+}}.sub0
12 ---
13 name:            f
14 tracksRegLiveness: true
15 body:             |
16   bb.0:
17     S_WAITCNT 0
18     undef %0.sub1:vreg_64 = V_MOV_B32_e32 0, implicit $exec
19     %1.sub1:vreg_64 = V_ADD_U32_e32 2, %0.sub1, implicit $exec
20     %0.sub0:vreg_64 = V_ADD_U32_e32 %1.sub1, %0.sub0, implicit $exec
21     %1.sub0:vreg_64 = V_ADD_U32_e32 4, %0.sub0, implicit $exec
22     S_ENDPGM 0, implicit %1, implicit %0.sub0
23 ...