[PATCH] D82858: [llvm-objdump] Detect note section for ELF objects
Jordan Rupprecht via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jun 30 15:14:03 PDT 2020
rupprecht added a comment.
In D82858#2122628 <https://reviews.llvm.org/D82858#2122628>, @jhenderson wrote:
> In D82858#2122464 <https://reviews.llvm.org/D82858#2122464>, @rochauha wrote:
>
> > In D82858#2122431 <https://reviews.llvm.org/D82858#2122431>, @jhenderson wrote:
> >
> > > Could you more clearly clarify what the motivation here is? Is this working towards some missing GNU compatibility or similar? If so, could you paste an example of what GNU objdump produces, please.
> > >
> > > Note that .note sections can be dumped using llvm-readelf in GNU style, just not as part of the disassembly.
> >
> >
> > GNU compatibility is not a goal here. The idea is to support disassembling everything that appears in a binary. Right now almost every entity is disassembled as instructions (even notes). This is not very helpful to the user.
> >
> > Let us consider the example of notes. A user has to use llvm-readobj to look at notes and then use llvm-objdump to look at instructions. There is //some// overlap between the functionality llvm-readobj and llvm-objdump as well. For example, both also support only looking at symbols. I guess this divide between both tools is not necessary.
> >
> > llvm-objdump is more 'feature rich' in the sense that it allows to look at target specific parts of the code as well. Right now the plan is to add some of the missing functionality to llvm-objdump. The final goal would be to support re-assemblable disassembly after we are able to disassemble all contents of a binary.
> >
> > At the time of writing, no mainstream tool supports re-assemblable disassembly. The ones which do are mostly proprietary.
>
>
> If that's the motivation, I don't think I can support it for various reasons:
>
> 1. Having multiple tools to do the same job is not a good idea - each requires its own maintenance, the behaviour can diverge, bugs might require fixing in two places/support for new things etc etc etc. In an ideal world, we'd merge all the binary tools (GNU and LLVM) into a single tool, or redistribute functionality somehow, so that we don't have duplicate functionality like we already do. This takes us further away from that ideal.
+1, I think the long term idea is that we'll have a single llvm tool that tells us useful object info in a variety of ways, and objdump/readelf will just be GNU compatibility frontends to the tool. Something closer to that goal would be to teach llvm-readobj how to disassemble if you want both things in one tool short term.
> 2. Decoding the .note section in a special manner takes us further away from GNU compatibility. It's not clear to me that GNU would want to add this functionality themselves.
FWIW I think it's worth at least asking GNU binutils maintainers about this feature. I do imagine the answer would probably be no, but it doesn't hurt to see what they think. (I'm partly scared that there's someone out there relying on how objdump prints note sections).
> 3. I'm not convinced people actually find dumping all sections in an interpreted form at once useful. Do you actually have any users for that? I think most people are interested in the disassembly of their code, but are unlikely to want this information in the same output as note information.
> 4. I don't quite follow whether you're saying that one motivation is to make things re-assembleable, but if it is, the .note section is not the place to start - there are other sections where this would be more useful (e.g. data sections).
> 5. I'm not sure I follow your "feature rich" comment. llvm-readelf for example has just as much access to the object as a whole and so is able to use target-specific information where appropriate (for example, it knows about various target-specific flags, can parse the target-specific attributes section etc).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D82858/new/
https://reviews.llvm.org/D82858
More information about the llvm-commits
mailing list