[CMAKE]
[reactos.git] / dll / win32 / dbghelp / image_private.h
1 /*
2 * File elf_private.h - definitions for processing of ELF files
3 *
4 * Copyright (C) 1996, Eric Youngdale.
5 * 1999-2007 Eric Pouech
6 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
20 */
21
22 #ifdef HAVE_ELF_H
23 # include <elf.h>
24 #endif
25 #ifdef HAVE_SYS_ELF32_H
26 # include <sys/elf32.h>
27 #endif
28 #ifdef HAVE_SYS_EXEC_ELF_H
29 # include <sys/exec_elf.h>
30 #endif
31 #if !defined(DT_NUM)
32 # if defined(DT_COUNT)
33 # define DT_NUM DT_COUNT
34 # else
35 /* this seems to be a satisfactory value on Solaris, which doesn't support this AFAICT */
36 # define DT_NUM 24
37 # endif
38 #endif
39 #ifdef HAVE_LINK_H
40 # include <link.h>
41 #endif
42 #ifdef HAVE_SYS_LINK_H
43 # include <sys/link.h>
44 #endif
45
46 #define IMAGE_NO_MAP ((void*)-1)
47
48 #ifdef __ELF__
49
50 #ifdef _WIN64
51 #define Elf_Ehdr Elf64_Ehdr
52 #define Elf_Shdr Elf64_Shdr
53 #define Elf_Phdr Elf64_Phdr
54 #define Elf_Dyn Elf64_Dyn
55 #define Elf_Sym Elf64_Sym
56 #else
57 #define Elf_Ehdr Elf32_Ehdr
58 #define Elf_Shdr Elf32_Shdr
59 #define Elf_Phdr Elf32_Phdr
60 #define Elf_Dyn Elf32_Dyn
61 #define Elf_Sym Elf32_Sym
62 #endif
63 #else
64 #ifndef SHT_NULL
65 #define SHT_NULL 0
66 #endif
67 #endif
68
69 /* structure holding information while handling an ELF image
70 * allows one by one section mapping for memory savings
71 */
72 struct image_file_map
73 {
74 enum module_type modtype;
75 union
76 {
77 struct elf_file_map
78 {
79 size_t elf_size;
80 size_t elf_start;
81 int fd;
82 const char* shstrtab;
83 struct image_file_map* alternate; /* another ELF file (linked to this one) */
84 #ifdef __ELF__
85 Elf_Ehdr elfhdr;
86 struct
87 {
88 Elf_Shdr shdr;
89 const char* mapped;
90 }* sect;
91 #endif
92 } elf;
93 struct pe_file_map
94 {
95 HANDLE hMap;
96 IMAGE_NT_HEADERS ntheader;
97 unsigned full_count;
98 void* full_map;
99 struct
100 {
101 IMAGE_SECTION_HEADER shdr;
102 const char* mapped;
103 }* sect;
104 const char* strtable;
105 } pe;
106 } u;
107 };
108
109 struct image_section_map
110 {
111 struct image_file_map* fmap;
112 long sidx;
113 };
114
115 extern BOOL elf_find_section(struct image_file_map* fmap, const char* name,
116 unsigned sht, struct image_section_map* ism);
117 extern const char* elf_map_section(struct image_section_map* ism);
118 extern void elf_unmap_section(struct image_section_map* ism);
119 extern DWORD_PTR elf_get_map_rva(const struct image_section_map* ism);
120 extern unsigned elf_get_map_size(const struct image_section_map* ism);
121
122 extern BOOL pe_find_section(struct image_file_map* fmap, const char* name,
123 struct image_section_map* ism);
124 extern const char* pe_map_section(struct image_section_map* psm);
125 extern void pe_unmap_section(struct image_section_map* psm);
126 extern DWORD_PTR pe_get_map_rva(const struct image_section_map* psm);
127 extern unsigned pe_get_map_size(const struct image_section_map* psm);
128
129 static inline BOOL image_find_section(struct image_file_map* fmap, const char* name,
130 struct image_section_map* ism)
131 {
132 switch (fmap->modtype)
133 {
134 case DMT_ELF: return elf_find_section(fmap, name, SHT_NULL, ism);
135 case DMT_PE: return pe_find_section(fmap, name, ism);
136 default: assert(0); return FALSE;
137 }
138 }
139
140 static inline const char* image_map_section(struct image_section_map* ism)
141 {
142 if (!ism->fmap) return NULL;
143 switch (ism->fmap->modtype)
144 {
145 case DMT_ELF: return elf_map_section(ism);
146 case DMT_PE: return pe_map_section(ism);
147 default: assert(0); return NULL;
148 }
149 }
150
151 static inline void image_unmap_section(struct image_section_map* ism)
152 {
153 if (!ism->fmap) return;
154 switch (ism->fmap->modtype)
155 {
156 case DMT_ELF: elf_unmap_section(ism); break;
157 case DMT_PE: pe_unmap_section(ism); break;
158 default: assert(0); return;
159 }
160 }
161
162 static inline DWORD_PTR image_get_map_rva(struct image_section_map* ism)
163 {
164 if (!ism->fmap) return 0;
165 switch (ism->fmap->modtype)
166 {
167 case DMT_ELF: return elf_get_map_rva(ism);
168 case DMT_PE: return pe_get_map_rva(ism);
169 default: assert(0); return 0;
170 }
171 }
172
173 static inline unsigned image_get_map_size(struct image_section_map* ism)
174 {
175 if (!ism->fmap) return 0;
176 switch (ism->fmap->modtype)
177 {
178 case DMT_ELF: return elf_get_map_size(ism);
179 case DMT_PE: return pe_get_map_size(ism);
180 default: assert(0); return 0;
181 }
182 }