# 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