2020-04-22 17:55:34 +02:00
|
|
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
|
2020-07-21 19:27:18 +02:00
|
|
|
; RUN: -mcpu=pwr10 -ppc-asm-full-reg-names < %s | FileCheck %s
|
|
|
|
; RUN: llc -verify-machineinstrs -target-abi=elfv2 -mtriple=powerpc64-- \
|
|
|
|
; RUN: -mcpu=pwr10 -ppc-asm-full-reg-names < %s | FileCheck %s
|
|
|
|
|
2020-04-22 17:55:34 +02:00
|
|
|
|
|
|
|
; The test checks the behavior of PC Relative indirect calls. When using
|
|
|
|
; PC Relative, TOC save and restore are no longer required. Function pointer
|
|
|
|
; is passed as a parameter in this test.
|
|
|
|
|
|
|
|
; Function Attrs: noinline
|
|
|
|
define dso_local void @IndirectCallExternFuncPtr(void ()* nocapture %ptrfunc) {
|
|
|
|
; CHECK-LABEL: IndirectCallExternFuncPtr:
|
|
|
|
; CHECK: # %bb.0: # %entry
|
|
|
|
; CHECK-NEXT: mtctr r3
|
|
|
|
; CHECK-NEXT: mr r12, r3
|
2020-04-24 04:04:11 +02:00
|
|
|
; CHECK-NEXT: bctr
|
|
|
|
; CHECK-NEXT: #TC_RETURNr8 ctr
|
2020-04-22 17:55:34 +02:00
|
|
|
entry:
|
|
|
|
tail call void %ptrfunc()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define dso_local void @FuncPtrPassAsParam() {
|
|
|
|
entry:
|
|
|
|
tail call void @IndirectCallExternFuncPtr(void ()* nonnull @Function)
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
declare void @Function()
|