6 #define IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x010b
7 #define IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x020b
9 #define IMAGE_DOS_MAGIC 0x5a4d
10 #define IMAGE_PE_MAGIC 0x00004550
11 #define IMAGE_SIZEOF_SHORT_NAME 8
13 #define IMAGE_FILE_LINE_NUMS_STRIPPED 0x0004
14 #define IMAGE_FILE_LOCAL_SYMS_STRIPPED 0x0008
15 #define IMAGE_FILE_DEBUG_STRIPPED 0x0200
17 #define IMAGE_DIRECTORY_ENTRY_BASERELOC 5
19 #define IMAGE_SCN_TYPE_NOLOAD 0x00000002
20 #define IMAGE_SCN_TYPE_NO_PAD 0x00000008
21 #define IMAGE_SCN_CNT_CODE 0x00000020
22 #define IMAGE_SCN_CNT_INITIALIZED_DATA 0x00000040
23 #define IMAGE_SCN_CNT_UNINITIALIZED_DATA 0x00000080
24 #define IMAGE_SCN_LNK_OTHER 0x00000100
25 #define IMAGE_SCN_LNK_INFO 0x00000200
26 #define IMAGE_SCN_LNK_REMOVE 0x00000800
27 #define IMAGE_SCN_NO_DEFER_SPEC_EXC 0x00004000
28 #define IMAGE_SCN_GPREL 0x00008000
29 #define IMAGE_SCN_MEM_PURGEABLE 0x00020000
30 #define IMAGE_SCN_MEM_LOCKED 0x00040000
31 #define IMAGE_SCN_MEM_PRELOAD 0x00080000
32 #define IMAGE_SCN_LNK_NRELOC_OVFL 0x01000000
33 #define IMAGE_SCN_MEM_DISCARDABLE 0x02000000
34 #define IMAGE_SCN_MEM_NOT_CACHED 0x04000000
35 #define IMAGE_SCN_MEM_NOT_PAGED 0x08000000
36 #define IMAGE_SCN_MEM_SHARED 0x10000000
37 #define IMAGE_SCN_MEM_EXECUTE 0x20000000
38 #define IMAGE_SCN_MEM_READ 0x40000000
39 #define IMAGE_SCN_MEM_WRITE 0x80000000
41 #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
43 typedef unsigned char BYTE
;
44 typedef unsigned char UCHAR
;
45 typedef unsigned short WORD
;
46 typedef unsigned short USHORT
;
47 typedef unsigned long long ULONGLONG
;
48 #if defined(__x86_64__) && defined(unix)
49 typedef signed int LONG
;
50 typedef unsigned int ULONG
;
51 typedef unsigned int DWORD
;
53 typedef signed long LONG
;
54 typedef unsigned long ULONG
;
55 typedef unsigned long DWORD
;
58 typedef unsigned __int64 ULONG_PTR
;
60 #if defined(__x86_64__) && defined(unix)
61 typedef unsigned int ULONG_PTR
;
63 typedef unsigned long ULONG_PTR
;
69 typedef struct _IMAGE_DOS_HEADER
{
89 } IMAGE_DOS_HEADER
,*PIMAGE_DOS_HEADER
;
93 typedef struct _IMAGE_FILE_HEADER
{
95 WORD NumberOfSections
;
97 DWORD PointerToSymbolTable
;
98 DWORD NumberOfSymbols
;
99 WORD SizeOfOptionalHeader
;
100 WORD Characteristics
;
101 } IMAGE_FILE_HEADER
, *PIMAGE_FILE_HEADER
;
104 typedef struct _IMAGE_DATA_DIRECTORY
{
105 DWORD VirtualAddress
;
107 } IMAGE_DATA_DIRECTORY
,*PIMAGE_DATA_DIRECTORY
;
109 typedef struct _IMAGE_OPTIONAL_HEADER32
{
111 BYTE MajorLinkerVersion
;
112 BYTE MinorLinkerVersion
;
114 DWORD SizeOfInitializedData
;
115 DWORD SizeOfUninitializedData
;
116 DWORD AddressOfEntryPoint
;
120 DWORD SectionAlignment
;
122 WORD MajorOperatingSystemVersion
;
123 WORD MinorOperatingSystemVersion
;
124 WORD MajorImageVersion
;
125 WORD MinorImageVersion
;
126 WORD MajorSubsystemVersion
;
127 WORD MinorSubsystemVersion
;
128 DWORD Win32VersionValue
;
133 WORD DllCharacteristics
;
134 DWORD SizeOfStackReserve
;
135 DWORD SizeOfStackCommit
;
136 DWORD SizeOfHeapReserve
;
137 DWORD SizeOfHeapCommit
;
139 DWORD NumberOfRvaAndSizes
;
140 IMAGE_DATA_DIRECTORY DataDirectory
[IMAGE_NUMBEROF_DIRECTORY_ENTRIES
];
141 } IMAGE_OPTIONAL_HEADER32
,*PIMAGE_OPTIONAL_HEADER32
;
143 typedef struct _IMAGE_OPTIONAL_HEADER64
{
145 BYTE MajorLinkerVersion
;
146 BYTE MinorLinkerVersion
;
148 DWORD SizeOfInitializedData
;
149 DWORD SizeOfUninitializedData
;
150 DWORD AddressOfEntryPoint
;
153 DWORD SectionAlignment
;
155 WORD MajorOperatingSystemVersion
;
156 WORD MinorOperatingSystemVersion
;
157 WORD MajorImageVersion
;
158 WORD MinorImageVersion
;
159 WORD MajorSubsystemVersion
;
160 WORD MinorSubsystemVersion
;
161 DWORD Win32VersionValue
;
166 WORD DllCharacteristics
;
167 ULONGLONG SizeOfStackReserve
;
168 ULONGLONG SizeOfStackCommit
;
169 ULONGLONG SizeOfHeapReserve
;
170 ULONGLONG SizeOfHeapCommit
;
172 DWORD NumberOfRvaAndSizes
;
173 IMAGE_DATA_DIRECTORY DataDirectory
[IMAGE_NUMBEROF_DIRECTORY_ENTRIES
];
174 } IMAGE_OPTIONAL_HEADER64
,*PIMAGE_OPTIONAL_HEADER64
;
178 typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER
;
179 typedef PIMAGE_OPTIONAL_HEADER64 PIMAGE_OPTIONAL_HEADER
;
181 typedef IMAGE_OPTIONAL_HEADER32 IMAGE_OPTIONAL_HEADER
;
182 typedef PIMAGE_OPTIONAL_HEADER32 PIMAGE_OPTIONAL_HEADER
;
185 typedef struct _IMAGE_SECTION_HEADER
{
186 BYTE Name
[IMAGE_SIZEOF_SHORT_NAME
];
188 DWORD PhysicalAddress
;
191 DWORD VirtualAddress
;
193 DWORD PointerToRawData
;
194 DWORD PointerToRelocations
;
195 DWORD PointerToLinenumbers
;
196 WORD NumberOfRelocations
;
197 WORD NumberOfLinenumbers
;
198 DWORD Characteristics
;
199 } IMAGE_SECTION_HEADER
,*PIMAGE_SECTION_HEADER
;
202 typedef struct _IMAGE_BASE_RELOCATION
{
203 DWORD VirtualAddress
;
206 } IMAGE_BASE_RELOCATION
,*PIMAGE_BASE_RELOCATION
;
210 USHORT f_magic
; /* magic number */
211 USHORT f_nscns
; /* number of sections */
212 ULONG f_timdat
; /* time & date stamp */
213 ULONG f_symptr
; /* file pointer to symtab */
214 ULONG f_nsyms
; /* number of symtab entries */
215 USHORT f_opthdr
; /* sizeof(optional hdr) */
216 USHORT f_flags
; /* flags */
220 char s_name
[8]; /* section name */
221 ULONG s_paddr
; /* physical address, aliased s_nlib */
222 ULONG s_vaddr
; /* virtual address */
223 ULONG s_size
; /* section size */
224 ULONG s_scnptr
; /* file ptr to raw data for section */
225 ULONG s_relptr
; /* file ptr to relocation */
226 ULONG s_lnnoptr
; /* file ptr to line numbers */
227 USHORT s_nreloc
; /* number of relocation entries */
228 USHORT s_nlnno
; /* number of line number entries */
229 ULONG s_flags
; /* flags */
233 typedef struct _SYMBOLFILE_HEADER
{
238 } SYMBOLFILE_HEADER
, *PSYMBOLFILE_HEADER
;
240 typedef struct _STAB_ENTRY
{
241 ULONG n_strx
; /* index into string table of name */
242 UCHAR n_type
; /* type of symbol */
243 UCHAR n_other
; /* misc info (usually empty) */
244 USHORT n_desc
; /* description field */
245 ULONG n_value
; /* value of symbol */
246 } STAB_ENTRY
, *PSTAB_ENTRY
;
248 /* http://www.math.utah.edu/docs/info/stabs_12.html */
261 #define N_DSLINE 0x46
262 #define N_BSLINE 0x48
265 #define N_EHDECL 0x50
285 /* COFF symbol table */
287 #define E_SYMNMLEN 8 /* # characters in a symbol name */
288 #define E_FILNMLEN 14 /* # characters in a file name */
289 #define E_DIMNUM 4 /* # array dimensions in auxiliary entry */
291 #define N_BTMASK (0xf)
292 #define N_TMASK (0x30)
296 /* derived types, in e_type */
297 #define DT_NON (0) /* no derived type */
298 #define DT_PTR (1) /* pointer */
299 #define DT_FCN (2) /* function */
300 #define DT_ARY (3) /* array */
302 #define BTYPE(x) ((x) & N_BTMASK)
304 #define ISPTR(x) (((x) & N_TMASK) == (DT_PTR << N_BTSHFT))
305 #define ISFCN(x) (((x) & N_TMASK) == (DT_FCN << N_BTSHFT))
306 #define ISARY(x) (((x) & N_TMASK) == (DT_ARY << N_BTSHFT))
307 #define ISTAG(x) ((x)==C_STRTAG||(x)==C_UNTAG||(x)==C_ENTAG)
308 #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
310 #define C_EFCN 0xff /* physical end of function */
312 #define C_AUTO 1 /* automatic variable */
313 #define C_EXT 2 /* external symbol */
314 #define C_STAT 3 /* static */
315 #define C_REG 4 /* register variable */
316 #define C_EXTDEF 5 /* external definition */
317 #define C_LABEL 6 /* label */
318 #define C_ULABEL 7 /* undefined label */
319 #define C_MOS 8 /* member of structure */
320 #define C_ARG 9 /* function argument */
321 #define C_STRTAG 10 /* structure tag */
322 #define C_MOU 11 /* member of union */
323 #define C_UNTAG 12 /* union tag */
324 #define C_TPDEF 13 /* type definition */
325 #define C_USTATIC 14 /* undefined static */
326 #define C_ENTAG 15 /* enumeration tag */
327 #define C_MOE 16 /* member of enumeration */
328 #define C_REGPARM 17 /* register parameter */
329 #define C_FIELD 18 /* bit field */
330 #define C_AUTOARG 19 /* auto argument */
331 #define C_LASTENT 20 /* dummy entry (end of block) */
332 #define C_BLOCK 100 /* ".bb" or ".eb" */
333 #define C_FCN 101 /* ".bf" or ".ef" */
334 #define C_EOS 102 /* end of structure */
335 #define C_FILE 103 /* file name */
336 #define C_LINE 104 /* line # reformatted as symbol table entry */
337 #define C_ALIAS 105 /* duplicate tag */
338 #define C_HIDDEN 106 /* ext symbol in dmert public lib */
341 typedef struct _COFF_SYMENT
345 char e_name
[E_SYMNMLEN
];
359 } COFF_SYMENT
, *PCOFF_SYMENT
;
362 typedef struct _ROSSYM_ENTRY
{
364 ULONG FunctionOffset
;
367 } ROSSYM_ENTRY
, *PROSSYM_ENTRY
;
369 #define ROUND_UP(N, S) (((N) + (S) - 1) & ~((S) - 1))
372 convert_path(const char* origpath
);
375 load_file ( const char* file_name
, size_t* file_size
);