blob: 32ba3afbfe48e638aeff0164aedd97c5cc901632 [file] [log] [blame] [edit]
; RUN: llc -mtriple=powerpc64-ibm-aix-xcoff %s -o - | FileCheck %s --check-prefixes=COMMON,NO-FUNCSECT -DALIGN=3 -DPTR_SIZE=8 -DLOAD=ld -DOFF=16
; RUN: llc -mtriple=powerpc-ibm-aix-xcoff %s -o - | FileCheck %s --check-prefixes=COMMON,NO-FUNCSECT -DALIGN=2 -DPTR_SIZE=4 -DLOAD=lwz -DOFF=8
; RUN: llc -mtriple=powerpc64-ibm-aix-xcoff --function-sections %s -o - | FileCheck %s --check-prefixes=COMMON,FUNCSECT -DALIGN=3 -DPTR_SIZE=8 -DLOAD=ld -DOFF=16
; RUN: llc -mtriple=powerpc-ibm-aix-xcoff --function-sections %s -o - | FileCheck %s --check-prefixes=COMMON,FUNCSECT -DALIGN=2 -DPTR_SIZE=4 -DLOAD=lwz -DOFF=8
; RUN: llc -mtriple=powerpc64-ibm-aix-xcoff --function-sections --code-model=large %s -o - | FileCheck %s --check-prefixes=LARGE -DALIGN=3 -DPTR_SIZE=8 -DLOAD=ld -DOFF=16
; RUN: llc -mtriple=powerpc-ibm-aix-xcoff --function-sections --code-model=large %s -o - | FileCheck %s --check-prefixes=LARGE -DALIGN=2 -DPTR_SIZE=4 -DLOAD=lwz -DOFF=8
;;;; section __ifunc_sec holding the [foo:foo_resolver] pairs
; COMMON: .csect __ifunc_sec[RW],2
; COMMON-NEXT: .align [[ALIGN]]
; COMMON-NEXT: L..__update_foo:
; COMMON-NEXT: .vbyte [[PTR_SIZE]], foo[DS]
; COMMON-NEXT: .vbyte [[PTR_SIZE]], foo.resolver[DS]
;;;; forward declare the __init_ifuncs constructor
; COMMON-NEXT: .extern .__init_ifuncs[PR]
;;;; declare foo[DS] and .foo[PR]
; FUNCSECT-NEXT: .csect .foo[PR],5
; FUNCSECT-NEXT: .ref L..__update_foo
; FUNCSECT-NEXT: .ref .__init_ifuncs[PR]
; FUNCSECT-NEXT: .globl foo[DS]
; FUNCSECT-NEXT: .globl .foo[PR]
; FUNCSECT-NEXT: .align 2
; NO-FUNCSECT-NEXT: .csect ..text..[PR],5
; NO-FUNCSECT-NEXT: .ref L..__update_foo
; NO-FUNCSECT-NEXT: .ref .__init_ifuncs[PR]
; NO-FUNCSECT-NEXT: .globl foo[DS]
; NO-FUNCSECT-NEXT: .globl .foo
; NO-FUNCSECT-NEXT: .align 2
;;;; define foo's descriptor
; COMMON-NEXT: .csect foo[DS],[[ALIGN]]
; FUNCSECT-NEXT: .vbyte [[PTR_SIZE]], .foo[PR]
; NO-FUNCSECT-NEXT: .vbyte [[PTR_SIZE]], .foo
; COMMON-NEXT: .vbyte [[PTR_SIZE]], TOC[TC0]
; COMMON-NEXT: .vbyte [[PTR_SIZE]], 0
;;;; emit foo's body
; FUNCSECT-NEXT: .csect .foo[PR],5
; NO-FUNCSECT-NEXT: .csect ..text..[PR],5
; NO-FUNCSECT-NEXT: .foo:
; COMMON-NEXT: [[LOAD]] 12, [[FOO_TOC:.*]](2)
; COMMON-NEXT: [[LOAD]] 11, [[OFF]](12)
; COMMON-NEXT: [[LOAD]] 12, 0(12)
; COMMON-NEXT: mtctr 12
; COMMON-NEXT: bctr
; -mcmodel=large:
; LARGE: .csect .foo[PR],5
; LARGE: addis 12, [[FOO_TOC:.*]]@u(2)
; LARGE-NEXT: [[LOAD]] 12, [[FOO_TOC]]@l(12)
; LARGE-NEXT: [[LOAD]] 11, [[OFF]](12)
; LARGE-NEXT: [[LOAD]] 12, 0(12)
;;;; foo's TOC entry
; COMMON: [[FOO_TOC]]:
; COMMON-NEXT: .tc foo[TC],foo[DS]
; LARGE: [[FOO_TOC]]:
; LARGE-NEXT: .tc foo[TE],foo[DS]
@foo = ifunc i32 (...), ptr @foo.resolver
define hidden i32 @my_foo() {
entry:
ret i32 4
}
define internal ptr @foo.resolver() {
entry:
ret ptr @my_foo
}