File: loadname.test

package info (click to toggle)
llvm-toolchain-14 1%3A14.0.6-12
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,496,180 kB
  • sloc: cpp: 5,593,972; ansic: 986,872; asm: 585,869; python: 184,223; objc: 72,530; lisp: 31,119; f90: 27,793; javascript: 9,780; pascal: 9,762; sh: 9,482; perl: 7,468; ml: 5,432; awk: 3,523; makefile: 2,538; xml: 953; cs: 573; fortran: 567
file content (65 lines) | stat: -rw-r--r-- 2,520 bytes parent folder | download | duplicates (19)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
## Check we are able to dump library soname properly.

## Test a valid object case first. We set 'FileSize' to 0x48, because this is a no-op,
## i.e. this value would be set if we had no 'FileSize' at all.
# RUN: yaml2obj -DDTSTRTABVAL=0x0 -DPHDRFILESIZE="0x48" %s -o %t.o
# RUN: llvm-readobj %t.o | FileCheck %s --check-prefix LLVM
# RUN: llvm-readelf --dynamic-table %t.o | FileCheck %s --check-prefix GNU

# LLVM:      Format: elf64-x86-64
# LLVM-NEXT: Arch: x86_64
# LLVM-NEXT: AddressSize: 64bit
# LLVM-NEXT: LoadName: test.so

# GNU:       Dynamic section at offset 0x80 contains 4 entries:
# GNU-NEXT:   Tag                Type     Name/Value
# GNU-NEXT:   0x0000000000000005 (STRTAB) 0x0
# GNU-NEXT:   0x000000000000000a (STRSZ)  8 (bytes)
# GNU-NEXT:   0x000000000000000e (SONAME) Library soname: [test.so]
# GNU-NEXT:   0x0000000000000000 (NULL)   0x0

!ELF
FileHeader:
  Class:   ELFCLASS64
  Data:    ELFDATA2LSB
  Type:    ET_EXEC
  Machine: EM_X86_64
Sections:
  - Name:  .dynstr
    Type:  SHT_STRTAB
    Flags: [ SHF_ALLOC ]
    Content: '746573742e736f00' ## "test.so"
  - Name:  .dynamic
    Type:  SHT_DYNAMIC
    Flags: [ SHF_ALLOC ]
    Link:  .dynstr
    Entries:
      - Tag:   DT_STRTAB
        Value: [[DTSTRTABVAL]]
      - Tag:   DT_STRSZ
        Value: 0x0000000000000008
      - Tag:   DT_SONAME
        Value: 0x0000000000000000
      - Tag:   DT_NULL
        Value: 0x0000000000000000
ProgramHeaders:
  - Type:     PT_LOAD
    Flags:    [ PF_R ]
    VAddr:    0x0000
    FileSize: [[PHDRFILESIZE]]
    FirstSec: .dynstr
    LastSec:  .dynamic

## Check we do not crash when an object contains a DT_STRTAB entry whose address
## is past the end of the object.
## Note that we have to set p_filesz for PT_LOAD larger than DT_STRTAB value
## to trigger this particular warning.

# RUN: yaml2obj -DDTSTRTABVAL=0xFFFE -DPHDRFILESIZE=0xFFFF %s -o %t.err.1.o
# RUN: llvm-readobj %t.err.1.o 2>&1 | FileCheck %s -DFILE=%t.err.1.o --check-prefixes=BROKEN-OFFSET,BROKEN-OFFSET-LLVM
# RUN: llvm-readelf --dynamic-table %t.err.1.o 2>&1 | FileCheck %s -DFILE=%t.err.1.o --check-prefixes=BROKEN-OFFSET,BROKEN-OFFSET-GNU

# BROKEN-OFFSET:      warning: '[[FILE]]': unable to parse DT_STRTAB: can't map virtual address 0xfffe to the segment with index 1: the segment ends at 0x10077, which is greater than the file size (0x228)
# BROKEN-OFFSET:      warning: '[[FILE]]': string table was not found
# BROKEN-OFFSET-LLVM: LoadName: <?>
# BROKEN-OFFSET-GNU:  0x000000000000000e (SONAME) Library soname: [<?>]