|  |  | 
|  | # RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass machine-cp  -verify-machineinstrs  -o - %s | FileCheck %s | 
|  |  | 
|  | --- | | 
|  | define i32 @copyprop1(i32 %a, i32 %b) { ret i32 %a } | 
|  | define i32 @copyprop2(i32 %a, i32 %b) { ret i32 %a } | 
|  | define i32 @copyprop3(i32 %a, i32 %b) { ret i32 %a } | 
|  | define i32 @copyprop4(i32 %a, i32 %b) { ret i32 %a } | 
|  | define i32 @copyprop5(i32 %a, i32 %b) { ret i32 %a } | 
|  | define i32 @copyprop6(i32 %a, i32 %b) { ret i32 %a } | 
|  | declare i32 @foo(i32) | 
|  | ... | 
|  | --- | 
|  | # The first copy is dead copy which is not used. | 
|  | # CHECK-LABEL: name: copyprop1 | 
|  | # CHECK: bb.0: | 
|  | # CHECK-NOT: $w20 = COPY | 
|  | name: copyprop1 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $w0,  $w1 | 
|  | $w20 = COPY $w1 | 
|  | BL @foo, csr_aarch64_aapcs, implicit $w0, implicit-def $w0 | 
|  | RET_ReallyLR implicit $w0 | 
|  | ... | 
|  | --- | 
|  | # The first copy is not a dead copy which is used in the second copy after the | 
|  | # call. | 
|  | # CHECK-LABEL: name: copyprop2 | 
|  | # CHECK: bb.0: | 
|  | # CHECK: $w20 = COPY | 
|  | name: copyprop2 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $w0,  $w1 | 
|  | $w20 = COPY $w1 | 
|  | BL @foo, csr_aarch64_aapcs, implicit $w0, implicit-def $w0 | 
|  | $w0 = COPY $w20 | 
|  | RET_ReallyLR implicit $w0 | 
|  | ... | 
|  | --- | 
|  | # Both the first and second copy are dead copies which are not used. | 
|  | # CHECK-LABEL: name: copyprop3 | 
|  | # CHECK: bb.0: | 
|  | # CHECK-NOT: COPY | 
|  | name: copyprop3 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $w0,  $w1 | 
|  | $w20 = COPY $w1 | 
|  | BL @foo, csr_aarch64_aapcs, implicit $w0, implicit-def $w0 | 
|  | $w20 = COPY $w0 | 
|  | RET_ReallyLR implicit $w0 | 
|  | ... | 
|  | # The second copy is removed as a NOP copy, after then the first copy become | 
|  | # dead which should be removed as well. | 
|  | # CHECK-LABEL: name: copyprop4 | 
|  | # CHECK: bb.0: | 
|  | # CHECK-NOT: COPY | 
|  | name: copyprop4 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $w0,  $w1 | 
|  | $w20 = COPY $w0 | 
|  | $w0 = COPY $w20 | 
|  | BL @foo, csr_aarch64_aapcs, implicit $w0, implicit-def $w0 | 
|  | RET_ReallyLR implicit $w0 | 
|  | ... | 
|  |  | 
|  | # Don't try to erase any COPY which overlaps itself. | 
|  | # CHECK-LABEL: name: copyprop5 | 
|  | # CHECK: bb.0: | 
|  | # CHECK: COPY killed $q26_q27_q28_q29 | 
|  | # CHECK: COPY killed $q28_q29_q30_q31 | 
|  | name: copyprop5 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $q26_q27_q28_q29 | 
|  | $q28_q29_q30_q31 = COPY killed $q26_q27_q28_q29 | 
|  | $q26_q27_q28_q29 = COPY killed $q28_q29_q30_q31 | 
|  | BL @foo, csr_aarch64_aapcs, implicit killed $q26_q27_q28_q29 | 
|  | RET_ReallyLR | 
|  | ... | 
|  |  | 
|  | # Don't try to analyze any COPY which overlaps itself. | 
|  | # CHECK-LABEL: name: copyprop6 | 
|  | # CHECK: bb.0: | 
|  | # CHECK: COPY killed $q26_q27_q28_q29 | 
|  | # CHECK: $q30 = COPY $q28 | 
|  | name: copyprop6 | 
|  | body: | | 
|  | bb.0: | 
|  | liveins: $q26_q27_q28_q29 | 
|  | $q28_q29_q30_q31 = COPY killed $q26_q27_q28_q29 | 
|  | $q30 = COPY $q28 | 
|  | BL @foo, csr_aarch64_aapcs, implicit killed $q28_q29_q30_q31 | 
|  | RET_ReallyLR | 
|  | ... | 
|  |  |