# 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 ...