ppc64-long-branch-init.s
980 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# REQUIRES: ppc
# RUN: llvm-mc -filetype=obj -triple=powerpc64-pc-freebsd13.0 %s -o %t.o
# RUN: ld.lld %t.o -o %t
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s
## .init consists of sections from several object files. Sections other than the
## last one do not have a terminator. Check we do not create a long branch stub
## in the middle.
## We currently use thunk section spacing to ensure the stub is in the end. This
## is not foolproof but good enough to not break in practice.
# CHECK: Disassembly of section .init:
# CHECK-EMPTY:
# CHECK-LABEL: _init:
# CHECK: blr
# CHECK-EMPTY:
# CHECK-LABEL: __long_branch_foo:
.globl foo
foo:
.space 0x2000000
blr
.section .init,"ax",@progbits,unique,0
.globl _init
_init:
stdu 1, -48(1)
mflr 0
std 0, 64(1)
.section .init,"ax",@progbits,unique,1
bl foo
nop
.section .init,"ax",@progbits,unique,2
bl foo
nop
.section .init,"ax",@progbits,unique,3
ld 1, 0(1)
ld 0, 16(1)
mtlr 0
blr