# RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass machine-outliner -verify-machineinstrs -enable-machine-outliner %s -o - | FileCheck %s --- | ; Function Attrs: minsize declare void @foo(i32, i32, i32, i32) #0 ; Function Attrs: nounwind define void @xray0(i1 %a) #1 { entry: br i1 %a, label %if.then, label %if.end if.then: ; preds = %entry call void @foo(i32 1, i32 2, i32 3, i32 4) br label %if.end if.end: ; preds = %if.then, %entry call void @foo(i32 5, i32 6, i32 7, i32 8) ret void } ; Function Attrs: nounwind define void @xray1(i1 %a) #1 { entry: br i1 %a, label %if.then, label %if.end if.then: ; preds = %entry call void @foo(i32 1, i32 2, i32 3, i32 4) br label %if.end if.end: ; preds = %if.then, %entry call void @foo(i32 5, i32 6, i32 7, i32 8) ret void } attributes #0 = { minsize } attributes #1 = { nounwind "function-instrument"="xray-always" } ... --- name: xray0 tracksRegLiveness: true liveins: - { reg: '$w0', virtual-reg: '' } stack: - { id: 0, name: '', type: spill-slot, offset: -16, size: 8, alignment: 16, stack-id: default, callee-saved-register: '$lr', callee-saved-restored: true, debug-info-variable: '', debug-info-expression: '', debug-info-location: '' } machineFunctionInfo: hasRedZone: false body: | ; CHECK-LABEL: name: xray0 ; CHECK: bb.0.entry: ; CHECK: PATCHABLE_FUNCTION_ENTER ; CHECK: bb.1.if.then: ; CHECK: BL @[[OUTLINED_FUNCTION:OUTLINED_FUNCTION_[0-9]]] ; CHECK: bb.2.if.end: ; CHECK-NEXT: $w0 = MOVZWi 5, 0 ; CHECK-NEXT: $w1 = MOVZWi 6, 0 ; CHECK-NEXT: $w2 = MOVZWi 7, 0 ; CHECK-NEXT: $w3 = MOVZWi 8, 0 ; CHECK-NEXT: BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp ; CHECK: $w0 = MOVZWi 5, 0 ; CHECK-NEXT: $w1 = MOVZWi 6, 0 ; CHECK-NEXT: PATCHABLE_FUNCTION_EXIT ; CHECK-NEXT: RET undef $lr bb.0.entry: successors: %bb.1(0x40000000), %bb.2(0x40000000) liveins: $w0, $lr PATCHABLE_FUNCTION_ENTER early-clobber $sp = frame-setup STRXpre killed $lr, $sp, -16 :: (store (s64) into %stack.0) TBZW killed renamable $w0, 0, %bb.2 bb.1.if.then: successors: %bb.2(0x80000000) $w0 = MOVZWi 1, 0 $w1 = MOVZWi 2, 0 $w2 = MOVZWi 3, 0 $w3 = MOVZWi 4, 0 BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp bb.2.if.end: $w0 = MOVZWi 5, 0 $w1 = MOVZWi 6, 0 $w2 = MOVZWi 7, 0 $w3 = MOVZWi 8, 0 BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp early-clobber $sp, $lr = frame-destroy LDRXpost $sp, 16 :: (load (s64) from %stack.0) $w0 = MOVZWi 5, 0 $w1 = MOVZWi 6, 0 PATCHABLE_FUNCTION_EXIT RET undef $lr ... --- name: xray1 tracksRegLiveness: true liveins: - { reg: '$w0', virtual-reg: '' } stack: - { id: 0, name: '', type: spill-slot, offset: -16, size: 8, alignment: 16, stack-id: default, callee-saved-register: '$lr', callee-saved-restored: true, debug-info-variable: '', debug-info-expression: '', debug-info-location: '' } machineFunctionInfo: hasRedZone: false body: | ; CHECK-LABEL: name: xray1 ; CHECK: bb.0.entry: ; CHECK: PATCHABLE_FUNCTION_ENTER ; CHECK: bb.1.if.then: ; CHECK: BL @[[OUTLINED_FUNCTION]] ; CHECK: bb.2.if.end: ; CHECK-NEXT: $w0 = MOVZWi 5, 0 ; CHECK-NEXT: $w1 = MOVZWi 6, 0 ; CHECK-NEXT: $w2 = MOVZWi 7, 0 ; CHECK-NEXT: $w3 = MOVZWi 8, 0 ; CHECK-NEXT: BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp ; CHECK: $w0 = MOVZWi 5, 0 ; CHECK-NEXT: $w1 = MOVZWi 6, 0 ; CHECK-NEXT: PATCHABLE_FUNCTION_EXIT ; CHECK-NEXT: RET undef $lr bb.0.entry: successors: %bb.1(0x40000000), %bb.2(0x40000000) liveins: $w0, $lr PATCHABLE_FUNCTION_ENTER early-clobber $sp = frame-setup STRXpre killed $lr, $sp, -16 :: (store (s64) into %stack.0) TBZW killed renamable $w0, 0, %bb.2 bb.1.if.then: successors: %bb.2(0x80000000) $w0 = MOVZWi 1, 0 $w1 = MOVZWi 2, 0 $w2 = MOVZWi 3, 0 $w3 = MOVZWi 4, 0 BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp bb.2.if.end: $w0 = MOVZWi 5, 0 $w1 = MOVZWi 6, 0 $w2 = MOVZWi 7, 0 $w3 = MOVZWi 8, 0 BL @foo, csr_aarch64_aapcs, implicit-def dead $lr, implicit $sp, implicit killed $w0, implicit killed $w1, implicit killed $w2, implicit killed $w3, implicit-def $sp early-clobber $sp, $lr = frame-destroy LDRXpost $sp, 16 :: (load (s64) from %stack.0) $w0 = MOVZWi 5, 0 $w1 = MOVZWi 6, 0 PATCHABLE_FUNCTION_EXIT RET undef $lr ; CHECK: name: [[OUTLINED_FUNCTION]] ; CHECK: bb.0: ; CHECK: $w0 = MOVZWi 1, 0 ; CHECK-NEXT: $w1 = MOVZWi 2, 0 ; CHECK-NEXT: $w2 = MOVZWi 3, 0 ; CHECK-NEXT: $w3 = MOVZWi 4, 0 ; CHECK-NEXT: TCRETURNdi @foo, 0, implicit $sp ...