# RUN: llc -mtriple=x86_64-- -run-pass=peephole-opt %s -o - | FileCheck %s --- | define void @func() { ret void } ... --- # Check that instructions with MI.isBitcast() are only replaced by COPY if there # are no SUBREG_TO_REG users. # CHECK-LABEL: name: func name: func registers: - { id: 0, class: gr32 } - { id: 1, class: fr32 } - { id: 2, class: gr32 } - { id: 3, class: gr32 } - { id: 4, class: fr32 } - { id: 5, class: gr32 } - { id: 6, class: gr64 } body: | bb.0: ; CHECK: %1:fr32 = VMOVDI2SSrr %0 ; CHECK: %7:gr32 = COPY %0 ; CHECK: NOOP implicit %7 %0 = MOV32ri 42 %1 = VMOVDI2SSrr %0 %2 = MOVSS2DIrr %1 NOOP implicit %2 ; CHECK: %4:fr32 = VMOVDI2SSrr %3 ; CHECK-NOT: COPY ; CHECK: %5:gr32 = MOVSS2DIrr %4 ; CHECK: %6:gr64 = SUBREG_TO_REG %5, 0 ; CHECK: NOOP implicit %6 %3 = MOV32ri 42 %4 = VMOVDI2SSrr %3 %5 = MOVSS2DIrr %4 %6 = SUBREG_TO_REG %5, 0, %subreg.sub_32bit NOOP implicit %6 ...