| # RUN: llc  -o -  -mtriple=thumbv7--windows-gnu -run-pass=greedy -run-pass=virtregrewriter %s | FileCheck %s | 
 | --- | | 
 |   target datalayout = "e-m:w-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64" | 
 |   target triple = "thumbv7--windows-gnu" | 
 |    | 
 |   define void @subregLiveThrough() { ret void } | 
 |   define void @subregNotLiveThrough() { ret void } | 
 |   define void @subregNotLiveThrough2() { ret void } | 
 |  | 
 | ... | 
 | --- | 
 | # Check that we properly recognize that r1 is live through | 
 | # the first subreg copy. | 
 | # That will materialize as an implicit use of the big register | 
 | # on that copy. | 
 | # PR34107. | 
 | # | 
 | # CHECK-LABEL: name: subregLiveThrough | 
 | name:            subregLiveThrough | 
 | tracksRegLiveness: true | 
 | registers: | 
 |   - { id: 0, class: gprpair } | 
 | body:             | | 
 |   bb.0: | 
 |     liveins: $r0, $r1 | 
 |  | 
 |     ; That copy is being coalesced so we should use a KILL | 
 |     ; placeholder. If that's not a kill that means we probably | 
 |     ; not coalescing %0 and $r0_r1 and thus we are not testing | 
 |     ; the problematic code anymore. | 
 |     ; | 
 |     ; CHECK: $r0 = KILL $r0, implicit killed $r0_r1, implicit-def $r0_r1 | 
 |     ; CHECK-NEXT: $r1 = KILL $r1, implicit killed $r0_r1 | 
 |     undef %0.gsub_0 = COPY $r0 | 
 |     %0.gsub_1 = COPY $r1 | 
 |     tBX_RET 14, $noreg, implicit %0 | 
 |    | 
 |  | 
 | ... | 
 |  | 
 | --- | 
 | # Check that we properly recognize that r1 is *not* live through | 
 | # the first subreg copy. | 
 | # CHECK-LABEL: name: subregNotLiveThrough | 
 | name:            subregNotLiveThrough | 
 | tracksRegLiveness: true | 
 | registers: | 
 |   - { id: 0, class: gprpair } | 
 | body:             | | 
 |   bb.0: | 
 |     liveins: $r0, $r1 | 
 |  | 
 |     ; r1 is not live through so check we are not implicitly using | 
 |     ; the big register. | 
 |     ; CHECK: $r0 = KILL $r0, implicit-def $r0_r1 | 
 |     ; CHECK-NEXT: tBX_RET | 
 |     undef %0.gsub_0 = COPY $r0 | 
 |     tBX_RET 14, $noreg, implicit %0 | 
 |    | 
 |  | 
 | ... | 
 |  | 
 | --- | 
 | # Check that we properly recognize that r1 is *not* live through | 
 | # the first subreg copy. It is defined by this copy, but is not | 
 | # through. | 
 | # CHECK-LABEL: name: subregNotLiveThrough2 | 
 | name:            subregNotLiveThrough2 | 
 | tracksRegLiveness: true | 
 | registers: | 
 |   - { id: 0, class: gprpair } | 
 | body:             | | 
 |   bb.0: | 
 |     liveins: $r0, $r1 | 
 |  | 
 |     ; r1 is not live through so check we are not implicitly using | 
 |     ; the big register. | 
 |     ; CHECK: $r0 = KILL $r0, implicit-def $r1, implicit-def $r0_r1 | 
 |     ; CHECK-NEXT: tBX_RET | 
 |     undef %0.gsub_0 = COPY $r0, implicit-def $r1 | 
 |     tBX_RET 14, $noreg, implicit %0 | 
 |    | 
 |  | 
 | ... |