<div dir="ltr">Not directly related to this, but we have code that sets virtual addresses to .tbss sections. Do you know why we are doing that? IIUC, virtual addresses of .tbss sections are not significant, so we can just set them to zero.</div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, May 3, 2017 at 8:00 PM, Rafael Espindola via llvm-commits <span dir="ltr"><<a href="mailto:llvm-commits@lists.llvm.org" target="_blank">llvm-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: rafael<br>
Date: Wed May 3 22:00:27 2017<br>
New Revision: 302107<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=302107&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=302107&view=rev</a><br>
Log:<br>
Fix accounting of tbss.<br>
<br>
We were correctly computing the size contribution of a .tbss input<br>
section (it is none), but we were incorrectly considering the<br>
alignment of the output section: it was advancing Dot instead of<br>
ThreadBssOffset.<br>
<br>
As far as I can tell this was always wrong in our linkerscript<br>
implementation, but that became more visible now that the code is<br>
shared with the non linker script case.<br>
<br>
Modified:<br>
lld/trunk/ELF/LinkerScript.cpp<br>
lld/trunk/ELF/LinkerScript.h<br>
lld/trunk/test/ELF/tls-offset.<wbr>s<br>
<br>
Modified: lld/trunk/ELF/LinkerScript.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.cpp?rev=302107&r1=302106&r2=302107&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/ELF/<wbr>LinkerScript.cpp?rev=302107&<wbr>r1=302106&r2=302107&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- lld/trunk/ELF/LinkerScript.cpp (original)<br>
+++ lld/trunk/ELF/LinkerScript.cpp Wed May 3 22:00:27 2017<br>
@@ -495,17 +495,22 @@ void LinkerScript::<wbr>addOrphanSections(Out<br>
}<br>
}<br>
<br>
-static bool isTbss(OutputSection *Sec) {<br>
- return (Sec->Flags & SHF_TLS) && Sec->Type == SHT_NOBITS;<br>
+uint64_t LinkerScript::advance(uint64_t Size, unsigned Align) {<br>
+ bool IsTbss = (CurOutSec->Flags & SHF_TLS) && CurOutSec->Type == SHT_NOBITS;<br>
+ uint64_t Start = IsTbss ? Dot + ThreadBssOffset : Dot;<br>
+ Start = alignTo(Start, Align);<br>
+ uint64_t End = Start + Size;<br>
+<br>
+ if (IsTbss)<br>
+ ThreadBssOffset = End - Dot;<br>
+ else<br>
+ Dot = End;<br>
+ return End;<br>
}<br>
<br>
void LinkerScript::output(<wbr>InputSection *S) {<br>
- bool IsTbss = isTbss(CurOutSec);<br>
-<br>
- uint64_t Pos = IsTbss ? Dot + ThreadBssOffset : Dot;<br>
- Pos = alignTo(Pos, S->Alignment);<br>
- S->OutSecOff = Pos - CurOutSec->Addr;<br>
- Pos += S->getSize();<br>
+ uint64_t Pos = advance(S->getSize(), S->Alignment);<br>
+ S->OutSecOff = Pos - S->getSize() - CurOutSec->Addr;<br>
<br>
// Update output section size after adding each section. This is so that<br>
// SIZEOF works correctly in the case below:<br>
@@ -524,11 +529,6 @@ void LinkerScript::output(<wbr>InputSection *<br>
" bytes");<br>
}<br>
}<br>
-<br>
- if (IsTbss)<br>
- ThreadBssOffset = Pos - Dot;<br>
- else<br>
- Dot = Pos;<br>
}<br>
<br>
void LinkerScript::switchTo(<wbr>OutputSection *Sec) {<br>
@@ -536,9 +536,7 @@ void LinkerScript::switchTo(<wbr>OutputSectio<br>
return;<br>
<br>
CurOutSec = Sec;<br>
-<br>
- Dot = alignTo(Dot, CurOutSec->Alignment);<br>
- CurOutSec->Addr = isTbss(CurOutSec) ? Dot + ThreadBssOffset : Dot;<br>
+ CurOutSec->Addr = advance(0, CurOutSec->Alignment);<br>
<br>
// If neither AT nor AT> is specified for an allocatable section, the linker<br>
// will set the LMA such that the difference between VMA and LMA for the<br>
<br>
Modified: lld/trunk/ELF/LinkerScript.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.h?rev=302107&r1=302106&r2=302107&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/ELF/<wbr>LinkerScript.h?rev=302107&r1=<wbr>302106&r2=302107&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- lld/trunk/ELF/LinkerScript.h (original)<br>
+++ lld/trunk/ELF/LinkerScript.h Wed May 3 22:00:27 2017<br>
@@ -228,6 +228,7 @@ protected:<br>
MemoryRegion *findMemoryRegion(<wbr>OutputSectionCommand *Cmd);<br>
<br>
void switchTo(OutputSection *Sec);<br>
+ uint64_t advance(uint64_t Size, unsigned Align);<br>
void output(InputSection *Sec);<br>
void process(BaseCommand &Base);<br>
<br>
<br>
Modified: lld/trunk/test/ELF/tls-offset.<wbr>s<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/tls-offset.s?rev=302107&r1=302106&r2=302107&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/test/ELF/<wbr>tls-offset.s?rev=302107&r1=<wbr>302106&r2=302107&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- lld/trunk/test/ELF/tls-offset.<wbr>s (original)<br>
+++ lld/trunk/test/ELF/tls-offset.<wbr>s Wed May 3 22:00:27 2017<br>
@@ -10,7 +10,7 @@<br>
// RUN: .tbss : { *(.tbss) } \<br>
// RUN: .<a href="http://data.rel.ro" rel="noreferrer" target="_blank">data.rel.ro</a> : { *(.<a href="http://data.rel.ro" rel="noreferrer" target="_blank">data.rel.ro</a>) } \<br>
// RUN: }" > %t.script<br>
- // RUN: ld.lld -T %t.script %t -o %tout2<br>
+// RUN: ld.lld -T %t.script %t -o %tout2<br>
// RUN: echo SCRIPT<br>
// RUN: llvm-readobj -s %tout2 | FileCheck %s<br>
.global _start<br>
@@ -61,6 +61,6 @@ _start:<br>
// CHECK-NEXT: SHF_ALLOC<br>
// CHECK-NEXT: SHF_WRITE<br>
// CHECK-NEXT: ]<br>
-// CHECK-NEXT: Address: 0x202010<br>
-// CHECK-NEXT: Offset: 0x2010<br>
+// CHECK-NEXT: Address: 0x202004<br>
+// CHECK-NEXT: Offset: 0x2004<br>
// CHECK-NEXT: Size: 4<br>
<br>
<br>
______________________________<wbr>_________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/llvm-commits</a><br>
</blockquote></div><br></div>