VirtualBox

source: vbox/trunk/src/VBox/Runtime/include/internal/ldr.h@ 31960

Last change on this file since 31960 was 28800, checked in by vboxsync, 15 years ago

Automated rebranding to Oracle copyright/license strings via filemuncher

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 13.4 KB
Line 
1/* $Id: ldr.h 28800 2010-04-27 08:22:32Z vboxsync $ */
2/** @file
3 * IPRT - Loader Internals.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef ___internal_ldr_h
28#define ___internal_ldr_h
29
30#include <iprt/types.h>
31#include "internal/magics.h"
32
33RT_C_DECLS_BEGIN
34
35
36/*******************************************************************************
37* Defined Constants And Macros *
38*******************************************************************************/
39#ifdef DOXYGEN_RUNNING
40/** @def LDR_WITH_NATIVE
41 * Define this to get native support. */
42# define LDR_WITH_NATIVE
43
44/** @def LDR_WITH_ELF32
45 * Define this to get 32-bit ELF support. */
46# define LDR_WITH_ELF32
47
48/** @def LDR_WITH_ELF64
49 * Define this to get 64-bit ELF support. */
50# define LDR_WITH_ELF64
51
52/** @def LDR_WITH_PE
53 * Define this to get 32-bit and 64-bit PE support. */
54# define LDR_WITH_PE
55
56/** @def LDR_WITH_LX
57 * Define this to get LX support. */
58# define LDR_WITH_LX
59
60/** @def LDR_WITH_MACHO
61 * Define this to get mach-o support (not implemented yet). */
62# define LDR_WITH_MACHO
63#endif /* DOXYGEN_RUNNING */
64
65#if defined(LDR_WITH_ELF32) || defined(LDR_WITH_ELF64)
66/** @def LDR_WITH_ELF
67 * This is defined if any of the ELF versions is requested.
68 */
69# define LDR_WITH_ELF
70#endif
71
72/* These two may clash with winnt.h. */
73#undef IMAGE_DOS_SIGNATURE
74#undef IMAGE_NT_SIGNATURE
75
76
77/** Little endian uint32_t ELF signature ("\x7fELF"). */
78#define IMAGE_ELF_SIGNATURE (0x7f | ('E' << 8) | ('L' << 16) | ('F' << 24))
79/** Little endian uint32_t PE signature ("PE\0\0"). */
80#define IMAGE_NT_SIGNATURE 0x00004550
81/** Little endian uint16_t LX signature ("LX") */
82#define IMAGE_LX_SIGNATURE ('L' | ('X' << 8))
83/** Little endian uint16_t LE signature ("LE") */
84#define IMAGE_LE_SIGNATURE ('L' | ('E' << 8))
85/** Little endian uint16_t NE signature ("NE") */
86#define IMAGE_NE_SIGNATURE ('N' | ('E' << 8))
87/** Little endian uint16_t MZ signature ("MZ"). */
88#define IMAGE_DOS_SIGNATURE ('M' | ('Z' << 8))
89
90
91/*******************************************************************************
92* Structures and Typedefs *
93*******************************************************************************/
94/**
95 * Loader state.
96 */
97typedef enum RTLDRSTATE
98{
99 /** Invalid. */
100 LDR_STATE_INVALID = 0,
101 /** Opened. */
102 LDR_STATE_OPENED,
103 /** The image can no longer be relocated. */
104 LDR_STATE_DONE,
105 /** The image was loaded, not opened. */
106 LDR_STATE_LOADED,
107 /** The usual 32-bit hack. */
108 LDR_STATE_32BIT_HACK = 0x7fffffff
109} RTLDRSTATE;
110
111
112/** Pointer to a loader item. */
113typedef struct RTLDRMODINTERNAL *PRTLDRMODINTERNAL;
114
115/**
116 * Loader module operations.
117 */
118typedef struct RTLDROPS
119{
120 /** The name of the executable format. */
121 const char *pszName;
122
123 /**
124 * Release any resources attached to the module.
125 * The caller will do RTMemFree on pMod on return.
126 *
127 * @returns iprt status code.
128 * @param pMod Pointer to the loader module structure.
129 * @remark Compulsory entry point.
130 */
131 DECLCALLBACKMEMBER(int, pfnClose)(PRTLDRMODINTERNAL pMod);
132
133 /**
134 * Gets a simple symbol.
135 * This entrypoint can be omitted if RTLDROPS::pfnGetSymbolEx() is provided.
136 *
137 * @returns iprt status code.
138 * @param pMod Pointer to the loader module structure.
139 * @param pszSymbol The symbol name.
140 * @param ppvValue Where to store the symbol value.
141 */
142 DECLCALLBACKMEMBER(int, pfnGetSymbol)(PRTLDRMODINTERNAL pMod, const char *pszSymbol, void **ppvValue);
143
144 /**
145 * Called when we're done with getting bits and relocating them.
146 * This is used to release resources used by the loader to support those actions.
147 *
148 * After this call none of the extended loader functions can be called.
149 *
150 * @returns iprt status code.
151 * @param pMod Pointer to the loader module structure.
152 * @remark This is an optional entry point.
153 */
154 DECLCALLBACKMEMBER(int, pfnDone)(PRTLDRMODINTERNAL pMod);
155
156 /**
157 * Enumerates the symbols exported by the module.
158 *
159 * @returns iprt status code, which might have been returned by pfnCallback.
160 * @param pMod Pointer to the loader module structure.
161 * @param fFlags Flags indicating what to return and such.
162 * @param pvBits Pointer to the bits returned by RTLDROPS::pfnGetBits(), optional.
163 * @param BaseAddress The image base addressto use when calculating the symbol values.
164 * @param pfnCallback The callback function which each symbol is to be feeded to.
165 * @param pvUser User argument to pass to the enumerator.
166 * @remark This is an optional entry point.
167 */
168 DECLCALLBACKMEMBER(int, pfnEnumSymbols)(PRTLDRMODINTERNAL pMod, unsigned fFlags, const void *pvBits, RTUINTPTR BaseAddress,
169 PFNRTLDRENUMSYMS pfnCallback, void *pvUser);
170
171
172/* extended functions: */
173
174 /**
175 * Gets the size of the loaded image (i.e. in memory).
176 *
177 * @returns in memory size, in bytes.
178 * @returns ~(size_t)0 if it's not an extended image.
179 * @param pMod Pointer to the loader module structure.
180 * @remark Extended loader feature.
181 */
182 DECLCALLBACKMEMBER(size_t, pfnGetImageSize)(PRTLDRMODINTERNAL pMod);
183
184 /**
185 * Gets the image bits fixed up for a specified address.
186 *
187 * @returns iprt status code.
188 * @param pMod Pointer to the loader module structure.
189 * @param pvBits Where to store the bits. The size of this buffer is equal or
190 * larger to the value returned by pfnGetImageSize().
191 * @param BaseAddress The base address which the image should be fixed up to.
192 * @param pfnGetImport The callback function to use to resolve imports (aka unresolved externals).
193 * @param pvUser User argument to pass to the callback.
194 * @remark Extended loader feature.
195 */
196 DECLCALLBACKMEMBER(int, pfnGetBits)(PRTLDRMODINTERNAL pMod, void *pvBits, RTUINTPTR BaseAddress, PFNRTLDRIMPORT pfnGetImport, void *pvUser);
197
198 /**
199 * Relocate bits obtained using pfnGetBits to a new address.
200 *
201 * @returns iprt status code.
202 * @param pMod Pointer to the loader module structure.
203 * @param pvBits Where to store the bits. The size of this buffer is equal or
204 * larger to the value returned by pfnGetImageSize().
205 * @param NewBaseAddress The base address which the image should be fixed up to.
206 * @param OldBaseAddress The base address which the image is currently fixed up to.
207 * @param pfnGetImport The callback function to use to resolve imports (aka unresolved externals).
208 * @param pvUser User argument to pass to the callback.
209 * @remark Extended loader feature.
210 */
211 DECLCALLBACKMEMBER(int, pfnRelocate)(PRTLDRMODINTERNAL pMod, void *pvBits, RTUINTPTR NewBaseAddress, RTUINTPTR OldBaseAddress, PFNRTLDRIMPORT pfnGetImport, void *pvUser);
212
213 /**
214 * Gets a symbol with special base address and stuff.
215 * This entrypoint can be omitted if RTLDROPS::pfnGetSymbolEx() is provided and the special BaseAddress feature isn't supported.
216 *
217 * @returns iprt status code.
218 * @param pMod Pointer to the loader module structure.
219 * @param pvBits Pointer to bits returned by RTLDROPS::pfnGetBits(), optional.
220 * @param BaseAddress The image base address to use when calculating the symbol value.
221 * @param pszSymbol The symbol name.
222 * @param pValue Where to store the symbol value.
223 * @remark Extended loader feature.
224 */
225 DECLCALLBACKMEMBER(int, pfnGetSymbolEx)(PRTLDRMODINTERNAL pMod, const void *pvBits, RTUINTPTR BaseAddress, const char *pszSymbol, RTUINTPTR *pValue);
226
227 /** Dummy entry to make sure we've initialized it all. */
228 RTUINT uDummy;
229} RTLDROPS;
230typedef RTLDROPS *PRTLDROPS;
231typedef const RTLDROPS *PCRTLDROPS;
232
233
234/** Pointer to a loader reader instance. */
235typedef struct RTLDRREADER *PRTLDRREADER;
236
237/**
238 * Loader image reader instance.
239 * The reader will have extra data members following this structure.
240 */
241typedef struct RTLDRREADER
242{
243 /** The name of the image provider. */
244 const char *pszName;
245
246 /**
247 * Reads bytes at a give place in the raw image.
248 *
249 * @returns iprt status code.
250 * @param pReader Pointer to the reader instance.
251 * @param pvBuf Where to store the bits.
252 * @param cb Number of bytes to read.
253 * @param off Where to start reading relative to the start of the raw image.
254 */
255 DECLCALLBACKMEMBER(int, pfnRead)(PRTLDRREADER pReader, void *pvBuf, size_t cb, RTFOFF off);
256
257 /**
258 * Tells end position of last read.
259 *
260 * @returns position relative to start of the raw image.
261 * @param pReader Pointer to the reader instance.
262 */
263 DECLCALLBACKMEMBER(RTFOFF, pfnTell)(PRTLDRREADER pReader);
264
265 /**
266 * Gets the size of the raw image bits.
267 *
268 * @returns size of raw image bits in bytes.
269 * @param pReader Pointer to the reader instance.
270 */
271 DECLCALLBACKMEMBER(RTFOFF, pfnSize)(PRTLDRREADER pReader);
272
273 /**
274 * Map the bits into memory.
275 *
276 * The mapping will be freed upon calling pfnDestroy() if not pfnUnmap()
277 * is called before that. The mapping is read only.
278 *
279 * @returns iprt status code.
280 * @param pReader Pointer to the reader instance.
281 * @param ppvBits Where to store the address of the memory mapping on success.
282 * The size of the mapping can be obtained by calling pfnSize().
283 */
284 DECLCALLBACKMEMBER(int, pfnMap)(PRTLDRREADER pReader, const void **ppvBits);
285
286 /**
287 * Unmap bits.
288 *
289 * @returns iprt status code.
290 * @param pReader Pointer to the reader instance.
291 * @param pvBits Memory pointer returned by pfnMap().
292 */
293 DECLCALLBACKMEMBER(int, pfnUnmap)(PRTLDRREADER pReader, const void *pvBits);
294
295 /**
296 * Gets the most appropriate log name.
297 *
298 * @returns Pointer to readonly log name.
299 * @param pReader Pointer to the reader instance.
300 */
301 DECLCALLBACKMEMBER(const char *, pfnLogName)(PRTLDRREADER pReader);
302
303 /**
304 * Releases all resources associated with the reader instance.
305 * The instance is invalid after this call returns.
306 *
307 * @returns iprt status code.
308 * @param pReader Pointer to the reader instance.
309 */
310 DECLCALLBACKMEMBER(int, pfnDestroy)(PRTLDRREADER pReader);
311
312} RTLDRREADER;
313
314
315/**
316 * Loader module core.
317 */
318typedef struct RTLDRMODINTERNAL
319{
320 /** The loader magic value (RTLDRMOD_MAGIC). */
321 uint32_t u32Magic;
322 /** State. */
323 RTLDRSTATE eState;
324 /** Loader ops. */
325 PCRTLDROPS pOps;
326} RTLDRMODINTERNAL;
327
328
329/**
330 * Validates that a loader module handle is valid.
331 *
332 * @returns true if valid.
333 * @returns false if invalid.
334 * @param hLdrMod The loader module handle.
335 */
336DECLINLINE(bool) rtldrIsValid(RTLDRMOD hLdrMod)
337{
338 return VALID_PTR(hLdrMod)
339 && ((PRTLDRMODINTERNAL)hLdrMod)->u32Magic == RTLDRMOD_MAGIC;
340}
341
342int rtldrOpenWithReader(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, PRTLDRMOD phMod);
343
344
345/**
346 * Native loader module.
347 */
348typedef struct RTLDRMODNATIVE
349{
350 /** The core structure. */
351 RTLDRMODINTERNAL Core;
352 /** The native handle. */
353 uintptr_t hNative;
354} RTLDRMODNATIVE, *PRTLDRMODNATIVE;
355
356/** @copydoc RTLDROPS::pfnGetSymbol */
357DECLCALLBACK(int) rtldrNativeGetSymbol(PRTLDRMODINTERNAL pMod, const char *pszSymbol, void **ppvValue);
358/** @copydoc RTLDROPS::pfnClose */
359DECLCALLBACK(int) rtldrNativeClose(PRTLDRMODINTERNAL pMod);
360
361/**
362 * Load a native module using the native loader.
363 *
364 * @returns iprt status code.
365 * @param pszFilename The image filename.
366 * @param phHandle Where to store the module handle on success.
367 */
368int rtldrNativeLoad(const char *pszFilename, uintptr_t *phHandle);
369
370int rtldrPEOpen(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, RTFOFF offNtHdrs, PRTLDRMOD phLdrMod);
371int rtldrELFOpen(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, PRTLDRMOD phLdrMod);
372int rtldrkLdrOpen(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, PRTLDRMOD phLdrMod);
373/*int rtldrLXOpen(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, RTFOFF offLX, PRTLDRMOD phLdrMod);
374int rtldrMachoOpen(PRTLDRREADER pReader, uint32_t fFlags, RTLDRARCH enmArch, RTFOFF offSomething, PRTLDRMOD phLdrMod);*/
375
376
377RT_C_DECLS_END
378
379#endif
380
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette