-
Notifications
You must be signed in to change notification settings - Fork 12.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[lld][ELF] Add basic TLSDESC support for LoongArch
LoongArch does not yet implement transition from TLSDESC to LE/IE, so TLSDESC dynamic relocation needs to be generated for each desc, which is ultimately handled by the dynamic linker. The test cases reference RISC-V: #79239 Reviewed By: MaskRay, SixWeining Pull Request: #94451
- Loading branch information
Showing
6 changed files
with
210 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# REQUIRES: loongarch | ||
# RUN: llvm-mc -filetype=obj -triple=loongarch64 %s -o %t.o | ||
# RUN: ld.lld -shared %t.o -o %t.so | ||
# RUN: llvm-readobj -r %t.so | FileCheck %s --check-prefix=RELA | ||
|
||
## Both TLSDESC and DTPMOD64/DTPREL64 should be present. | ||
# RELA: .rela.dyn { | ||
# RELA-NEXT: 0x[[#%X,ADDR:]] R_LARCH_TLS_DESC64 a 0x0 | ||
# RELA-NEXT: 0x[[#ADDR+16]] R_LARCH_TLS_DTPMOD64 a 0x0 | ||
# RELA-NEXT: 0x[[#ADDR+24]] R_LARCH_TLS_DTPREL64 a 0x0 | ||
# RELA-NEXT: } | ||
|
||
la.tls.gd $a0,a | ||
bl %plt(__tls_get_addr) | ||
|
||
la.tls.desc $a0, a | ||
add.d $a1, $a0, $tp | ||
|
||
.section .tbss,"awT",@nobits | ||
.globl a | ||
.zero 8 | ||
a: | ||
.zero 4 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
# REQUIRES: loongarch | ||
# RUN: rm -rf %t && split-file %s %t && cd %t | ||
# RUN: llvm-mc -filetype=obj -triple=loongarch64 a.s -o a.64.o | ||
# RUN: llvm-mc -filetype=obj -triple=loongarch64 c.s -o c.64.o | ||
# RUN: ld.lld -shared -soname=c.64.so c.64.o -o c.64.so | ||
# RUN: llvm-mc -filetype=obj -triple=loongarch32 --defsym ELF32=1 a.s -o a.32.o | ||
# RUN: llvm-mc -filetype=obj -triple=loongarch32 --defsym ELF32=1 c.s -o c.32.o | ||
# RUN: ld.lld -shared -soname=c.32.so c.32.o -o c.32.so | ||
|
||
# RUN: ld.lld -shared -z now a.64.o c.64.o -o a.64.so | ||
# RUN: llvm-readobj -r -x .got a.64.so | FileCheck --check-prefix=GD64-RELA %s | ||
# RUN: llvm-objdump --no-show-raw-insn -h -d a.64.so | FileCheck %s --check-prefix=GD64 | ||
|
||
# RUN: ld.lld -shared -z now a.64.o c.64.o -o rel.64.so -z rel | ||
# RUN: llvm-readobj -r -x .got rel.64.so | FileCheck --check-prefix=GD64-REL %s | ||
|
||
## FIXME: The transition frome TLSDESC to IE/LE has not yet been implemented. | ||
## Keep the dynamic relocations and hand them over to dynamic linker. | ||
|
||
# RUN: ld.lld -e 0 -z now a.64.o c.64.o -o a.64.le | ||
# RUN: llvm-readobj -r -x .got a.64.le | FileCheck --check-prefix=LE64-RELA %s | ||
|
||
# RUN: ld.lld -e 0 -z now a.64.o c.64.so -o a.64.ie | ||
# RUN: llvm-readobj -r -x .got a.64.ie | FileCheck --check-prefix=IE64-RELA %s | ||
|
||
## 32-bit code is mostly the same. We only test a few variants. | ||
|
||
# RUN: ld.lld -shared -z now a.32.o c.32.o -o rel.32.so -z rel | ||
# RUN: llvm-readobj -r -x .got rel.32.so | FileCheck --check-prefix=GD32-REL %s | ||
|
||
# GD64-RELA: .rela.dyn { | ||
# GD64-RELA-NEXT: 0x20400 R_LARCH_TLS_DESC64 - 0x7FF | ||
# GD64-RELA-NEXT: 0x203E0 R_LARCH_TLS_DESC64 a 0x0 | ||
# GD64-RELA-NEXT: 0x203F0 R_LARCH_TLS_DESC64 c 0x0 | ||
# GD64-RELA-NEXT: } | ||
# GD64-RELA: Hex dump of section '.got': | ||
# GD64-RELA-NEXT: 0x000203e0 00000000 00000000 00000000 00000000 . | ||
# GD64-RELA-NEXT: 0x000203f0 00000000 00000000 00000000 00000000 . | ||
# GD64-RELA-NEXT: 0x00020400 00000000 00000000 00000000 00000000 . | ||
|
||
# GD64-REL: .rel.dyn { | ||
# GD64-REL-NEXT: 0x203E8 R_LARCH_TLS_DESC64 - | ||
# GD64-REL-NEXT: 0x203C8 R_LARCH_TLS_DESC64 a | ||
# GD64-REL-NEXT: 0x203D8 R_LARCH_TLS_DESC64 c | ||
# GD64-REL-NEXT: } | ||
# GD64-REL: Hex dump of section '.got': | ||
# GD64-REL-NEXT: 0x000203c8 00000000 00000000 00000000 00000000 . | ||
# GD64-REL-NEXT: 0x000203d8 00000000 00000000 00000000 00000000 . | ||
# GD64-REL-NEXT: 0x000203e8 00000000 00000000 ff070000 00000000 . | ||
|
||
# GD64: .got 00000030 00000000000203e0 | ||
|
||
## &.got[a]-. = 0x203e0 - 0x102e0: 0x10 pages, page offset 0x3e0 | ||
# GD64: 102e0: pcalau12i $a0, 16 | ||
# GD64-NEXT: addi.d $a0, $a0, 992 | ||
# GD64-NEXT: ld.d $ra, $a0, 0 | ||
# GD64-NEXT: jirl $ra, $ra, 0 | ||
# GD64-NEXT: add.d $a1, $a0, $tp | ||
|
||
## &.got[b]-. = 0x203e0+32 - 0x102f4: 0x10 pages, page offset 0x400 | ||
# GD64: 102f4: pcalau12i $a0, 16 | ||
# GD64-NEXT: addi.d $a0, $a0, 1024 | ||
# GD64-NEXT: ld.d $ra, $a0, 0 | ||
# GD64-NEXT: jirl $ra, $ra, 0 | ||
# GD64-NEXT: add.d $a2, $a0, $tp | ||
|
||
## &.got[c]-. = 0x23e0+16 - 0x10308: 0x10 pages, page offset 0x3f0 | ||
# GD64: 10308: pcalau12i $a0, 16 | ||
# GD64-NEXT: addi.d $a0, $a0, 1008 | ||
# GD64-NEXT: ld.d $ra, $a0, 0 | ||
# GD64-NEXT: jirl $ra, $ra, 0 | ||
# GD64-NEXT: add.d $a3, $a0, $tp | ||
|
||
# LE64-RELA: .rela.dyn { | ||
# LE64-RELA-NEXT: 0x30250 R_LARCH_TLS_DESC64 - 0x8 | ||
# LE64-RELA-NEXT: 0x30260 R_LARCH_TLS_DESC64 - 0x800 | ||
# LE64-RELA-NEXT: 0x30270 R_LARCH_TLS_DESC64 - 0x7FF | ||
# LE64-RELA-NEXT: } | ||
# LE64-RELA: Hex dump of section '.got': | ||
# LE64-RELA-NEXT: 0x00030250 00000000 00000000 00000000 00000000 . | ||
# LE64-RELA-NEXT: 0x00030260 00000000 00000000 00000000 00000000 . | ||
# LE64-RELA-NEXT: 0x00030270 00000000 00000000 00000000 00000000 . | ||
|
||
# IE64-RELA: .rela.dyn { | ||
# IE64-RELA-NEXT: 0x303D8 R_LARCH_TLS_DESC64 - 0x8 | ||
# IE64-RELA-NEXT: 0x303F8 R_LARCH_TLS_DESC64 - 0x7FF | ||
# IE64-RELA-NEXT: 0x303E8 R_LARCH_TLS_DESC64 c 0x0 | ||
# IE64-RELA-NEXT: } | ||
# IE64-RELA: Hex dump of section '.got': | ||
# IE64-RELA-NEXT: 0x000303d8 00000000 00000000 00000000 00000000 . | ||
# IE64-RELA-NEXT: 0x000303e8 00000000 00000000 00000000 00000000 . | ||
# IE64-RELA-NEXT: 0x000303f8 00000000 00000000 00000000 00000000 . | ||
|
||
# GD32-REL: .rel.dyn { | ||
# GD32-REL-NEXT: 0x20270 R_LARCH_TLS_DESC32 - | ||
# GD32-REL-NEXT: 0x20260 R_LARCH_TLS_DESC32 a | ||
# GD32-REL-NEXT: 0x20268 R_LARCH_TLS_DESC32 c | ||
# GD32-REL-NEXT: } | ||
# GD32-REL: Hex dump of section '.got': | ||
# GD32-REL-NEXT: 0x00020260 00000000 00000000 00000000 00000000 . | ||
# GD32-REL-NEXT: 0x00020270 00000000 ff070000 . | ||
|
||
#--- a.s | ||
.macro add dst, src1, src2 | ||
.ifdef ELF32 | ||
add.w \dst, \src1, \src2 | ||
.else | ||
add.d \dst, \src1, \src2 | ||
.endif | ||
.endm | ||
|
||
la.tls.desc $a0, a | ||
add $a1, $a0, $tp | ||
|
||
la.tls.desc $a0, b | ||
add $a2, $a0, $tp | ||
|
||
la.tls.desc $a0, c | ||
add $a3, $a0, $tp | ||
|
||
.section .tbss,"awT",@nobits | ||
.globl a | ||
.zero 8 | ||
a: | ||
.zero 2039 ## Place b at 0x7ff | ||
b: | ||
.zero 1 | ||
|
||
#--- c.s | ||
.section .tbss,"awT",@nobits | ||
.globl c | ||
c: .zero 4 |