On Thu, Oct 22, 2015 at 7:11 AM, Ilya Verbin <iver...@gmail.com> wrote:
> On Wed, Oct 21, 2015 at 10:44:56 -0700, H.J. Lu wrote:
>> On Wed, Oct 21, 2015 at 10:42 AM, Ilya Verbin <iver...@gmail.com> wrote:
>> > On Wed, Oct 21, 2015 at 10:38:10 -0700, H.J. Lu wrote:
>> >> On Wed, Oct 21, 2015 at 10:33 AM, Ilya Verbin <iver...@gmail.com> wrote:
>> >> > H.J.,
>> >> > Maybe linker should print some warning about joining writable + 
>> >> > nonwritable
>> >> > sections?  Here is a simple testcase:
>> >> >
>> >> > $ cat t1.s
>> >> > .section ".AAA", "a"
>> >> > .long 0x12345678
>> >> > $ cat t2.s
>> >> > .section ".AAA", "wa"
>> >> > .long 0x12345678
>> >> > $ as t1.s -o t1.o
>> >> > $ as t2.s -o t2.o
>> >> > $ ld -shared t1.o t2.o
>> >> > $ ls -lh a.out
>> >> > 2.1M a.out
>> >> >
>> >>
>> >> Does linker make AAA  writable? If yes, linker does what it
>> >> is told.
>> >
>> > Yes, it makes it writable, but why it also makes this?
>> >
>> >   [Nr] Name              Type             Address           Offset
>> >        Size              EntSize          Flags  Link  Info  Align
>> >   [ 0]                   NULL             0000000000000000  00000000
>> >        0000000000000000  0000000000000000           0     0     0
>> >   [ 1] .hash             HASH             00000000000000b0  000000b0
>> >        0000000000000028  0000000000000004   A       2     0     8
>> >   [ 2] .dynsym           DYNSYM           00000000000000d8  000000d8
>> >        0000000000000078  0000000000000018   A       3     2     8
>> >   [ 3] .dynstr           STRTAB           0000000000000150  00000150
>> >        0000000000000019  0000000000000000   A       0     0     1
>> >   [ 4] .AAA              PROGBITS         0000000000000169  00000169
>> >        0000000000000008  0000000000000000  WA       0     0     1
>> >   [ 5] .eh_frame         PROGBITS         0000000000000178  00000178
>> >        0000000000000000  0000000000000000   A       0     0     8
>> >   [ 6] .dynamic          DYNAMIC          0000000000200178  00200178  <-- 
>> > ???
>> >        00000000000000b0  0000000000000010  WA       3     0     8
>> >   [ 7] .shstrtab         STRTAB           0000000000000000  00200380
>> >        0000000000000049  0000000000000000           0     0     1
>> >   [ 8] .symtab           SYMTAB           0000000000000000  00200228
>> >        0000000000000120  0000000000000018           9     9     8
>> >   [ 9] .strtab           STRTAB           0000000000000000  00200348
>> >        0000000000000038  0000000000000000           0     0     1
>> >
>>
>> Linker groups input sections by section name and ors section
>> flags.
>
> Could you please help figure out how this number 0x200178 is calculated?
> ld -verbose doesn't show anything helpful.  It seems that something goes wrong
> during section-to-segment mapping, because when both .AAA have "wa" flags, we
> got small binary with 2 LOAD segments:
>   Type           Offset             VirtAddr           PhysAddr
>                  FileSiz            MemSiz              Flags  Align
>   LOAD           0x0000000000000000 0x0000000000000000 0x0000000000000000
>                  0x00000000000001a8 0x00000000000001a8  R      200000
>   LOAD           0x00000000000001a8 0x00000000002001a8 0x00000000002001a8
>                  0x00000000000000b8 0x00000000000000b8  RW     200000
>
> But when one .AAA has "a" flag, and another .AAA has "wa" flag, we got huge
> binary with only one big LOAD segment:
>   Type           Offset             VirtAddr           PhysAddr
>                  FileSiz            MemSiz              Flags  Align
>   LOAD           0x0000000000000000 0x0000000000000000 0x0000000000000000
>                  0x0000000000200228 0x0000000000200228  RW     200000
>
> BTW, gold produces small binary in both cases.
>

Please open a binutils bug with a testcase.


-- 
H.J.

Reply via email to