| # RUN: llc -o - %s -mtriple=armv7-- -verify-machineinstrs -run-pass=peephole-opt | FileCheck %s | 
 | # | 
 | # Make sure we do not crash on this input. | 
 | # Note that this input could in principle be optimized, but right now we don't | 
 | # have this case implemented so the output should simply be unchanged. | 
 | # | 
 | # CHECK-LABEL: name: func | 
 | # CHECK: body: | | 
 | # CHECK:   bb.0: | 
 | # CHECK:     Bcc %bb.2, 1, undef $cpsr | 
 | # | 
 | # CHECK:   bb.1: | 
 | # CHECK:     %0:dpr = IMPLICIT_DEF | 
 | # CHECK:     %1:gpr, %2:gpr = VMOVRRD %0, 14, $noreg | 
 | # CHECK:     B %bb.3 | 
 | # | 
 | # CHECK:   bb.2: | 
 | # CHECK:     %3:spr = IMPLICIT_DEF | 
 | # CHECK:     %4:gpr = VMOVRS %3, 14, $noreg | 
 | # | 
 | # CHECK:   bb.3: | 
 | # CHECK:     %5:gpr = PHI %1, %bb.1, %4, %bb.2 | 
 | # CHECK:     %6:spr = VMOVSR %5, 14, $noreg | 
 | --- | 
 | name: func0 | 
 | tracksRegLiveness: true | 
 | body: | | 
 |   bb.0: | 
 |     Bcc %bb.2, 1, undef $cpsr | 
 |  | 
 |   bb.1: | 
 |     %0:dpr = IMPLICIT_DEF | 
 |     %1:gpr, %2:gpr = VMOVRRD %0:dpr, 14, $noreg | 
 |     B %bb.3 | 
 |  | 
 |   bb.2: | 
 |     %3:spr = IMPLICIT_DEF | 
 |     %4:gpr = VMOVRS %3:spr, 14, $noreg | 
 |  | 
 |   bb.3: | 
 |     %5:gpr = PHI %1, %bb.1, %4, %bb.2 | 
 |     %6:spr = VMOVSR %5, 14, $noreg | 
 | ... | 
 |  | 
 | # CHECK-LABEL: name: func1 | 
 | # CHECK:    %6:spr = PHI %0, %bb.1, %2, %bb.2 | 
 | # CHEKC:    %7:spr = COPY %6 | 
 | --- | 
 | name: func1 | 
 | tracksRegLiveness: true | 
 | body: | | 
 |   bb.0: | 
 |     Bcc %bb.2, 1, undef $cpsr | 
 |  | 
 |   bb.1: | 
 |     %1:spr = IMPLICIT_DEF | 
 |     %0:gpr = VMOVRS %1, 14, $noreg | 
 |     B %bb.3 | 
 |  | 
 |   bb.2: | 
 |     %3:spr = IMPLICIT_DEF | 
 |     %2:gpr = VMOVRS %3:spr, 14, $noreg | 
 |  | 
 |   bb.3: | 
 |     %4:gpr = PHI %0, %bb.1, %2, %bb.2 | 
 |     %5:spr = VMOVSR %4, 14, $noreg | 
 | ... | 
 |  | 
 | # The current implementation doesn't perform any transformations if undef | 
 | # operands are involved. | 
 | # CHECK-LABEL: name: func-undefops | 
 | # CHECK: body: | | 
 | # CHECK:   bb.0: | 
 | # CHECK:     Bcc %bb.2, 1, undef $cpsr | 
 | # | 
 | # CHECK:   bb.1: | 
 | # CHECK:     %0:gpr = VMOVRS undef %1:spr, 14, $noreg | 
 | # CHECK:     B %bb.3 | 
 | # | 
 | # CHECK:   bb.2: | 
 | # CHECK:     %2:gpr = VMOVRS undef %3:spr, 14, $noreg | 
 | # | 
 | # CHECK:   bb.3: | 
 | # CHECK:     %4:gpr = PHI %0, %bb.1, %2, %bb.2 | 
 | # CHECK:     %5:spr = VMOVSR %4, 14, $noreg | 
 | --- | 
 | name: func-undefops | 
 | tracksRegLiveness: true | 
 | body: | | 
 |   bb.0: | 
 |     Bcc %bb.2, 1, undef $cpsr | 
 |  | 
 |   bb.1: | 
 |     %0:gpr = VMOVRS undef %1:spr, 14, $noreg | 
 |     B %bb.3 | 
 |  | 
 |   bb.2: | 
 |     %2:gpr = VMOVRS undef %3:spr, 14, $noreg | 
 |  | 
 |   bb.3: | 
 |     %4:gpr = PHI %0, %bb.1, %2, %bb.2 | 
 |     %5:spr = VMOVSR %4, 14, $noreg | 
 | ... |