[yaml2obj/obj2yaml] - Add support for .stack_sizes sections.
[llvm-complete.git] / test / Object / invalid.test
blobcbf770afbdc641cc27ca037d5783afc64254f111
1 ## Check that llvm-objdump reports an error when
2 ## .shstrtab has an invalid type.
4 # RUN: yaml2obj %s --docnum=1 -o %t1
5 # RUN: not llvm-objdump -s %t1 2>&1 | FileCheck %s -DFILE=%t1 --check-prefix=INVALID-SHTYPE
7 # INVALID-SHTYPE: error: '[[FILE]]': invalid sh_type for string table section [index 1]: expected SHT_STRTAB, but got SHT_PROGBITS
9 --- !ELF
10 FileHeader:
11   Class:   ELFCLASS64
12   Data:    ELFDATA2LSB
13   Type:    ET_DYN
14   Machine: EM_X86_64
15 Sections:
16   - Name: .shstrtab
17     Type: SHT_PROGBITS
19 ## Check that llvm-objdump reports an error when
20 ## .shstrtab has an invalid zero-size.
22 # RUN: yaml2obj %s --docnum=2 -o %t2
23 # RUN: not llvm-objdump -s %t2 2>&1 | FileCheck %s -DFILE=%t2 --check-prefix=STRTAB-EMPTY
25 # STRTAB-EMPTY: error: '[[FILE]]': SHT_STRTAB string table section [index 1] is empty
27 --- !ELF
28 FileHeader:
29   Class:   ELFCLASS64
30   Data:    ELFDATA2LSB
31   Type:    ET_DYN
32   Machine: EM_X86_64
33 Sections:
34   - Name: .shstrtab
35     Type: SHT_STRTAB
36     Size: 0
38 ## Check that llvm-objdump reports an error when .shstrtab has an invalid
39 ## size that goes past the end of the file.
41 # RUN: not llvm-objdump -s %p/Inputs/invalid-strtab-size.elf 2>&1 \
42 # RUN:   | FileCheck %s -DFILE=%p/Inputs/invalid-strtab-size.elf --check-prefix=INVALID-STRTAB-SIZE
44 # INVALID-STRTAB-SIZE: error: '[[FILE]]': section [index 1] has a sh_offset (0x70) + sh_size (0x16777215) that cannot be represented
46 ## Check that llvm-dwarfdump reports an error during relocation resolution
47 ## when instead of expected SHT_RELA section it locates a section of a different type.
49 # RUN: yaml2obj %s --docnum=3 -o %t3
50 # RUN: not llvm-dwarfdump -debug-line %t3 2>&1 | FileCheck --check-prefix=RELA %s
52 # RELA: LLVM ERROR: Section is not SHT_RELA
54 --- !ELF
55 FileHeader:
56   Class:   ELFCLASS64
57   Data:    ELFDATA2LSB
58   Type:    ET_REL
59   Machine: EM_X86_64
60 Sections:
61   - Name: .debug_line
62     Type: SHT_PROGBITS
63 ## The exact content does not matter here. We can use any minimal valid debug section
64 ## which is a target for relocation. The idea is to trigger the code that reads the
65 ## relocation's addend during relocation resolution. It should fail if called on
66 ## a non-SHT_RELA section.
67     Content: 380000000200210000000101FB0E0D00010101010000000100000100676C6F62616C2E63707000000000000009020000000000000000130237000101
68   - Name: .rela.debug_line
69     Type: SHT_REL
70     Info: .debug_line
71     Relocations:
72       - Offset: 0x000000000000002E
73         Type:   R_X86_64_64
75 ## Check that llvm-objdump reports an error when it tries to dump section names
76 ## and .shstrtab is not null-terminated.
78 # RUN: yaml2obj %s --docnum=4 -o %t4
79 # RUN: not llvm-objdump -s %t4 2>&1 | FileCheck -DFILE=%t4 --check-prefix=SHSTRTAB-NON-TERM %s
81 # SHSTRTAB-NON-TERM: error: '[[FILE]]': SHT_STRTAB string table section [index 1] is non-null terminated
83 --- !ELF
84 FileHeader:
85   Class:   ELFCLASS64
86   Data:    ELFDATA2LSB
87   Type:    ET_DYN
88   Machine: EM_X86_64
89 Sections:
90   - Name: .shstrtab
91     Type: SHT_STRTAB
92     Content: "11"
94 ## Check that llvm-objdump reports an error when it tries to dump a symbol name and
95 ## .strtab is not null-terminated.
97 # RUN: yaml2obj %s --docnum=5 -o %t5
98 # RUN: not llvm-objdump -syms %t5 2>&1 | FileCheck --check-prefix=NONULL %s
100 # NONULL: error: {{.*}}: SHT_STRTAB string table section [index 1] is non-null terminated
102 --- !ELF
103 FileHeader:
104   Class:   ELFCLASS64
105   Data:    ELFDATA2LSB
106   Type:    ET_DYN
107   Machine: EM_X86_64
108 Sections:
109   - Name: .strtab
110     Type: SHT_STRTAB
111     Content: "11"
112 Symbols:
113   - Name: foo
115 ## Check that llvm-readobj reports an error if .symtab has an invalid sh_entsize.
117 # RUN: yaml2obj %s --docnum=6 -o %t6
118 # RUN: not llvm-readobj --symbols %t6 2>&1 | FileCheck -DFILE=%t6 --check-prefix=INVALID-SYM-SIZE %s
120 # INVALID-SYM-SIZE: error: '[[FILE]]': section [index 1] has an invalid sh_entsize: 32
122 --- !ELF
123 FileHeader:
124   Class:   ELFCLASS64
125   Data:    ELFDATA2LSB
126   Type:    ET_DYN
127   Machine: EM_X86_64
128 Sections:
129   - Name: .symtab
130     Type: SHT_SYMTAB
131     EntSize: 32
132 Symbols:
133   - Name: foo
135 ## Check that llvm-readobj reports a warning if .dynsym has an invalid sh_entsize.
137 # RUN: yaml2obj %s --docnum=7 -o %t7
138 # RUN: llvm-readobj --dyn-symbols %t7 2>&1 | FileCheck -DFILE=%t7 --check-prefix=INVALID-DYNSYM-SIZE %s
140 # INVALID-DYNSYM-SIZE: warning: '[[FILE]]': invalid section size (48) or entity size (32)
142 --- !ELF
143 FileHeader:
144   Class:   ELFCLASS64
145   Data:    ELFDATA2LSB
146   Type:    ET_DYN
147   Machine: EM_X86_64
148 Sections:
149   - Name: .dynsym
150     Type: SHT_DYNSYM
151     EntSize: 32
152 DynamicSymbols:
153   - Name: foo
155 ## Check that llvm-readobj reports an error if .symtab has an invalid sh_link value,
156 ## which is greater than number of sections.
158 # RUN: yaml2obj %s --docnum=8 -o %t8
159 # RUN: not llvm-readobj --symbols %t8 2>&1 | FileCheck -DFILE=%t8 --check-prefix=INVALID-SYMTAB-LINK %s
161 # INVALID-SYMTAB-LINK: error: '[[FILE]]': invalid section index: 255
163 --- !ELF
164 FileHeader:
165   Class:   ELFCLASS64
166   Data:    ELFDATA2LSB
167   Type:    ET_REL
168   Machine: EM_X86_64
169 Sections:
170   - Name: .symtab
171     Type: SHT_SYMTAB
172     Link: 0xFF
174 ## Check that llvm-readobj reports an error when trying to dump sections
175 ## when the e_shentsize field is broken.
177 # RUN: yaml2obj %s --docnum=9 -o %t9
178 # RUN: not llvm-readobj -S %t9 2>&1 | FileCheck --check-prefix=INVALID-SH-ENTSIZE %s
180 # INVALID-SH-ENTSIZE: error: {{.*}}: invalid  e_shentsize in ELF header: 1
182 --- !ELF
183 FileHeader:
184   Class:     ELFCLASS64
185   Data:      ELFDATA2LSB
186   Type:      ET_REL
187   Machine:   EM_X86_64
188   SHEntSize: 1
190 ## Check that llvm-readobj reports an error if .symtab has sh_size
191 ## that is not a multiple of sh_entsize.
193 # RUN: yaml2obj %s --docnum=10 -o %t10
194 # RUN: not llvm-readobj --symbols %t10 2>&1 | FileCheck -DFILE=%t10 --check-prefix=INVALID-SYMTAB-SIZE %s
196 # INVALID-SYMTAB-SIZE: error: '[[FILE]]': section [index 1] has an invalid sh_size (1) which is not a multiple of its sh_entsize (24)
198 --- !ELF
199 FileHeader:
200   Class:   ELFCLASS64
201   Data:    ELFDATA2LSB
202   Type:    ET_DYN
203   Machine: EM_X86_64
204 Sections:
205   - Name: .symtab
206     Type: SHT_SYMTAB
207     Size: 1
209 ## Test that llvm-readobj reports an error if SHT_SYMTAB_SHNDX section has
210 ## invalid sh_size which should be:
211 ## sizeof(.symtab_shndx) = (sizeof(.symtab) / entsize(.symtab)) * entsize(.symtab_shndx)
213 # RUN: yaml2obj %s --docnum=11 -o %t11
214 # RUN: not llvm-readobj --symbols %t11 2>&1 | FileCheck --check-prefix=INVALID-XINDEX-SIZE %s
216 # INVALID-XINDEX-SIZE: error: {{.*}}: SHT_SYMTAB_SHNDX section has sh_size (24) which is not equal to the number of symbols (2)
218 --- !ELF
219 FileHeader:
220   Class:   ELFCLASS64
221   Data:    ELFDATA2LSB
222   Type:    ET_DYN
223   Machine: EM_X86_64
224 Sections:
225   - Name: .symtab_shndx
226     Type: SHT_SYMTAB_SHNDX
227     Entries: [ 0, 1 ]
228     Link: .symtab
230 ## Check that llvm-readobj reports an error if the e_phentsize field is broken.
232 # RUN: not llvm-readobj --program-headers %p/Inputs/invalid-e_shnum.elf 2>&1 | \
233 # RUN:  FileCheck -DFILE=%p/Inputs/invalid-e_shnum.elf --check-prefix=INVALID-PH-ENTSIZE %s
235 # INVALID-PH-ENTSIZE: error: '[[FILE]]': invalid e_phentsize: 12336
237 ## Check that llvm-readobj reports an error when we have no SHT_SYMTAB_SHNDX section,
238 ## but have a symbol referencing it.
240 # RUN: not llvm-readobj --symbols %p/Inputs/invalid-ext-symtab-index.elf-x86-64 2>&1 | \
241 # RUN:   FileCheck -DFILE=%p/Inputs/invalid-ext-symtab-index.elf-x86-64 --check-prefix=INVALID-EXT-SYMTAB-INDEX %s
243 # INVALID-EXT-SYMTAB-INDEX: error: '[[FILE]]': extended symbol index (0) is past the end of the SHT_SYMTAB_SHNDX section of size 0
245 ## Check that llvm-readobj reports an error if a relocation section
246 ## has a broken sh_offset (past the end of the file).
248 # RUN: yaml2obj %s --docnum=12 -o %t12
249 # RUN: yaml2obj %s --docnum=13 -o %t13
250 # RUN: not llvm-readobj -r %t12 2>&1 | FileCheck -DFILE=%t12 --check-prefix=INVALID-RELOC-SH-OFFSET %s
251 # RUN: not llvm-readobj -r %t13 2>&1 | FileCheck -DFILE=%t13 --check-prefix=INVALID-RELOC-SH-OFFSET %s
253 # INVALID-RELOC-SH-OFFSET: error: '[[FILE]]': section [index 1] has a sh_offset (0x10000) + sh_size (0x0) that cannot be represented
255 --- !ELF
256 FileHeader:
257   Class:   ELFCLASS64
258   Data:    ELFDATA2LSB
259   Type:    ET_REL
260   Machine: EM_386
261 Sections:
262   - Name:     .rel
263     Type:     SHT_REL
264     ShOffset: 0x10000
266 --- !ELF
267 FileHeader:
268   Class:   ELFCLASS64
269   Data:    ELFDATA2LSB
270   Type:    ET_REL
271   Machine: EM_X86_64
272 Sections:
273   - Name:     .rela
274     Type:     SHT_RELA
275     ShOffset: 0x10000
277 ## Check that llvm-objdump reports an error when .shstrtab has a broken sh_offset
278 ## so large that sh_offset + sh_size overflows the platform address size type.
280 # RUN: yaml2obj %s --docnum=14 -o %t14
281 # RUN: not llvm-readobj --symbols %t14 2>&1 | FileCheck -DFILE=%t14 --check-prefix=INVALID-SECTION-SIZE2 %s
283 # INVALID-SECTION-SIZE2: error: '[[FILE]]': section [index 1] has a sh_offset (0xffffffff) + sh_size (0x27) that cannot be represented
285 --- !ELF
286 FileHeader:
287   Class:   ELFCLASS64
288   Data:    ELFDATA2LSB
289   Type:    ET_REL
290   Machine: EM_386
291 Sections:
292   - Name:     .shstrtab
293     Type:     SHT_STRTAB
294     ShOffset: 0xFFFFFFFF
296 ## Check that llvm-readobj reports an error when trying to dump sections
297 ## when the e_shnum field is broken (is greater than the actual number of sections).
299 # RUN: yaml2obj %s --docnum=15 -o %t15
300 # RUN: not llvm-readobj -S %t15 2>&1 | FileCheck --check-prefix=INVALID-SECTION-NUM %s
302 # INVALID-SECTION-NUM: error: {{.*}}: section table goes past the end of file
304 --- !ELF
305 FileHeader:
306   Class:   ELFCLASS64
307   Data:    ELFDATA2LSB
308   Type:    ET_REL
309   Machine: EM_X86_64
310   SHNum:   0xFF
312 ## Check that llvm-readobj reports an error if a relocation contains an
313 ## incorrect (too large) symbol index.
315 # RUN: yaml2obj %s --docnum=16 -o %t16
316 # RUN: not llvm-readobj -r %t16 2>&1 | FileCheck -DFILE=%t16 --check-prefix=INVALID-REL-SYM %s
318 # INVALID-REL-SYM: error: '[[FILE]]': unable to access section [index 2] data at 0x18000040: offset goes past the end of file
320 --- !ELF
321 FileHeader:
322   Class:   ELFCLASS64
323   Data:    ELFDATA2LSB
324   Type:    ET_REL
325   Machine: EM_X86_64
326 Sections:
327   - Name: .rela.text
328     Type: SHT_RELA
329     Info: 0
330     Relocations:
331       - Offset: 0x0
332         Type:   R_X86_64_64
333         Symbol: 0xFFFFFF
335 ## Check llvm-readobj does not crash on a truncated ELF.
337 ## Create a truncated ELF object with ELFCLASSNONE class using echo.
338 ## 0x7f, 'E', 'L', 'F', ELFCLASS64(2), ELFDATA2LSB(1),
339 ## EV_CURRENT(1), ELFOSABI_LINUX(3), <padding zero bytes>, ET_REL(1), EM_NONE(0)
340 # RUN: echo -e -n "\x7f\x45\x4c\x46\x02\x01\x01\x03\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00" > %t11
341 # RUN: not llvm-readobj -r %t11 2>&1 | FileCheck --check-prefix=INVALID-BUFFER %s
343 # INVALID-BUFFER: error: {{.*}}': invalid buffer: the size (18) is smaller than an ELF header (64)
345 # RUN: not llvm-readobj %p/Inputs/invalid-coff-header-too-small 2>&1 | FileCheck --check-prefix=COFF-HEADER %s
346 # COFF-HEADER: The file was not recognized as a valid object file
348 ## Check that llvm-readobj reports an error if section name offset
349 ## overflows the section name string table.
351 # RUN: yaml2obj %s --docnum=17 -o %t17
352 # RUN: not llvm-readobj --sections %t17 2>&1 | FileCheck -DFILE=%t17 --check-prefix=BROKEN-SECNAME %s
354 ## BROKEN-SECNAME: error: '[[FILE]]': a section [index 1] has an invalid sh_name (0x1) offset which goes past the end of the section name string table
356 --- !ELF
357 FileHeader:
358   Class:   ELFCLASS64
359   Data:    ELFDATA2LSB
360   Type:    ET_REL
361   Machine: EM_X86_64
362 Sections:
363   - Name: .shstrtab
364     Type: SHT_STRTAB
365     Size: 1
367 ## Check that llvm-readobj reports an error if a section has a broken offset
368 ## that goes past the end of the file.
370 # RUN: yaml2obj %s --docnum=18 -o %t18
371 # RUN: not llvm-readobj --sections --section-data %t18 2>&1 \
372 # RUN:  | FileCheck -DFILE=%t18 --check-prefix=BROKEN-SECSHOFFSET %s
374 # BROKEN-SECSHOFFSET: error: '[[FILE]]': section [index 1] has a sh_offset (0xffff0000) + sh_size (0x0) that cannot be represented
376 --- !ELF
377 FileHeader:
378   Class:   ELFCLASS64
379   Data:    ELFDATA2LSB
380   Type:    ET_REL
381   Machine: EM_X86_64
382 Sections:
383   - Name:     .foo
384     Type:     SHT_PROGBITS
385     ShOffset: 0xFFFF0000
387 ## Check that llvm-readobj reports an error if symbol name
388 ## offset goes past the end of the symbol string table.
390 # RUN: yaml2obj %s --docnum=19 -o %t19
391 # RUN: not llvm-readobj --symbols %t19 2>&1 | FileCheck -DFILE=%t19 --check-prefix=INVALID-SYM-NAME %s
393 # INVALID-SYM-NAME: error: '[[FILE]]': st_name (0x1) is past the end of the string table of size 0x1
395 --- !ELF
396 FileHeader:
397   Class:   ELFCLASS64
398   Data:    ELFDATA2LSB
399   Type:    ET_REL
400   Machine: EM_X86_64
401 Sections:
402   - Name: .strtab
403     Type: SHT_STRTAB
404     Size: 1
405 Symbols:
406   - Name: foo
408 ## Version index in .gnu.version overflows the version map.
409 ## Check llvm-readobj reports it.
411 # RUN: yaml2obj %s --docnum=20 -o %t20
412 # RUN: not llvm-readobj -dt %t20 2>&1 | FileCheck -DFILE=%t20 --check-prefix=INVALID-VERSION %s
414 # INVALID-VERSION: error: '[[FILE]]': Invalid version entry
416 --- !ELF
417 FileHeader:
418   Class:   ELFCLASS64
419   Data:    ELFDATA2LSB
420   Type:    ET_DYN
421   Machine: EM_X86_64
422 Sections:
423   - Name:    .gnu.version
424     Type:    SHT_GNU_versym
425     Entries: [ 0xFF ]
426 DynamicSymbols:
427   - Name: foo
429 ## ELF header contains e_phentsize field with a value != sizeof(Elf_Phdr).
430 ## Check llvm-readobj reports it.
432 # RUN: not llvm-readobj -l %p/Inputs/corrupt-invalid-phentsize.elf.x86-64 2>&1 \
433 # RUN:   | FileCheck -DFILE=%p/Inputs/corrupt-invalid-phentsize.elf.x86-64 --check-prefix=PHENTSIZE %s
435 # PHENTSIZE: error: '[[FILE]]': invalid e_phentsize: 57
437 ## The dynamic table contains DT_STRTAB with a value that is not in any loadable segment.
438 ## Check llvm-readobj reports it.
440 # RUN: yaml2obj %s --docnum=21 -o %t21
441 # RUN: llvm-readobj --dynamic-table %t21 2>&1 | FileCheck -DFILE=%t21 --check-prefix=INVALID-DTSTRTAB %s
443 # INVALID-DTSTRTAB: warning: '[[FILE]]': Unable to parse DT_STRTAB: virtual address is not in any segment: 0xffff0000
445 --- !ELF
446 FileHeader:
447   Class:   ELFCLASS64
448   Data:    ELFDATA2LSB
449   Type:    ET_EXEC
450   Machine: EM_X86_64
451 Sections:
452   - Name:    .dynamic
453     Type:    SHT_DYNAMIC
454     Address: 0x1000
455     Entries:
456       - Tag:   DT_STRTAB
457         Value: 0xFFFF0000
458       - Tag:   DT_NULL
459         Value: 0x0
460 ProgramHeaders:
461   - Type: PT_LOAD
462     VAddr: 0x1000
463     Sections:
464       - Section: .dynamic
466 ## Check that llvm-readobj reports a warning when a dynamic relocation section
467 ## has sh_entsize field with size != sizeof(Elf_Rela).
469 # RUN: llvm-readobj --dyn-relocations \
470 # RUN:   %p/Inputs/corrupt-invalid-relocation-size.elf.x86-64 2>&1 \
471 # RUN:    | FileCheck -DFILE=%p/Inputs/corrupt-invalid-relocation-size.elf.x86-64 --check-prefix=RELOC-BROKEN-ENTSIZE %s
473 # RELOC-BROKEN-ENTSIZE: warning: '[[FILE]]': invalid section size (24) or entity size (25)
475 ## Check that llvm-readobj reports a warning when .dynamic section has an invalid
476 ## size, which isn't a multiple of the dynamic entry size. 
478 # RUN: yaml2obj %s --docnum=22 -o %t22
479 # RUN: llvm-readobj --dyn-relocations %t22 2>&1 | FileCheck -DFILE=%t22 --check-prefix=DYN-TABLE-SIZE %s
481 # DYN-TABLE-SIZE: warning: '[[FILE]]': invalid section size (1) or entity size (16)
483 --- !ELF
484 FileHeader:
485   Class:   ELFCLASS64
486   Data:    ELFDATA2LSB
487   Type:    ET_EXEC
488   Machine: EM_X86_64
489 Sections:
490   - Name:    .dynamic
491     Type:    SHT_DYNAMIC
492     Content: "00"
494 ## PT_DYNAMIC's p_offset field is so large that p_offset + p_filesz is larger
495 ## than the object size. Check llvm-readobj reports it.
497 # RUN: yaml2obj %s --docnum=23 -o %t23
498 # RUN: llvm-readobj --dyn-relocations %t23 2>&1 | FileCheck -DFILE=%t23 --check-prefix=DYN-TABLE-PHDR %s
500 # DYN-TABLE-PHDR: warning: '[[FILE]]': PT_DYNAMIC segment offset + size exceeds the size of the file
502 --- !ELF
503 FileHeader:
504   Class:   ELFCLASS64
505   Data:    ELFDATA2LSB
506   Type:    ET_EXEC
507   Machine: EM_X86_64
508 Sections:
509   - Name: .dynamic
510     Type: SHT_DYNAMIC
511     Entries:
512       - Tag:   DT_NULL
513         Value: 0
514 ProgramHeaders:
515   - Type:   PT_DYNAMIC
516     Offset: 0xffff0000
517     Sections:
518       - Section: .dynamic
520 ## PT_DYNAMIC's p_filesz field is so large that p_offset + p_filesz is larger
521 ## than the object size. Check llvm-readobj reports it.
523 # RUN: yaml2obj %s --docnum=24 -o %t24
524 # RUN: llvm-readobj --dyn-relocations %t24 2>&1 \
525 # RUN:  | FileCheck -DFILE=%t24 --check-prefix=DYN-TABLE-PHDR %s
527 --- !ELF
528 FileHeader:
529   Class:   ELFCLASS64
530   Data:    ELFDATA2LSB
531   Type:    ET_EXEC
532   Machine: EM_X86_64
533 Sections:
534   - Name: .dynamic
535     Type: SHT_DYNAMIC
536     Entries:
537       - Tag:   DT_NULL
538         Value: 0
539 ProgramHeaders:
540   - Type:     PT_DYNAMIC
541     FileSize: 0xffff0000
542     Sections:
543       - Section: .dynamic
545 # RUN: yaml2obj --docnum=25 %s -o %t25
546 # RUN: not obj2yaml 2>&1 %t25 | FileCheck %s -DFILE=%t25 --check-prefix=INVALID-SHSTRNDX
548 # INVALID-SHSTRNDX: Error reading file: [[FILE]]: section header string table index 255 does not exist
550 --- !ELF
551 FileHeader:
552   Class:    ELFCLASS64
553   Data:     ELFDATA2LSB
554   Type:     ET_REL
555   Machine:  EM_X86_64
556   SHStrNdx: 0xFF
557 Sections:
558   - Name: .foo
559     Type: SHT_PROGBITS
561 ## We report an error if the number of sections stored in sh_size
562 ## is greater than UINT64_MAX / sizeof(Elf_Shdr) == 288230376151711743.
563 ## Here we check that do not crash on a border value.
565 # RUN: yaml2obj --docnum=26 %s -o %t26
566 # RUN: not llvm-readobj -h %t26 2>&1 | FileCheck -DFILE=%t26 --check-prefix=INVALID-SEC-NUM1 %s
568 # INVALID-SEC-NUM1: error: '[[FILE]]': invalid section header table offset (e_shoff = 0x78) or invalid number of sections specified in the first section header's sh_size field (0x3ffffffffffffff)
570 --- !ELF
571 FileHeader:
572   Class:   ELFCLASS64
573   Data:    ELFDATA2LSB
574   Type:    ET_REL
575   Machine: EM_X86_64
576   SHNum:   0x0
577 Sections:
578   - Type: SHT_NULL
579     Size: 288230376151711743
581 ## See above, but now we test the UINT64_MAX / sizeof(Elf_Shdr) value.
582 ## The error is slightly different in this case.
584 # RUN: yaml2obj --docnum=27 %s -o %t27
585 # RUN: not llvm-readobj -h %t27 2>&1 | FileCheck -DFILE=%t27 --check-prefix=INVALID-SEC-NUM2 %s
587 # INVALID-SEC-NUM2: error: '[[FILE]]': invalid number of sections specified in the NULL section's sh_size field (288230376151711744)
589 --- !ELF
590 FileHeader:
591   Class:   ELFCLASS64
592   Data:    ELFDATA2LSB
593   Type:    ET_REL
594   Machine: EM_X86_64
595   SHNum:   0x0
596 Sections:
597   - Type: SHT_NULL
598     Size: 288230376151711744
600 ## Check the case when SHOff is too large. SHOff + sizeof(Elf_Shdr) overflows the uint64 type.
602 # RUN: yaml2obj --docnum=28 %s -o %t28
603 # RUN: not llvm-readobj -h %t28 2>&1 | FileCheck -DFILE=%t28 --check-prefix=INVALID-SEC-NUM3 %s
605 # INVALID-SEC-NUM3: error: '[[FILE]]': section header table goes past the end of the file: e_shoff = 0xffffffffffffffff
607 --- !ELF
608 FileHeader:
609   Class:    ELFCLASS64
610   Data:     ELFDATA2LSB
611   Type:     ET_REL
612   Machine:  EM_X86_64
613   SHOff:    0xffffffffffffffff
615 ## Check that llvm-objdump reports an error when it tries to dump a
616 ## symbol name and .strtab is empty.
618 # RUN: yaml2obj %s --docnum=29 -o %t29
619 # RUN: not llvm-objdump -syms %t29 2>&1 | FileCheck -DFILE=%t29 --check-prefix=STRTAB-EMPTY2 %s
621 # STRTAB-EMPTY2: error: '[[FILE]]': SHT_STRTAB string table section [index 1] is empty
623 --- !ELF
624 FileHeader:
625   Class:   ELFCLASS64
626   Data:    ELFDATA2LSB
627   Type:    ET_DYN
628   Machine: EM_X86_64
629 Sections:
630   - Name: .strtab
631     Type: SHT_STRTAB
632     Content: ""
633 Symbols:
634   - Name: foo
636 ## Check that we report an error if SHT_GNU_versym has invalid
637 ## sh_entsize value (3 instead of 2) when trying to access the entries.
639 # RUN: yaml2obj %s --docnum=30 -o %t30
640 # RUN: not llvm-readobj -V %t30 2>&1 | FileCheck -DFILE=%t30 --check-prefix=INVALID-VER-SHENTSIZE %s
642 # INVALID-VER-SHENTSIZE: error: '[[FILE]]': section [index 1] has invalid sh_entsize: expected 2, but got 3
644 --- !ELF
645 FileHeader:
646   Class:   ELFCLASS64
647   Data:    ELFDATA2LSB
648   OSABI:   ELFOSABI_FREEBSD
649   Type:    ET_DYN
650   Machine: EM_X86_64
651 Sections:
652   - Name:    .gnu.version
653     Type:    SHT_GNU_versym
654     EntSize: 0x0000000000000003
655     Entries: [ ]
656 ## Needed to trigger creation of .dynsym.
657 DynamicSymbols:
658   - Name:    foo
659     Binding: STB_GLOBAL
661 ## Check the case when e_shstrndx == SHN_XINDEX, but null section's sh_link contains
662 ## the index of a section header string table that is larger than the number of the sections.
664 # RUN: yaml2obj --docnum=31 %s -o %t31
665 # RUN: not llvm-objcopy %t31 2>&1 | FileCheck %s -DFILE=%t31 --check-prefix=INVALID-SHSTRTAB-INDEX
667 # INVALID-SHSTRTAB-INDEX: error: section header string table index 255 does not exist
669 --- !ELF
670 FileHeader:
671   Class:    ELFCLASS64
672   Data:     ELFDATA2LSB
673   Type:     ET_REL
674   Machine:  EM_X86_64
675 ## SHN_XINDEX == 0xffff.
676   SHStrNdx: 0xffff
677 Sections:
678   - Type: SHT_NULL
679     Link: 0xff