59 lines
1.5 KiB
ArmAsm
59 lines
1.5 KiB
ArmAsm
# REQUIRES: ppc
|
|
## Test .got2 placed in a different output section.
|
|
|
|
# RUN: rm -rf %t && split-file %s %t
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc %t/a.s -o %t/a.o
|
|
# RUN: llvm-mc -filetype=obj -triple=powerpc %t/b.s -o %t/b.o
|
|
# RUN: ld.lld -shared -T %t/t %t/a.o %t/b.o -o %t/a.so
|
|
# RUN: llvm-readobj -r %t/a.so | FileCheck --check-prefix=RELOC %s
|
|
# RUN: llvm-readelf -S %t/a.so | FileCheck --check-prefix=SEC %s
|
|
|
|
# RELOC: .rela.plt {
|
|
# RELOC-NEXT: 0x1A4 R_PPC_JMP_SLOT f 0x0
|
|
# RELOC-NEXT: }
|
|
|
|
# SEC: .got PROGBITS 0000018c
|
|
# SEC-NEXT: .rodata PROGBITS 00000198
|
|
|
|
## .got2+0x8000-0xb0 = .rodata+4+0x8000-0xb0 = 0x198+4+0x8000-0xb0 = 65536*1-32532
|
|
# CHECK: <_start>:
|
|
# CHECK-NEXT: bcl 20, 31, 0x
|
|
# CHECK-NEXT: b0: mflr 30
|
|
# CHECK-NEXT: addis 30, 30, 1
|
|
# CHECK-NEXT: addi 30, 30, -32532
|
|
# CHECK-NEXT: bl {{.*}} <00008000.got2.plt_pic32.f>
|
|
|
|
## &.got[2] - (.got2+0x8000) = &.got[2] - (.rodata+4+0x8000) = 0x1A4 - (0x198+4+0x8000) = -32760
|
|
# CHECK: <00008000.got2.plt_pic32.f>:
|
|
# CHECK-NEXT: lwz 11, -32760(30)
|
|
# CHECK-NEXT: mtctr 11
|
|
# CHECK-NEXT: bctr
|
|
# CHECK-NEXT: nop
|
|
|
|
#--- a.s
|
|
.section .rodata.cst4,"aM",@progbits,4
|
|
.long 1
|
|
|
|
.section .got2,"aw"
|
|
.long f
|
|
|
|
.text
|
|
.globl _start, f, g
|
|
_start:
|
|
bcl 20,31,.L
|
|
.L:
|
|
mflr 30
|
|
addis 30, 30, .got2+0x8000-.L@ha
|
|
addi 30, 30, .got2+0x8000-.L@l
|
|
bl f+0x8000@plt
|
|
|
|
#--- b.s
|
|
.section .got2,"aw"
|
|
.globl f
|
|
f:
|
|
bl f+0x8000@plt
|
|
|
|
#--- t
|
|
SECTIONS {
|
|
.rodata : { *(.rodata .rodata.*) *(.got2) }
|
|
}
|