blob: 5fccb452e9642b9654888ab18bbcb07e878bbb76 [file] [log] [blame]
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5
# RUN: llc -mtriple arm64-apple-ios -mattr +cmpbr -o - -aarch64-cb-offset-bits=3 \
# RUN: -run-pass=branch-relaxation -verify-machineinstrs -simplify-mir %s | \
# RUN: FileCheck -check-prefix=RELAX %s
# RUN: llc -mtriple arm64-apple-ios -mattr +cmpbr -o - -aarch64-cb-offset-bits=9 \
# RUN: -run-pass=branch-relaxation -verify-machineinstrs -simplify-mir %s | \
# RUN: FileCheck -check-prefix=NO-RELAX %s
---
name: relax_cb
registers:
- { id: 0, class: gpr32 }
- { id: 1, class: gpr32 }
liveins:
- { reg: '$w0', virtual-reg: '%0' }
- { reg: '$w1', virtual-reg: '%1' }
body: |
; RELAX-LABEL: name: relax_cb
; RELAX: bb.0:
; RELAX-NEXT: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
; RELAX-NEXT: [[COPY1:%[0-9]+]]:gpr32 = COPY $w1
; RELAX-NEXT: CBWPrr 1, [[COPY]], [[COPY1]], %bb.1
; RELAX-NEXT: B %bb.2
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: bb.1:
; RELAX-NEXT: [[ADDWrr:%[0-9]+]]:gpr32 = ADDWrr [[COPY]], [[COPY1]]
; RELAX-NEXT: [[ADDWrr1:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr]], [[COPY1]]
; RELAX-NEXT: [[ADDWrr2:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr1]], [[ADDWrr]]
; RELAX-NEXT: [[ADDWrr3:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr2]], [[ADDWrr1]]
; RELAX-NEXT: [[ADDWrr4:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr3]], [[ADDWrr2]]
; RELAX-NEXT: $w0 = ADDWrr [[ADDWrr4]], [[ADDWrr3]]
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: bb.2:
; RELAX-NEXT: RET_ReallyLR implicit $w0
;
; NO-RELAX-LABEL: name: relax_cb
; NO-RELAX: bb.0:
; NO-RELAX-NEXT: successors: %bb.1, %bb.2
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
; NO-RELAX-NEXT: [[COPY1:%[0-9]+]]:gpr32 = COPY $w1
; NO-RELAX-NEXT: CBWPrr 0, [[COPY]], [[COPY1]], %bb.2
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: bb.1:
; NO-RELAX-NEXT: [[ADDWrr:%[0-9]+]]:gpr32 = ADDWrr [[COPY]], [[COPY1]]
; NO-RELAX-NEXT: [[ADDWrr1:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr]], [[COPY1]]
; NO-RELAX-NEXT: [[ADDWrr2:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr1]], [[ADDWrr]]
; NO-RELAX-NEXT: [[ADDWrr3:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr2]], [[ADDWrr1]]
; NO-RELAX-NEXT: [[ADDWrr4:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr3]], [[ADDWrr2]]
; NO-RELAX-NEXT: $w0 = ADDWrr [[ADDWrr4]], [[ADDWrr3]]
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: bb.2:
; NO-RELAX-NEXT: RET_ReallyLR implicit $w0
bb.0:
successors: %bb.1, %bb.2
%0:gpr32 = COPY $w0
%1:gpr32 = COPY $w1
CBWPrr 0, %0, %1, %bb.2
bb.1:
successors: %bb.2
%2:gpr32 = ADDWrr %0, %1
%3:gpr32 = ADDWrr %2, %1
%4:gpr32 = ADDWrr %3, %2
%5:gpr32 = ADDWrr %4, %3
%6:gpr32 = ADDWrr %5, %4
$w0 = ADDWrr %6, %5
bb.2:
RET_ReallyLR implicit $w0
...
---
name: relax_and_split_block
tracksRegLiveness: true
registers:
- { id: 0, class: gpr32 }
- { id: 1, class: gpr32 }
liveins:
- { reg: '$w0', virtual-reg: '%0' }
- { reg: '$w1', virtual-reg: '%1' }
body: |
; RELAX-LABEL: name: relax_and_split_block
; RELAX: bb.0:
; RELAX-NEXT: liveins: $w0, $w1
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
; RELAX-NEXT: [[COPY1:%[0-9]+]]:gpr32 = COPY $w1
; RELAX-NEXT: CBWPrr 1, [[COPY]], [[COPY1]], %bb.3
; RELAX-NEXT: B %bb.2
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: bb.3:
; RELAX-NEXT: liveins: $w0, $w1
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: CBWPrr 0, [[COPY]], [[COPY1]], %bb.1
; RELAX-NEXT: B %bb.2
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: bb.1:
; RELAX-NEXT: liveins: $w0, $w1
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: [[ADDWrr:%[0-9]+]]:gpr32 = ADDWrr [[COPY]], [[COPY1]]
; RELAX-NEXT: [[ADDWrr1:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr]], [[COPY1]]
; RELAX-NEXT: [[ADDWrr2:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr1]], [[ADDWrr]]
; RELAX-NEXT: [[ADDWrr3:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr2]], [[ADDWrr1]]
; RELAX-NEXT: [[ADDWrr4:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr3]], [[ADDWrr2]]
; RELAX-NEXT: $w0 = ADDWrr [[ADDWrr4]], [[ADDWrr3]]
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: bb.2:
; RELAX-NEXT: liveins: $w0, $w1
; RELAX-NEXT: {{ $}}
; RELAX-NEXT: RET_ReallyLR implicit $w0
;
; NO-RELAX-LABEL: name: relax_and_split_block
; NO-RELAX: bb.0:
; NO-RELAX-NEXT: successors: %bb.1, %bb.2
; NO-RELAX-NEXT: liveins: $w0, $w1
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: [[COPY:%[0-9]+]]:gpr32 = COPY $w0
; NO-RELAX-NEXT: [[COPY1:%[0-9]+]]:gpr32 = COPY $w1
; NO-RELAX-NEXT: CBWPrr 0, [[COPY]], [[COPY1]], %bb.2
; NO-RELAX-NEXT: CBWPrr 1, [[COPY]], [[COPY1]], %bb.2
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: bb.1:
; NO-RELAX-NEXT: liveins: $w0, $w1
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: [[ADDWrr:%[0-9]+]]:gpr32 = ADDWrr [[COPY]], [[COPY1]]
; NO-RELAX-NEXT: [[ADDWrr1:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr]], [[COPY1]]
; NO-RELAX-NEXT: [[ADDWrr2:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr1]], [[ADDWrr]]
; NO-RELAX-NEXT: [[ADDWrr3:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr2]], [[ADDWrr1]]
; NO-RELAX-NEXT: [[ADDWrr4:%[0-9]+]]:gpr32 = ADDWrr [[ADDWrr3]], [[ADDWrr2]]
; NO-RELAX-NEXT: $w0 = ADDWrr [[ADDWrr4]], [[ADDWrr3]]
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: bb.2:
; NO-RELAX-NEXT: liveins: $w0, $w1
; NO-RELAX-NEXT: {{ $}}
; NO-RELAX-NEXT: RET_ReallyLR implicit $w0
bb.0:
successors: %bb.1, %bb.2
liveins: $w0, $w1
%0:gpr32 = COPY $w0
%1:gpr32 = COPY $w1
CBWPrr 0, %0, %1, %bb.2
CBWPrr 1, %0, %1, %bb.2
bb.1:
successors: %bb.2
liveins: $w0, $w1
%2:gpr32 = ADDWrr %0, %1
%3:gpr32 = ADDWrr %2, %1
%4:gpr32 = ADDWrr %3, %2
%5:gpr32 = ADDWrr %4, %3
%6:gpr32 = ADDWrr %5, %4
$w0 = ADDWrr %6, %5
bb.2:
liveins: $w0, $w1
RET_ReallyLR implicit $w0
...