view lld/test/ELF/ppc64-long-branch-init.s @ 192:d7606dcf6fce

Added tag llvm10 for changeset 0572611fdcc8
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 14 Dec 2020 18:01:34 +0900
parents 0572611fdcc8
children 2e18cbf3894f
line wrap: on
line source

# 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