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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
#include <stdio.h>
#include <libelf.h>
#include <gelf.h>
#include <libelfu/libelfu.h>
static char *ptstr[] = {"NULL", "LOAD", "DYNAMIC", "INTERP", "NOTE", "SHLIB", "PHDR", "TLS", "NUM"};
char* segmentTypeStr(size_t pt)
{
if (pt >= 0 && pt <= PT_NUM) {
return ptstr[pt];
}
return "-?-";
}
void printSectionsInSegment(Elf *e, GElf_Phdr *phdr)
{
Elf_Scn *scn;
scn = elf_getscn(e, 0);
while (scn) {
GElf_Shdr shdr;
if (gelf_getshdr(scn, &shdr) != &shdr) {
fprintf(stderr, "gelf_getshdr() failed: %s\n", elf_errmsg(-1));
continue;
}
if (elfu_segmentContainsSection(phdr, &shdr)) {
printf(" %10u %s\n", elf_ndxscn(scn), elfu_sectionName(e, scn));
}
scn = elf_nextscn(e, scn);
}
}
void printSegments(Elf *e)
{
size_t i, n;
if (elf_getphdrnum(e, &n)) {
fprintf(stderr, "elf_getphdrnum() failed: %s.", elf_errmsg(-1));
}
printf("Segments:\n");
printf(" # typeStr type offset vaddr paddr filesz memsz flags align\n");
for (i = 0; i < n; i++) {
GElf_Phdr phdr;
if (gelf_getphdr(e, i, &phdr) != &phdr) {
fprintf(stderr, "getphdr() failed for #%d: %s.", i, elf_errmsg(-1));
continue;
}
printf(" * %4d: %8s ", i, segmentTypeStr(phdr.p_type));
printf("%8jx %8jx %8jx %8jx %8jx %8jx %8jx %8jx\n",
(uintmax_t) phdr.p_type,
(uintmax_t) phdr.p_offset,
(uintmax_t) phdr.p_vaddr,
(uintmax_t) phdr.p_paddr,
(uintmax_t) phdr.p_filesz,
(uintmax_t) phdr.p_memsz,
(uintmax_t) phdr.p_flags,
(uintmax_t) phdr.p_align);
printSectionsInSegment(e, &phdr);
}
printf("\n");
}
|