Mercurial > hg > CbC > CbC_llvm
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