Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / unreachable-mbb-undef-phi.mir
blob1bdbc538626679cc9714501263de5d6a4cebcd36
1 # RUN: llc -mtriple=x86_64-- %s -o - -run-pass=processimpdefs -run-pass=unreachable-mbb-elimination | FileCheck %s
2 ---
3 name:            f
4 tracksRegLiveness: true
5 registers:
6   - { id: 0, class: gr32, preferred-register: '' }
7   - { id: 1, class: gr32, preferred-register: '' }
8   - { id: 2, class: gr32, preferred-register: '' }
9 body:             |
10   bb.0:
11     %0 = IMPLICIT_DEF
12     JMP_1 %bb.1
14   bb.1:
15     %1 = PHI %0, %bb.0, %2, %bb.2
16     %2 = ADD32ri8 killed %1, 1, implicit-def $eflags
17     JMP_1 %bb.3
19   bb.2:
20     JMP_1 %bb.1
22   bb.3:
23 ...
25 # bb2 above is dead and should be removed and the PHI should be replaced with a
26 # COPY from an undef value since the bb0 value in the PHI is undef.
28 # CHECK:  bb.0:
29 # CHECK:    successors: %bb.1
30 # CHECK:    JMP_1 %bb.1
32 # CHECK:  bb.1:
33 # CHECK:    successors: %bb.2
34 # CHECK:    [[TMP1:%[0-9]+]]:gr32 = COPY undef %{{[0-9]+}}
35 # CHECK:    %{{[0-9]+}}:gr32 = ADD32ri8 killed [[TMP1]], 1
36 # CHECK:    JMP_1 %bb.2
38 # CHECK:  bb.2: