|  | # RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass machine-sink -o - %s | FileCheck %s | 
|  | --- | | 
|  | define void @sinkwzr() { ret void } | 
|  | ... | 
|  | --- | 
|  | name:            sinkwzr | 
|  | tracksRegLiveness: true | 
|  | registers: | 
|  | - { id: 0, class: gpr32 } | 
|  | - { id: 1, class: gpr32 } | 
|  | - { id: 2, class: gpr32sp } | 
|  | - { id: 3, class: gpr32 } | 
|  | - { id: 4, class: gpr32 } | 
|  | body:             | | 
|  | ; Check that WZR copy is sunk into the loop preheader. | 
|  | ; CHECK-LABEL: name: sinkwzr | 
|  | ; CHECK-LABEL: bb.0: | 
|  | ; CHECK-NOT: COPY $wzr | 
|  | bb.0: | 
|  | liveins: $w0 | 
|  |  | 
|  | %0 = COPY $w0 | 
|  | %1 = COPY $wzr | 
|  | CBZW %0, %bb.3 | 
|  |  | 
|  | ; CHECK-LABEL: bb.1: | 
|  | ; CHECK: COPY $wzr | 
|  |  | 
|  | bb.1: | 
|  | B %bb.2 | 
|  |  | 
|  | bb.2: | 
|  | %2 = PHI %0, %bb.1, %4, %bb.2 | 
|  | $w0 = COPY %1 | 
|  | %3 = SUBSWri %2, 1, 0, implicit-def dead $nzcv | 
|  | %4 = COPY %3 | 
|  | CBZW %3, %bb.3 | 
|  | B %bb.2 | 
|  |  | 
|  | bb.3: | 
|  | RET_ReallyLR | 
|  |  | 
|  | ... |