diff options
Diffstat (limited to 'llvm/test/CodeGen/RISCV/machine-outliner-patchable.ll')
-rw-r--r-- | llvm/test/CodeGen/RISCV/machine-outliner-patchable.ll | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/RISCV/machine-outliner-patchable.ll b/llvm/test/CodeGen/RISCV/machine-outliner-patchable.ll new file mode 100644 index 000000000000..4ef3abd24157 --- /dev/null +++ b/llvm/test/CodeGen/RISCV/machine-outliner-patchable.ll @@ -0,0 +1,77 @@ +; RUN: llc < %s -verify-machineinstrs -enable-machine-outliner | FileCheck %s + +target triple = "riscv64-unknown-linux-gnu" + +declare void @foo(i32, i32, i32, i32) minsize + +;; TargetOpcode::FENTRY_CALL at the start of the function expands to a __fentry__ +;; call which must be present. Don't outline it. +define void @fentry0(i1 %a) nounwind "fentry-call"="true" { +; CHECK-LABEL: fentry0: +; CHECK-NEXT: # %bb.0: +; CHECK-NEXT: # FEntry call +; CHECK: # %bb.1: +; CHECK-NEXT: call t0, OUTLINED_FUNCTION_1 +entry: + br i1 %a, label %if.then, label %if.end +if.then: + call void @foo(i32 1, i32 2, i32 3, i32 4) + br label %if.end +if.end: + call void @foo(i32 5, i32 6, i32 7, i32 8) + ret void +} + +define void @fentry1(i1 %a) nounwind "fentry-call"="true" { +; CHECK-LABEL: fentry1: +; CHECK-NEXT: # %bb.0: +; CHECK-NEXT: # FEntry call +; CHECK: # %bb.1: +; CHECK-NEXT: call t0, OUTLINED_FUNCTION_1 +entry: + br i1 %a, label %if.then, label %if.end +if.then: + call void @foo(i32 1, i32 2, i32 3, i32 4) + br label %if.end +if.end: + call void @foo(i32 5, i32 6, i32 7, i32 8) + ret void +} + +;; TargetOpcode::PATCHABLE_FUNCTION_ENTER at the start of the function expands to +;; NOPs which must be present. Don't outline them. +define void @patchable0(i1 %a) nounwind "patchable-function-entry"="2" { +; CHECK-LABEL: patchable0: +; CHECK-NEXT: .Lfunc_begin0: +; CHECK-NEXT: # %bb.0: +; CHECK-NEXT: nop +; CHECK-NEXT: nop +; CHECK: # %bb.1: +; CHECK-NEXT: call t0, OUTLINED_FUNCTION_1 +entry: + br i1 %a, label %if.then, label %if.end +if.then: + call void @foo(i32 1, i32 2, i32 3, i32 4) + br label %if.end +if.end: + call void @foo(i32 5, i32 6, i32 7, i32 8) + ret void +} + +define void @patchable1(i1 %a) nounwind "patchable-function-entry"="2" { +; CHECK-LABEL: patchable1: +; CHECK-NEXT: .Lfunc_begin1: +; CHECK-NEXT: # %bb.0: +; CHECK-NEXT: nop +; CHECK-NEXT: nop +; CHECK: # %bb.1: +; CHECK-NEXT: call t0, OUTLINED_FUNCTION_1 +entry: + br i1 %a, label %if.then, label %if.end +if.then: + call void @foo(i32 1, i32 2, i32 3, i32 4) + br label %if.end +if.end: + call void @foo(i32 5, i32 6, i32 7, i32 8) + ret void +} |