[llvm-readelf] - Improve dumping of objects without a section header string table.

We have a test/Object/no-section-header-string-table.test which checks
what happens when an object does not have a section header string table.
It does not check the full output though.
Currently our output is different from GNU readelf, because the latter prints
"<no-strings>" instead of a section name, while we print nothing.

This patch fixes this, adds a proper test case and removes the one from test/Object,
as it is not a right folder for llvm-readelf tests.

Differential revision: https://reviews.llvm.org/D73193
This commit is contained in:
Georgii Rymar 2020-01-22 17:20:07 +03:00
parent 7d20e80225
commit 1af6209d64
4 changed files with 69 additions and 12 deletions

View File

@ -1,10 +0,0 @@
RUN: llvm-readobj %p/Inputs/no-section-header-string-table.elf-x86-64 --sections \
RUN: | FileCheck %s
CHECK: Type: SHT_PROGBITS (0x1)
CHECK: Type: SHT_PROGBITS (0x1)
CHECK: Type: SHT_PROGBITS (0x1)
CHECK: Type: SHT_RELA (0x4)
CHECK: Type: SHT_SYMTAB (0x2)
CHECK: Type: SHT_STRTAB (0x3)
CHECK: Type: SHT_STRTAB (0x3)

View File

@ -0,0 +1,61 @@
## Check what --sections prints when there is no section header string table.
# RUN: yaml2obj %s -o %t
# RUN: llvm-readelf --sections %t \
# RUN: | FileCheck %s --strict-whitespace --match-full-lines --check-prefix=GNU
# RUN: not llvm-readobj --sections %t 2>&1 \
# RUN: | FileCheck %s -DFILE=%t --check-prefix=LLVM
# GNU:Section Headers:
# GNU-NEXT: [Nr] Name Type Address Off Size ES Flg Lk Inf Al
# GNU-NEXT: [ 0] <no-strings> NULL 0000000000000000 000000 000000 00 0 0 0
# GNU-NEXT: [ 1] <no-strings> PROGBITS 0000000000000000 000040 000000 00 0 0 0
# GNU-NEXT: [ 2] <no-strings> PROGBITS 0000000000000000 000040 000000 00 0 0 0
# GNU-NEXT: [ 3] <no-strings> STRTAB 0000000000000000 000040 000001 00 0 0 1
# GNU-NEXT: [ 4] <no-strings> STRTAB 0000000000000000 000041 00001d 00 0 0 1
# LLVM: Sections [
# LLVM-NEXT: Section {
# LLVM-NEXT: Index: 0
# LLVM-NEXT: Name: (0)
# LLVM-NEXT: Type: SHT_NULL (0x0)
# LLVM-NEXT: Flags [ (0x0)
# LLVM-NEXT: ]
# LLVM-NEXT: Address: 0x0
# LLVM-NEXT: Offset: 0x0
# LLVM-NEXT: Size: 0
# LLVM-NEXT: Link: 0
# LLVM-NEXT: Info: 0
# LLVM-NEXT: AddressAlignment: 0
# LLVM-NEXT: EntrySize: 0
# LLVM-NEXT: }
# LLVM-NEXT: Section {
# LLVM-NEXT: Index: 1
# LLVM-NEXT: Name: (0)
# LLVM-NEXT: Type: SHT_PROGBITS (0x1)
# LLVM-NEXT: Flags [ (0x0)
# LLVM-NEXT: ]
# LLVM-NEXT: Address: 0x0
# LLVM-NEXT: Offset: 0x40
# LLVM-NEXT: Size: 0
# LLVM-NEXT: Link: 0
# LLVM-NEXT: Info: 0
# LLVM-NEXT: AddressAlignment: 0
# LLVM-NEXT: EntrySize: 0
# LLVM-NEXT: }
# LLVM-NEXT: error: '[[FILE]]': a section [index 2] has an invalid sh_name (0x1) offset which goes past the end of the section name string table
--- !ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_DYN
Machine: EM_X86_64
SHStrNdx: 0
Sections:
- Name: .foo
Type: SHT_PROGBITS
ShName: 0
- Name: .bar
Type: SHT_PROGBITS
ShName: 1

View File

@ -3515,11 +3515,17 @@ void GNUStyle<ELFT>::printSectionHeaders(const ELFO *Obj) {
OS << "\n"; OS << "\n";
const ELFObjectFile<ELFT> *ElfObj = this->dumper()->getElfObject(); const ELFObjectFile<ELFT> *ElfObj = this->dumper()->getElfObject();
StringRef SecStrTable = unwrapOrError<StringRef>(
ElfObj->getFileName(),
Obj->getSectionStringTable(Sections, this->WarningHandler));
size_t SectionIndex = 0; size_t SectionIndex = 0;
for (const Elf_Shdr &Sec : Sections) { for (const Elf_Shdr &Sec : Sections) {
Fields[0].Str = to_string(SectionIndex); Fields[0].Str = to_string(SectionIndex);
Fields[1].Str = unwrapOrError<StringRef>( if (SecStrTable.empty())
ElfObj->getFileName(), Obj->getSectionName(&Sec, this->WarningHandler)); Fields[1].Str = "<no-strings>";
else
Fields[1].Str = unwrapOrError<StringRef>(
ElfObj->getFileName(), Obj->getSectionName(&Sec, SecStrTable));
Fields[2].Str = Fields[2].Str =
getSectionTypeString(Obj->getHeader()->e_machine, Sec.sh_type); getSectionTypeString(Obj->getHeader()->e_machine, Sec.sh_type);
Fields[3].Str = Fields[3].Str =