forked from OSchip/llvm-project
35 lines
1.0 KiB
ArmAsm
35 lines
1.0 KiB
ArmAsm
// REQUIRES: aarch64
|
|
// RUN: llvm-mc %s -o %t.o -filetype=obj -triple=aarch64-pc-linux
|
|
// RUN: llvm-mc %p/Inputs/aarch64-tls-gdie.s -o %t2.o -filetype=obj -triple=aarch64-pc-linux
|
|
// RUN: ld.lld %t2.o -o %t2.so -shared
|
|
// RUN: ld.lld --hash-style=sysv %t.o %t2.so -o %t
|
|
// RUN: llvm-readobj -s %t | FileCheck --check-prefix=SEC %s
|
|
// RUN: llvm-objdump -d %t | FileCheck %s
|
|
|
|
.globl _start
|
|
_start:
|
|
nop
|
|
adrp x0, :tlsdesc:a
|
|
ldr x1, [x0, :tlsdesc_lo12:a]
|
|
add x0, x0, :tlsdesc_lo12:a
|
|
.tlsdesccall a
|
|
blr x1
|
|
|
|
// SEC: Name: .got
|
|
// SEC-NEXT: Type: SHT_PROGBITS
|
|
// SEC-NEXT: Flags [
|
|
// SEC-NEXT: SHF_ALLOC
|
|
// SEC-NEXT: SHF_WRITE
|
|
// SEC-NEXT: ]
|
|
// SEC-NEXT: Address: 0x2200B0
|
|
|
|
// page(0x2200B0) - page(0x20004) = 65536
|
|
// 0x0B0 = 176
|
|
|
|
// CHECK: _start:
|
|
// CHECK-NEXT: 210000: {{.*}} nop
|
|
// CHECK-NEXT: 210004: {{.*}} adrp x0, #65536
|
|
// CHECK-NEXT: 210008: {{.*}} ldr x0, [x0, #176]
|
|
// CHECK-NEXT: 21000c: {{.*}} nop
|
|
// CHECK-NEXT: 210010: {{.*}} nop
|