]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commit - ld/ChangeLog-2015
Start of relro segment adjustment
authorAlan Modra <amodra@gmail.com>
Wed, 1 Apr 2015 08:49:27 +0000 (19:19 +1030)
committerAlan Modra <amodra@gmail.com>
Wed, 1 Apr 2015 09:07:58 +0000 (19:37 +1030)
commit6c1aca3e2d408ef4874bd882a7f0e2cd944bbf09
tree873fa01252fa3f880772a894a9ca15bf8b1e43c8
parent269e9c185f67d477a99574f53ead904d50fddfda
Start of relro segment adjustment

Adjusting the start of the relro segment in order to make it end
exactly on a page boundary runs into difficulties when sections in the
relro segment are aligned;  Adjusting the start by (next_page - end)
sometimes results in more than that adjustment occurring at the end,
overrunning the page boundary.  So when that occurs we try a new lower
start position by masking the adjusted start with the maximum section
alignment.  However, we didn't consider that this masked start address
may in fact be before the initial relro base, which is silly since
that can only increase padding at the relro end.

I've also moved some calculations closer to where they are used, and
comments closer to the relevant statements.

* ldlang.c (lang_size_sections): When alignment of sections
results in relro base adjustment being too large, don't go lower
than the initial value.
* ldexp.c (fold_binary <DATA_SEGMENT_RELRO_END>): Comment.
* scripttempl/elf.sc (DATA_SEGMENT_ALIGN): Omit SEGMENT_SIZE
alignment when SEGMENT_SIZE is the same as MAXPAGESIZE.
ld/ChangeLog
ld/ldexp.c
ld/ldlang.c
ld/scripttempl/elf.sc