|
| 1 | +# RUN: llc -mtriple=aarch64-linux-gnu -verify-machineinstrs -o - %s -start-before=phi-node-elimination -stop-after=block-placement | FileCheck %s |
| 2 | + |
| 3 | +# TODO: Reduce test case. |
| 4 | +# CHECK-NOT: CBNZX |
| 5 | + |
| 6 | +--- |
| 7 | +name: test |
| 8 | +tracksRegLiveness: true |
| 9 | +body: | |
| 10 | + bb.0: |
| 11 | + liveins: $x0, $w1, $x2, $x3 |
| 12 | + %42:gpr64all = COPY killed $x0 |
| 13 | + %41:gpr32all = COPY killed $w1 |
| 14 | + %120:gpr64common = COPY killed $x2 |
| 15 | + %121:gpr64common = COPY killed $x3 |
| 16 | + B %bb.20 |
| 17 | +
|
| 18 | + bb.20: |
| 19 | + successors: %bb.21(0x30000000), %bb.22(0x50000000); %bb.21(37.50%), %bb.22(62.50%) |
| 20 | +
|
| 21 | + %43:gpr64common = PHI %42:gpr64all, %bb.0, %55:gpr64common, %bb.28 |
| 22 | + %44:gpr32all = PHI %41:gpr32all, %bb.0, %57:gpr32all, %bb.28 |
| 23 | + %144:gpr64 = LDRXui %121:gpr64common, 0 :: (load (s64)) |
| 24 | + %145:gpr64 = LDRXui %43:gpr64common, 0 :: (load (s64)) |
| 25 | + %146:gpr64 = EORXrr killed %145:gpr64, killed %144:gpr64 |
| 26 | + STRXui killed %43:gpr64common, %121:gpr64common, 0 :: (store (s64)) |
| 27 | + STRXui %146:gpr64, %121:gpr64common, 1 :: (store (s64)) |
| 28 | + %147:gpr64 = LDRXui %120:gpr64common, 1 :: (load (s64)) |
| 29 | + CBNZX %147:gpr64, %bb.22 |
| 30 | +
|
| 31 | + bb.21: |
| 32 | + successors: %bb.26(0x80000000); %bb.26(100.00%) |
| 33 | +
|
| 34 | + %45:gpr64all = COPY killed %146:gpr64 |
| 35 | + B %bb.26 |
| 36 | +
|
| 37 | + bb.22: |
| 38 | + successors: %bb.23(0x80000000); %bb.23(100.00%) |
| 39 | +
|
| 40 | + %46:gpr64all = COPY killed %147:gpr64 |
| 41 | + %148:gpr64 = LDRXui %120:gpr64common, 0 :: (load (s64)) |
| 42 | + %47:gpr64all = COPY killed %148:gpr64 |
| 43 | +
|
| 44 | + bb.23: |
| 45 | + successors: %bb.25(0x04000000), %bb.24(0x7c000000); %bb.25(3.12%), %bb.24(96.88%) |
| 46 | +
|
| 47 | + %48:gpr32common = PHI %44:gpr32all, %bb.22, %51:gpr32all, %bb.24 |
| 48 | + %49:gpr64common = PHI %46:gpr64all, %bb.22, %52:gpr64all, %bb.24 |
| 49 | + %50:gpr64 = PHI %47:gpr64all, %bb.22, %49:gpr64common, %bb.24 |
| 50 | + %149:gpr32 = LDRWui %49:gpr64common, 2 :: (load (s32)) |
| 51 | + %150:gpr32common = nsw ADDWri %48:gpr32common, 1, 0 |
| 52 | + dead $wzr = SUBSWrr killed %149:gpr32, killed %150:gpr32common, implicit-def $nzcv |
| 53 | + Bcc 12, %bb.25, implicit killed $nzcv |
| 54 | + B %bb.24 |
| 55 | +
|
| 56 | + bb.24: |
| 57 | + successors: %bb.25(0x04000000), %bb.23(0x7c000000); %bb.25(3.12%), %bb.23(96.88%) |
| 58 | +
|
| 59 | + %152:gpr32 = LDRWui %49:gpr64common, 3 :: (load (s32)) |
| 60 | + dead $wzr = SUBSWrr %48:gpr32common, %152:gpr32, implicit-def $nzcv |
| 61 | + %154:gpr32 = CSELWr killed %48:gpr32common, killed %152:gpr32, 12, implicit killed $nzcv |
| 62 | + %51:gpr32all = COPY killed %154:gpr32 |
| 63 | + %155:gpr64 = LDRXui %49:gpr64common, 0 :: (load (s64)) |
| 64 | + %156:gpr64 = EORXrr %155:gpr64, %50:gpr64 |
| 65 | + %52:gpr64all = COPY %156:gpr64 |
| 66 | + STRXui %49:gpr64common, %120:gpr64common, 0 :: (store (s64)) |
| 67 | + STRXui killed %156:gpr64, %120:gpr64common, 1 :: (store (s64)) |
| 68 | + dead $xzr = SUBSXrr killed %155:gpr64, killed %50:gpr64, implicit-def $nzcv |
| 69 | + Bcc 1, %bb.23, implicit killed $nzcv |
| 70 | + B %bb.25 |
| 71 | +
|
| 72 | + bb.25: |
| 73 | + successors: %bb.26(0x80000000); %bb.26(100.00%) |
| 74 | +
|
| 75 | + %53:gpr32all = PHI %48:gpr32common, %bb.23, %51:gpr32all, %bb.24 |
| 76 | + %158:gpr64 = LDRXui %121:gpr64common, 1 :: (load (s64)) |
| 77 | + %54:gpr64all = COPY killed %158:gpr64 |
| 78 | +
|
| 79 | + bb.26: |
| 80 | + successors: %bb.29(0x04000000), %bb.27(0x7c000000); %bb.29(3.12%), %bb.27(96.88%) |
| 81 | +
|
| 82 | + %55:gpr64common = PHI %45:gpr64all, %bb.21, %54:gpr64all, %bb.25 |
| 83 | + %56:gpr32common = PHI %44:gpr32all, %bb.21, %53:gpr32all, %bb.25 |
| 84 | + CBZX %55:gpr64common, %bb.29 |
| 85 | + B %bb.27 |
| 86 | +
|
| 87 | + bb.27: |
| 88 | + successors: %bb.29(0x04000000), %bb.28(0x7c000000); %bb.29(3.12%), %bb.28(96.88%) |
| 89 | +
|
| 90 | + %159:gpr32 = LDRWui %55:gpr64common, 2 :: (load (s32)) |
| 91 | + %160:gpr32common = nsw ADDWri %56:gpr32common, 1, 0 |
| 92 | + dead $wzr = SUBSWrr killed %159:gpr32, killed %160:gpr32common, implicit-def $nzcv |
| 93 | + Bcc 12, %bb.29, implicit killed $nzcv |
| 94 | + B %bb.28 |
| 95 | +
|
| 96 | + bb.28: |
| 97 | + successors: %bb.20(0x80000000); %bb.20(100.00%) |
| 98 | +
|
| 99 | + %162:gpr32 = LDRWui %55:gpr64common, 3 :: (load (s32)) |
| 100 | + dead $wzr = SUBSWrr %56:gpr32common, %162:gpr32, implicit-def $nzcv |
| 101 | + %164:gpr32 = CSELWr killed %56:gpr32common, killed %162:gpr32, 12, implicit killed $nzcv |
| 102 | + %57:gpr32all = COPY killed %164:gpr32 |
| 103 | + B %bb.20 |
| 104 | +
|
| 105 | + bb.29: |
| 106 | + RET_ReallyLR |
| 107 | +... |
0 commit comments