# 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