<div dir="ltr">It looks like bfd and gold can both start their relro in the middle of a page, but it will extend to the start of the page following the relro region. It seems to be in fact the end address that is rounded down, not the size.<div><div><div><br></div><div>Peter</div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jan 5, 2017 at 1:37 PM, Rafael Avila de Espindola <span dir="ltr"><<a href="mailto:rafael.espindola@gmail.com" target="_blank">rafael.espindola@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
Both bfd and gold seem to have the same bug. Would you mind reporting<br>
this bug to them?<br>
<br>
Thanks,<br>
Rafael<br>
<br>
Peter Collingbourne via llvm-commits <<a href="mailto:llvm-commits@lists.llvm.org">llvm-commits@lists.llvm.org</a>><br>
writes:<br>
<div class="HOEnZb"><div class="h5"><br>
> Author: pcc<br>
> Date: Wed Jan 4 12:56:15 2017<br>
> New Revision: 290986<br>
><br>
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=290986&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=290986&view=rev</a><br>
> Log:<br>
> ELF: Round p_memsz of the PT_GNU_RELRO program header up to the page size.<br>
><br>
> The glibc dynamic loader rounds the size down, so without this the loader<br>
> will fail to change the memory protection for the last page.<br>
><br>
> Differential Revision: <a href="https://reviews.llvm.org/D28267" rel="noreferrer" target="_blank">https://reviews.llvm.org/<wbr>D28267</a><br>
><br>
> Modified:<br>
> lld/trunk/ELF/Writer.cpp<br>
> lld/trunk/test/ELF/basic-mips.<wbr>s<br>
> lld/trunk/test/ELF/basic-ppc.s<br>
><br>
> Modified: lld/trunk/ELF/Writer.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Writer.cpp?rev=290986&r1=290985&r2=290986&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/ELF/Writer.<wbr>cpp?rev=290986&r1=290985&r2=<wbr>290986&view=diff</a><br>
> ==============================<wbr>==============================<wbr>==================<br>
> --- lld/trunk/ELF/Writer.cpp (original)<br>
> +++ lld/trunk/ELF/Writer.cpp Wed Jan 4 12:56:15 2017<br>
> @@ -1444,8 +1444,13 @@ template <class ELFT> void Writer<ELFT>:<br>
> }<br>
> if (P.p_type == PT_LOAD)<br>
> P.p_align = Config->MaxPageSize;<br>
> - else if (P.p_type == PT_GNU_RELRO)<br>
> + else if (P.p_type == PT_GNU_RELRO) {<br>
> P.p_align = 1;<br>
> + // The glibc dynamic loader rounds the size down, so we need to round up<br>
> + // to protect the last page. This is a no-op on FreeBSD which always<br>
> + // rounds up.<br>
> + P.p_memsz = alignTo(P.p_memsz, Config->MaxPageSize);<br>
> + }<br>
><br>
> // The TLS pointer goes after PT_TLS. At least glibc will align it,<br>
> // so round up the size to make sure the offsets are correct.<br>
><br>
> Modified: lld/trunk/test/ELF/basic-mips.<wbr>s<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/basic-mips.s?rev=290986&r1=290985&r2=290986&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/test/ELF/<wbr>basic-mips.s?rev=290986&r1=<wbr>290985&r2=290986&view=diff</a><br>
> ==============================<wbr>==============================<wbr>==================<br>
> --- lld/trunk/test/ELF/basic-mips.<wbr>s (original)<br>
> +++ lld/trunk/test/ELF/basic-mips.<wbr>s Wed Jan 4 12:56:15 2017<br>
> @@ -297,7 +297,7 @@ __start:<br>
> # CHECK-NEXT: VirtualAddress: 0x30000<br>
> # CHECK-NEXT: PhysicalAddress: 0x30000<br>
> # CHECK-NEXT: FileSize: 8<br>
> -# CHECK-NEXT: MemSize: 8<br>
> +# CHECK-NEXT: MemSize: 65536<br>
> # CHECK-NEXT: Flags [ (0x4)<br>
> # CHECK-NEXT: PF_R (0x4)<br>
> # CHECK-NEXT: ]<br>
><br>
> Modified: lld/trunk/test/ELF/basic-ppc.s<br>
> URL: <a href="http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/basic-ppc.s?rev=290986&r1=290985&r2=290986&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/lld/trunk/test/ELF/<wbr>basic-ppc.s?rev=290986&r1=<wbr>290985&r2=290986&view=diff</a><br>
> ==============================<wbr>==============================<wbr>==================<br>
> --- lld/trunk/test/ELF/basic-ppc.s (original)<br>
> +++ lld/trunk/test/ELF/basic-ppc.s Wed Jan 4 12:56:15 2017<br>
> @@ -295,7 +295,7 @@<br>
> // CHECK-NEXT: VirtualAddress: 0x2000<br>
> // CHECK-NEXT: PhysicalAddress: 0x2000<br>
> // CHECK-NEXT: FileSize: 48<br>
> -// CHECK-NEXT: MemSize: 48<br>
> +// CHECK-NEXT: MemSize: 4096<br>
> // CHECK-NEXT: Flags [ (0x4)<br>
> // CHECK-NEXT: PF_R (0x4)<br>
> // CHECK-NEXT: ]<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>
</div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr">-- <div>Peter</div></div></div>
</div>