When there are no section headers section information printed by llvm-readelf is not useful and unnecessarily verbose. When there are no program headers there's a similar verbose output shown when section mapping is requested. Simplifying the message shown in these cases to match the behavior of GNU binuntils readelf.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Unit Tests
Event Timeline
Added tests that will cover the printSectionDetails() function no section header use cases.
Rendering the warning e_shstrndx == SHN_XINDEX, but the section header table is empty along with the There is no sections in the file. message.
llvm/test/tools/llvm-readobj/ELF/gnu-section-mapping-no-phdrs.test | ||
---|---|---|
3–6 ↗ | (On Diff #448669) | As we're changing this test anyway, I think it would be good to show that no other output is printed before or after, not just after the checked line. The easiest way to do this is to add --implicit-check-not={{.}} to the FileCheck command and then just get rid of the existing CHECK-NOT line. |
llvm/test/tools/llvm-readobj/ELF/many-sections.s | ||
11 | I'm not sure I follow what coverage this line is adding? We need a test case with --section-details but no sections, but you've added this to no-shdrs.test. | |
llvm/test/tools/llvm-readobj/ELF/no-phdrs.test | ||
15 | I think we need to show that the section segment mapping is not printed in this case. I'm thinking something like GNU-NOT: {{.}} or better yet, --implicit-check-not={{.}} should do the trick. | |
llvm/tools/llvm-readobj/ELFDumper.cpp | ||
3685 | ||
3689–3690 | We need a test case that shows this warning being emitted. | |
4073 | ||
4077–4078 | Ditto: this warning needs checking, I believe. | |
4263–4264 | I feel like this function could do with some early outs. I'm thinking something along the following lines would be much cleaner: template <class ELFT> void GNUELFDumper<ELFT>::printProgramHeaders( bool PrintProgramHeaders, cl::boolOrDefault PrintSectionMapping) { if (!PrintProgramHeaders && PrintSectionMapping == cl::BOU_FALSE) return; const Elf_Ehdr &Header = this->Obj.getHeader(); if (Header.e_phnum == 0) { OS << "\nThere are no program headers in this file.\n"; return; } if (PrintProgramHeaders) printProgramHeaders(); if (PrintSectionMapping != cl::BOU_FALSE) printSectionMapping(); } Thoughts? |
Program header rendering cleanup.
Rendering "no program header" message should not affect readelf invocations that request for section information only. Updated the PrintProgramHeader function and the corresponding tests.
Updated the printProgramHeaders section to address the review comment and to fix logic flaws. Updated corresponding tests. Please take a look.
llvm/test/tools/llvm-readobj/ELF/gnu-section-mapping-no-phdrs.test | ||
---|---|---|
3–6 ↗ | (On Diff #448669) | This change as it turns out is wrong. The code path that renders only "--section-mapping" is not originally intended to change. |
llvm/test/tools/llvm-readobj/ELF/many-sections.s | ||
11 | You're right. This is a duplicate check of what is already handled in section-details.test. Removing this test. | |
llvm/test/tools/llvm-readobj/ELF/no-phdrs.test | ||
15 | Once again there was an error in this work flow. Clean up of "Program Headers" section was intended. But the Section to Segment mapping was not intended to be changed so bringing that part back. | |
llvm/tools/llvm-readobj/ELFDumper.cpp | ||
3689–3690 | test/tools/llvm-readobj/ELF/many-sections.s line 36,37 (shown below) exercises this code path.
| |
4077–4078 | Added a new test to cover this path: test/tools/llvm-readobj/ELF/many-sections.s line 38,39 (shown below) :
| |
4263–4264 | This comment helped me find a logical flaw in rendering. The control flow of invocations that request for segment details/mapping without the program header info should not change. I have updated this function to reflect this change and considered some of the cleanups suggested in your comment. |
FWIW ELF Tool Chain readelf also emits There are no program headers in this file. or There are no sections in this file..
llvm/test/tools/llvm-readobj/ELF/no-phdrs.test | ||
---|---|---|
15 | So just to confirm, GNU prints the (empty) section to segment mapping even if there are no program headers, when the program headers are dumped? | |
llvm/test/tools/llvm-readobj/ELF/no-shdrs.test | ||
20 | ||
llvm/tools/llvm-readobj/ELFDumper.cpp | ||
4280–4282 | No need for braces in single-line if statements. Also, I'd rename IsPrintSectionMapping to ShouldPrintSectionMapping, as it is more grammatically correct. | |
4283 | I'm not sure this and the equivalent comment below for the section mapping are really adding anything anymore, given the new code layout. | |
4293–4295 |
llvm/test/tools/llvm-readobj/ELF/no-phdrs.test | ||
---|---|---|
15 | That's correct! When we ask to dump program headers we dump section to segment mapping by default. Showing empty mapping offers users consistency on what to expect in the output printed to the console imo. But I could go either way (show empty mapping or not) to be honest. |
I'm not sure I follow what coverage this line is adding? We need a test case with --section-details but no sections, but you've added this to no-shdrs.test.