GNU ld doesn't support multiple SHF_TLS SHT_NOBITS output sections (it restores the address after an SHF_TLS SHT_NOBITS section, so consecutive SHF_TLS SHT_NOBITS sections will have conflicting address ranges). That said, `threadBssOffset` implements limited support for consecutive SHF_TLS SHT_NOBITS sections. (SHF_TLS SHT_PROGBITS following a SHF_TLS SHT_NOBITS can still be incorrect.) `.` in an output section description of an SHF_TLS SHT_NOBITS section is incorrect. (https://lists.llvm.org/pipermail/llvm-dev/2021-July/151974.html) This patch saves the end address of the previous tbss section in `ctx->tbssAddr`, changes `dot` in the beginning of `assignOffset` so that `.` evaluation will be correct. Reviewed By: peter.smith Differential Revision: https://reviews.llvm.org/D107208
44 lines
1.5 KiB
ArmAsm
44 lines
1.5 KiB
ArmAsm
# REQUIRES: x86
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
|
|
# RUN: echo 'SECTIONS { \
|
|
# RUN: . = SIZEOF_HEADERS; \
|
|
# RUN: .text : { *(.text) } \
|
|
# RUN: .tbss : { __tbss_start = .; *(.tbss) __tbss_end = .; } \
|
|
# RUN: second_tbss : { second_tbss_start = .; *(second_tbss) second_tbss_end = .; } \
|
|
# RUN: bar : { *(bar) } \
|
|
# RUN: }' > %t.lds
|
|
# RUN: ld.lld -T %t.lds %t.o -o %t1
|
|
# RUN: llvm-readelf -S -s %t1 | FileCheck %s
|
|
|
|
# RUN: echo 'PHDRS { text PT_LOAD; }' > %th.lds
|
|
# RUN: cat %th.lds %t.lds > %t2.lds
|
|
# RUN: ld.lld -T %t.lds %t.o -o %t2
|
|
# RUN: llvm-readelf -S -s %t2 | FileCheck %s
|
|
|
|
## Test that a tbss section doesn't affect the start address of the next section.
|
|
|
|
# CHECK: Name Type Address Off Size ES Flg
|
|
# CHECK: .tbss NOBITS [[#%x,ADDR:]] [[#%x,OFF:]] 000004 00 WAT
|
|
# CHECK: second_tbss NOBITS {{0+}}[[#%x,ADDR+4]] {{0+}}[[#%x,OFF]] 000001 00 WAT
|
|
# CHECK: bar PROGBITS {{0+}}[[#%x,ADDR]] {{0+}}[[#%x,OFF]] 000004 00 WA
|
|
|
|
## Test that . in a tbss section represents the current location, even if the
|
|
## address will be reset.
|
|
|
|
# CHECK: Value {{.*}} Name
|
|
# CHECK: {{0+}}[[#%x,ADDR]] {{.*}} __tbss_start
|
|
# CHECK: {{0+}}[[#%x,ADDR+4]] {{.*}} __tbss_end
|
|
# CHECK: {{0+}}[[#%x,ADDR+4]] {{.*}} second_tbss_start
|
|
# CHECK: {{0+}}[[#%x,ADDR+5]] {{.*}} second_tbss_end
|
|
|
|
.globl _start
|
|
_start:
|
|
nop
|
|
|
|
.section .tbss,"awT",@nobits
|
|
.long 0
|
|
.section second_tbss,"awT",@nobits
|
|
.byte 0
|
|
.section bar, "aw"
|
|
.long 0
|