1## many-sections.elf-x86_64 is a file that was generated to simulate 2## an object with more than ~65k sections. When an ELF object 3## has SHN_LORESERVE (0xff00) or more sections, its e_shnum field 4## should be zero and sh_size of the section header at index 0 is used 5## to store the value. If the section name string table section index is 6## greater than or equal to SHN_LORESERVE, then e_shstrndx field 7## should have the value of SHN_XINDEX and sh_link of the section header 8## at index 0 is used to store the value. 9## 10## many-sections.elf-x86_64 has few sections to save disk 11## space, but its e_shnum, e_shstrndx, sh_size and sh_link fields are set 12## according to the above description, so that we can test the dumper. 13 14# RUN: llvm-readobj -file-headers -sections -elf-output-style GNU \ 15# RUN: %p/Inputs/many-sections.elf-x86_64 | FileCheck %s --check-prefix=GNU1 16# GNU1: Number of section headers: 0 (5) 17# GNU1: Section header string table index: 65535 (3) 18# GNU1: There are 5 section headers, starting at offset 0xb8 19 20# RUN: llvm-readobj -file-headers -elf-output-style LLVM \ 21# RUN: %p/Inputs/many-sections.elf-x86_64 | FileCheck %s --check-prefix=LLVM1 22# LLVM1: SectionHeaderCount: 0 (5) 23# LLVM1: StringTableSectionIndex: 65535 (3) 24 25## many-sections-stripped.elf-x86_64 is many-sections.elf-x86_64 with 26## e_shoff field set to zero, but not e_shstrndx, to show that 27## this corrupt case is handled correctly. 28 29# RUN: llvm-readobj -file-headers -elf-output-style GNU \ 30# RUN: %p/Inputs/many-sections-stripped.elf-x86_64 | FileCheck %s --check-prefix=GNU2 31# GNU2: Number of section headers: 0 32# GNU2: Section header string table index: 65535 (corrupt: out of range) 33 34# RUN: llvm-readobj -file-headers -elf-output-style LLVM \ 35# RUN: %p/Inputs/many-sections-stripped.elf-x86_64 | FileCheck %s --check-prefix=LLVM2 36# LLVM2: SectionHeaderCount: 0 37# LLVM2: StringTableSectionIndex: 65535 (corrupt: out of range) 38