view test/CodeGen/MIR/X86/unreachable-mbb-undef-phi.mir @ 128:c347d3398279 default tip

fix
author mir3636
date Wed, 06 Dec 2017 14:37:17 +0900
parents 803732b1fca8
children
line wrap: on
line source

# RUN: llc -march=x86-64 %s -o - -run-pass=processimpdefs -run-pass=unreachable-mbb-elimination | FileCheck %s
---
name:            f
tracksRegLiveness: true
registers:
  - { id: 0, class: gr32, preferred-register: '' }
  - { id: 1, class: gr32, preferred-register: '' }
  - { id: 2, class: gr32, preferred-register: '' }
body:             |
  bb.0:
    %0 = IMPLICIT_DEF
    JMP_1 %bb.1

  bb.1:
    %1 = PHI %0, %bb.0, %2, %bb.2
    %2 = ADD32ri8 killed %1, 1, implicit-def %eflags
    JMP_1 %bb.3

  bb.2:
    JMP_1 %bb.1

  bb.3:
...

# bb2 above is dead and should be removed and the PHI should be replaced with a
# COPY from an undef value since the bb0 value in the PHI is undef.

# CHECK:  bb.0:
# CHECK:    successors: %bb.1
# CHECK:    JMP_1 %bb.1

# CHECK:  bb.1:
# CHECK:    successors: %bb.2
# CHECK:    [[TMP1:%[0-9]+]]:gr32 = COPY undef %{{[0-9]+}}
# CHECK:    %{{[0-9]+}}:gr32 = ADD32ri8 killed [[TMP1]], 1
# CHECK:    JMP_1 %bb.2

# CHECK:  bb.2: