| # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py |
| # RUN: llc %s -mtriple aarch64 -run-pass=machine-outliner -o - | FileCheck %s |
| |
| ... |
| --- |
| name: unsafe_range_in_middle |
| tracksRegLiveness: true |
| machineFunctionInfo: |
| hasRedZone: false |
| body: | |
| bb.0: |
| liveins: $x0 |
| ; Begin safe range of 3 instructions |
| ; CHECK-LABEL: name: unsafe_range_in_middle |
| ; CHECK: liveins: $x0 |
| ; CHECK-NEXT: {{ $}} |
| ; CHECK-NEXT: BL @OUTLINED_FUNCTION_0, implicit-def $lr, implicit $sp, implicit-def $lr, implicit-def $x0, implicit-def $x1, implicit-def $x2, implicit-def $x3, implicit-def $x16, implicit $x0, implicit $sp |
| ; CHECK-NEXT: $x9 = ADDXri $x16, 16, 0 |
| ; CHECK-NEXT: $x16 = ADDXri killed $x16, 16, 0 |
| ; CHECK-NEXT: BL @OUTLINED_FUNCTION_0, implicit-def $lr, implicit $sp, implicit-def $lr, implicit-def $x0, implicit-def $x1, implicit-def $x2, implicit-def $x3, implicit-def $x16, implicit $x0, implicit $sp |
| ; CHECK-NEXT: $x9 = ADDXri $x9, 16, 0 |
| ; CHECK-NEXT: $x16 = ADDXri killed $x16, 16, 0 |
| ; CHECK-NEXT: RET undef $x9 |
| $x0 = ADDXri $x0, 0, 0 |
| $x1 = ADDXri $x0, 1, 0 |
| $x2 = ADDXri $x0, 2, 0 |
| $x3 = ADDXri $x0, 3, 0 |
| |
| ; End safe range |
| $x16 = ADDXri $x0, 16, 0 |
| $x9 = ADDXri $x16, 16, 0 |
| $x16 = ADDXri killed $x16, 16, 0 |
| |
| $x0 = ADDXri $x0, 0, 0 |
| $x1 = ADDXri $x0, 1, 0 |
| $x2 = ADDXri $x0, 2, 0 |
| $x3 = ADDXri $x0, 3, 0 |
| ; End safe range |
| $x16 = ADDXri $x0, 16, 0 |
| $x9 = ADDXri $x9, 16, 0 |
| $x16 = ADDXri killed $x16, 16, 0 |
| RET undef $x9 |