| # RUN: llc -mtriple=aarch64--linux-gnu -run-pass=aarch64-copyelim %s -verify-machineinstrs -o - | FileCheck %s |
| --- |
| # CHECK-LABEL: name: test1 |
| # CHECK: ANDSWri $w0, 1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test1 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $x1, $x2 |
| |
| $w0 = ANDSWri $w0, 1, implicit-def $nzcv |
| STRWui killed $w0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test2 |
| # CHECK: ANDSXri $x0, 1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test2 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2 |
| |
| $x0 = ANDSXri $x0, 1, implicit-def $nzcv |
| STRXui killed $x0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test3 |
| # CHECK: ADDSWri $w0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test3 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $x1, $x2 |
| |
| $w0 = ADDSWri $w0, 1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test4 |
| # CHECK: ADDSXri $x0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test4 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2 |
| |
| $x0 = ADDSXri $x0, 1, 0, implicit-def $nzcv |
| STRXui killed $x0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test5 |
| # CHECK: SUBSWri $w0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test5 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $x1, $x2 |
| |
| $w0 = SUBSWri $w0, 1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test6 |
| # CHECK: SUBSXri $x0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test6 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2 |
| |
| $x0 = SUBSXri $x0, 1, 0, implicit-def $nzcv |
| STRXui killed $x0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test7 |
| # CHECK: ADDSWrr $w0, $w1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test7 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = ADDSWrr $w0, $w1, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test8 |
| # CHECK: ADDSXrr $x0, $x1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test8 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = ADDSXrr $x0, $x1, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test9 |
| # CHECK: ANDSWrr $w0, $w1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test9 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = ANDSWrr $w0, $w1, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test10 |
| # CHECK: ANDSXrr $x0, $x1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test10 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = ANDSXrr $x0, $x1, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test11 |
| # CHECK: BICSWrr $w0, $w1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test11 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = BICSWrr $w0, $w1, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test12 |
| # CHECK: BICSXrr $x0, $x1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test12 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = BICSXrr $x0, $x1, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test13 |
| # CHECK: SUBSWrr $w0, $w1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test13 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = SUBSWrr $w0, $w1, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test14 |
| # CHECK: SUBSXrr $x0, $x1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test14 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = SUBSXrr $x0, $x1, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test15 |
| # CHECK: ADDSWrs $w0, $w1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test15 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = ADDSWrs $w0, $w1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test16 |
| # CHECK: ADDSXrs $x0, $x1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test16 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = ADDSXrs $x0, $x1, 0, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test17 |
| # CHECK: ANDSWrs $w0, $w1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test17 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = ANDSWrs $w0, $w1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test18 |
| # CHECK: ANDSXrs $x0, $x1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $xzr |
| name: test18 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2, $x3 |
| |
| $x0 = ANDSXrs $x0, $x1, 0, implicit-def $nzcv |
| STRXui killed $x0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $x0 = COPY $xzr |
| STRXui killed $x0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # CHECK-LABEL: name: test19 |
| # CHECK: BICSWrs $w0, $w1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: COPY $wzr |
| name: test19 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $w1, $x2, $x3 |
| |
| $w0 = BICSWrs $w0, $w1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x2, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x3 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x3, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # Unicorn test - we can remove a redundant copy and a redundant mov |
| # CHECK-LABEL: name: test20 |
| # CHECK: SUBSWri $w1, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK-NOT: $w0 = COPY $wzr |
| # CHECK-NOT: $w1 = MOVi32imm 1 |
| name: test20 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w1, $x2 |
| |
| $w0 = SUBSWri $w1, 1, 0, implicit-def $nzcv |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| $w1 = MOVi32imm 1 |
| STRWui killed $w0, $x2, 0 |
| STRWui killed $w1, killed $x2, 1 |
| |
| bb.2: |
| RET_ReallyLR |
| |
| ... |
| # Negative test - MOVi32imm clobbers $w0 |
| # CHECK-LABEL: name: test21 |
| # CHECK: ANDSWri $w0, 1, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK: $w0 = COPY $wzr |
| name: test21 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $x1, $x2 |
| |
| $w0 = ANDSWri $w0, 1, implicit-def $nzcv |
| STRWui killed $w0, $x1, 0 |
| $w0 = MOVi32imm -1 |
| STRWui killed $w0, killed $x1, 1 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # Negative test - SUBSXri self-clobbers x0, so MOVi64imm can't be removed |
| # CHECK-LABEL: name: test22 |
| # CHECK: SUBSXri $x0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK: $x0 = MOVi64imm 1 |
| name: test22 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $x0, $x1, $x2 |
| |
| $x0 = SUBSXri $x0, 1, 0, implicit-def $nzcv |
| STRXui killed $x0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $x0 = MOVi64imm 1 |
| STRXui killed $x0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |
| ... |
| # Negative test - bb.1 has multiple preds |
| # CHECK-LABEL: name: test23 |
| # CHECK: ADDSWri $w0, 1, 0, implicit-def $nzcv |
| # CHECK: bb.1: |
| # CHECK: COPY $wzr |
| name: test23 |
| tracksRegLiveness: true |
| body: | |
| bb.0.entry: |
| liveins: $w0, $x1, $x2 |
| |
| $w0 = ADDSWri $w0, 1, 0, implicit-def $nzcv |
| STRWui killed $w0, killed $x1, 0 |
| Bcc 1, %bb.2, implicit killed $nzcv |
| B %bb.1 |
| |
| bb.3: |
| B %bb.1 |
| |
| bb.1: |
| liveins: $x2 |
| |
| $w0 = COPY $wzr |
| STRWui killed $w0, killed $x2, 0 |
| |
| bb.2: |
| RET_ReallyLR |