blob: 8e51845c2faa9c0a6552691d38b599a4d0efb562 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
; RUN: llc -mtriple=aarch64-macho -global-isel -stop-after=irtranslator -verify-machineinstrs -o - %s | FileCheck %s --check-prefixes=MACHO,CHECK
; RUN: llc -mtriple=aarch64-elf -global-isel -stop-after=irtranslator -verify-machineinstrs -o - %s | FileCheck %s --check-prefixes=ELF,CHECK
@foo_ifunc = ifunc i32 (i32), ptr @foo_resolver
define internal ptr @foo_resolver() {
; CHECK-LABEL: name: foo_resolver
; CHECK: bb.1.entry:
; CHECK-NEXT: [[C:%[0-9]+]]:_(p0) = G_CONSTANT i64 0
; CHECK-NEXT: $x0 = COPY [[C]](p0)
; CHECK-NEXT: RET_ReallyLR implicit $x0
entry:
ret ptr null
}
define void @caller() {
; MACHO-LABEL: name: caller
; MACHO: bb.1.entry:
; MACHO-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
; MACHO-NEXT: BL @foo_ifunc, csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit-def $w0
; MACHO-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
; MACHO-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $w0
; MACHO-NEXT: RET_ReallyLR
;
; ELF-LABEL: name: caller
; ELF: bb.1.entry:
; ELF-NEXT: [[GV:%[0-9]+]]:gpr64(p0) = G_GLOBAL_VALUE @foo_ifunc
; ELF-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
; ELF-NEXT: BLR [[GV]](p0), csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit-def $w0
; ELF-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
; ELF-NEXT: [[COPY:%[0-9]+]]:_(s32) = COPY $w0
; ELF-NEXT: RET_ReallyLR
entry:
%0 = call i32 @foo_ifunc()
ret void
}