This is an archive of the discontinued LLVM Phabricator instance.

[ELF] - Reveal layout of synthetic mergeable sections when producing -Map
AbandonedPublic

Authored by grimar on Nov 16 2017, 6:56 AM.

Details

Reviewers
ruiu
rafael
Summary

It is inspired by comments for PR35248 though not directly relative to it.
It turns out we do not show the internal layout for mergeable sections when
producing Map file. Though it can be useful to show where is content coming from and
what is initial size (before mrging) and final size.
Patch adds support for dumping such sections.

Diff Detail

Event Timeline

grimar created this revision.Nov 16 2017, 6:56 AM
ruiu edited edge metadata.Nov 16 2017, 7:26 PM

How is this useful? Also, this change creates a malformed output that breaks the assumption that the 6th column contains symbol names.

grimar added a comment.EditedNov 17 2017, 12:25 AM
In D40128#928250, @ruiu wrote:

How is this useful?

Isn't one of intentions of map file to show where are sections coming from ? Currently we don't print
file names for SHF_MERGE sections, that looks inconsistent with how we dump regular sections.

Also I think it can be useful to show difference between input and output size. That can be applied for mergeable
sections and also for compressed input/output ones.

Also, this change creates a malformed output that breaks the assumption that the 6th column contains symbol names.

Oops, I missed header says its should be symbol, sorry.

Will it make sence to omit synthetic part (which is there only because of our internal representation and not useful)
and print something like following then ?

Address          Size                 Align      Out           In
0000000000000000 0000000000000008     2          .strings
0000000000000000 0000000000000004     1                        {{.*}}{{/|\\}}map-file.s.tmp1.o:(.strings)
0000000000000000 0000000000000008     2                        {{.*}}{{/|\\}}map-file.s.tmp2.o:(.strings)
ruiu added a comment.Nov 17 2017, 12:38 AM

First of all, the current output is consistent. It doesn't print out the information about mergeable input sections that consist make up an mergeable synthetic section, but that doesn't mean that the output is inconsistent.

So, back to the original question, I don't think the format you are proposing is useful for a few reasons:

  • Address and size fields contains bogus values. So you cannot use these numbers to analyze the output
  • There's no good way of printing out input sections that make up a synthetic section in the current format

I think the fundamental issue of this patch is that the information you are trying to print out doesn't actually fit well in the notion of the map file. The map file is to show how input sections are mapped to some contiguous output memory address, and it's not suitable to print out the information as to how mergeable section pieces are mapped to an output section.

In D40128#928354, @ruiu wrote:

First of all, the current output is consistent. It doesn't print out the information about mergeable input sections that consist make up an mergeable synthetic section, but that doesn't mean that the output is inconsistent.

So, back to the original question, I don't think the format you are proposing is useful for a few reasons:

  • Address and size fields contains bogus values. So you cannot use these numbers to analyze the output

I cant just agree here, because they contain exactly what I wanted to see, but I should admit I might have misunderstood the
intention of map file. So it can be true. Let me think about it. Thank you for explanation.

  • There's no good way of printing out input sections that make up a synthetic section in the current format

I think the fundamental issue of this patch is that the information you are trying to print out doesn't actually fit well in the notion of the map file. The map file is to show how input sections are mapped to some contiguous output memory address, and it's not suitable to print out the information as to how mergeable section pieces are mapped to an output section.

grimar abandoned this revision.Dec 1 2017, 4:16 AM