150
|
1 # REQUIRES: aarch64
|
|
2 # RUN: llvm-mc -filetype=obj -triple=aarch64-unknown-freebsd %p/Inputs/aarch64-tls-ie.s -o %tdso.o
|
|
3 # RUN: llvm-mc -filetype=obj -triple=aarch64-unknown-freebsd %s -o %tmain.o
|
|
4 # RUN: ld.lld -shared -soname=tdso.so %tdso.o -o %tdso.so
|
|
5 # RUN: ld.lld --hash-style=sysv %tmain.o %tdso.so -o %tout
|
|
6 # RUN: llvm-objdump -d --no-show-raw-insn %tout | FileCheck %s
|
|
7 # RUN: llvm-readobj -S -r %tout | FileCheck -check-prefix=RELOC %s
|
|
8
|
|
9 # RELOC: Section {
|
|
10 # RELOC: Index:
|
|
11 # RELOC: Name: .got
|
|
12 # RELOC-NEXT: Type: SHT_PROGBITS
|
|
13 # RELOC-NEXT: Flags [
|
|
14 # RELOC-NEXT: SHF_ALLOC
|
|
15 # RELOC-NEXT: SHF_WRITE
|
|
16 # RELOC-NEXT: ]
|
|
17 # RELOC-NEXT: Address: 0x220338
|
|
18 # RELOC-NEXT: Offset: 0x338
|
|
19 # RELOC-NEXT: Size: 16
|
|
20 # RELOC-NEXT: Link: 0
|
|
21 # RELOC-NEXT: Info: 0
|
|
22 # RELOC-NEXT: AddressAlignment: 8
|
|
23 # RELOC-NEXT: EntrySize: 0
|
|
24 # RELOC-NEXT: }
|
|
25 # RELOC: Relocations [
|
|
26 # RELOC-NEXT: Section ({{.*}}) .rela.dyn {
|
|
27 # RELOC-NEXT: 0x220340 R_AARCH64_TLS_TPREL64 bar 0x0
|
|
28 # RELOC-NEXT: 0x220338 R_AARCH64_TLS_TPREL64 foo 0x0
|
|
29 # RELOC-NEXT: }
|
|
30 # RELOC-NEXT:]
|
|
31
|
|
32 ## Page(0x2200B0) - Page(0x210000) = 0x10000 = 65536
|
|
33 ## 0x2200B0 & 0xff8 = 0xB0 = 176
|
|
34 ## Page(0x2200B8) - Page(0x210000) = 0x10000 = 65536
|
|
35 ## 0x2200B8 & 0xff8 = 0xB8 = 184
|
173
|
36 # CHECK: <_start>:
|
150
|
37 # CHECK-NEXT: 210278: adrp x0, #65536
|
|
38 # CHECK-NEXT: 21027c: ldr x0, [x0, #824]
|
|
39 # CHECK-NEXT: 210280: adrp x0, #65536
|
|
40 # CHECK-NEXT: 210284: ldr x0, [x0, #832]
|
|
41
|
|
42 .globl _start
|
|
43 _start:
|
|
44 adrp x0, :gottprel:foo
|
|
45 ldr x0, [x0, #:gottprel_lo12:foo]
|
|
46
|
|
47 adrp x0, :gottprel:bar
|
|
48 ldr x0, [x0, #:gottprel_lo12:bar]
|