/*++ Copyright (c) 1995 Microsoft Corporation Module Name: imagehlp.h Abstract: This is a private header file for imagehlp. Revision History: --*/ #ifndef _IMAGEHLP_PRV_ #define _IMAGEHLP_PRV_ #define _IMAGEHLP_SOURCE_ #define _IA64REG_ #include #include #include #include #include #include #include #include #if DBG // disable the -DNDEBUG set by oak\bin\makefile.def #undef NDEBUG #endif // DBG #include #include #include #include #include #define PDB_LIBRARY #include #include "pdbp.h" #ifdef __cplusplus extern "C" { #endif // used for delayloading the pdb handler #define REGKEY_DBGHELP "SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\dbgHelp" #define REGVAL_PDBHANDLER "PDBHandler" // define the module #ifdef BUILD_DBGHELP #define MOD_FILENAME "dbghelp.dll" #define MOD_NAME "dbghelp" #else #define MOD_FILENAME "imagehlp.dll" #define MOD_NAME "imagehlp" #endif #ifndef SIZEOF_ARRAY #define SIZEOF_ARRAY(_ar) (sizeof(_ar)/sizeof((_ar)[0])) #endif // !defined(SIZEOF_ARRAY) /****************************************************************************** On a Hydra System, we don't want imaghlp.dll to load user32.dll since it prevents CSRSS from exiting when running a under a debugger. The following two functions have been copied from user32.dll so that we don't link to user32.dll. ******************************************************************************/ #undef CharNext #undef CharPrev LPSTR CharNext( LPCSTR lpCurrentChar); LPSTR CharPrev( LPCSTR lpStart, LPCSTR lpCurrentChar); // Define some list prototypes #define InitializeListHead(ListHead) (\ (ListHead)->Flink = (ListHead)->Blink = (ListHead)) #define IsListEmpty(ListHead) \ ((ListHead)->Flink == (ListHead)) #define InsertTailList(ListHead,Entry) {\ PLIST_ENTRY _EX_Blink;\ PLIST_ENTRY _EX_ListHead;\ _EX_ListHead = (ListHead);\ _EX_Blink = _EX_ListHead->Blink;\ (Entry)->Flink = _EX_ListHead;\ (Entry)->Blink = _EX_Blink;\ _EX_Blink->Flink = (Entry);\ _EX_ListHead->Blink = (Entry);\ } #define RemoveEntryList(Entry) {\ PLIST_ENTRY _EX_Blink;\ PLIST_ENTRY _EX_Flink;\ _EX_Flink = (Entry)->Flink;\ _EX_Blink = (Entry)->Blink;\ _EX_Blink->Flink = _EX_Flink;\ _EX_Flink->Blink = _EX_Blink;\ } // // some helpers for PE32/PE64 issues // #define OPTIONALHEADER(field) (OptionalHeader32 ? (OptionalHeader32->field) : (OptionalHeader64 ? OptionalHeader64->field : 0)) #define OPTIONALHEADER_LV(field) (*(OptionalHeader32 ? &(OptionalHeader32->field) : &(OptionalHeader64->field))) #define OPTIONALHEADER_ASSIGN(field,value) (OptionalHeader32 ? (OptionalHeader32->field=(value)) : (OptionalHeader64->field=(value))) #define OPTIONALHEADER_SET_FLAG(field,flag) (OptionalHeader32 ? (OptionalHeader32->field |=(flag)) : (OptionalHeader64->field|=(flag))) #define OPTIONALHEADER_CLEAR_FLAG(field,flag) (OptionalHeader32 ? (OptionalHeader32->field &=(~flag)) : (OptionalHeader64->field&=(~flag))) // IA64 unwind specific structures #define VWNDIA64_FIXUP_TABLE_SIZE 5 #define VWNDIA64_UNWIND_CONTEXT_TABLE_SIZE 5 typedef struct _VWNDIA64_FUXUP_REGION { ULONGLONG Ip; ULONGLONG Begin; ULONGLONG End; ULONGLONG Fixup; } VWNDIA64_FUXUP_REGION, *PVWNDIA64_FUXUP_REGION; typedef struct _VWNDIA64_UNWIND_CONTEXT { BOOL bFailureReported; VWNDIA64_FUXUP_REGION FixupTable[VWNDIA64_FIXUP_TABLE_SIZE]; } VWNDIA64_UNWIND_CONTEXT, *PVWNDIA64_UNWIND_CONTEXT; // stackwalk operation flags #define WALK_FIX_FPO_EBP 0x1 __inline void OptionalHeadersFromNtHeaders( PIMAGE_NT_HEADERS32 NtHeaders, PIMAGE_OPTIONAL_HEADER32 *OptionalHeader32, PIMAGE_OPTIONAL_HEADER64 *OptionalHeader64 ) { if (NtHeaders->OptionalHeader.Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC) { if ( OptionalHeader32 ) { *OptionalHeader32 = (PIMAGE_OPTIONAL_HEADER32)&NtHeaders->OptionalHeader; } if ( OptionalHeader64 ) { *OptionalHeader64 = NULL; } } else if (NtHeaders->OptionalHeader.Magic == IMAGE_NT_OPTIONAL_HDR64_MAGIC) { if ( OptionalHeader64 ) { *OptionalHeader64 = (PIMAGE_OPTIONAL_HEADER64)&NtHeaders->OptionalHeader; } if ( OptionalHeader32 ) { *OptionalHeader32 = NULL; } } } #define DebugDirectoryIsUseful(Pointer, Size) ( \ (Pointer != NULL) && \ (Size >= sizeof(IMAGE_DEBUG_DIRECTORY)) && \ ((Size % sizeof(IMAGE_DEBUG_DIRECTORY)) == 0) \ ) ULONG IMAGEAPI SymGetFileLineOffsets64( IN HANDLE hProcess, IN LPSTR ModuleName, IN LPSTR FileName, OUT PDWORD64 Buffer, IN ULONG BufferLines ); BOOL CalculateImagePtrs( PLOADED_IMAGE LoadedImage ); typedef void * ( __cdecl * Alloc_t )( unsigned int ); typedef void ( __cdecl * Free_t )( void * ); typedef BOOL (__stdcall *PINTERNAL_GET_MODULE)(HANDLE,LPSTR,DWORD64,DWORD,PVOID); typedef PCHAR (__cdecl *PUNDNAME)( char *, const char *, int, Alloc_t, Free_t, unsigned short); #ifdef IMAGEHLP_HEAP_DEBUG #define HEAP_SIG 0x69696969 typedef struct _HEAP_BLOCK { LIST_ENTRY ListEntry; ULONG Signature; ULONG_PTR Size; ULONG Line; CHAR File[16]; } HEAP_BLOCK, *PHEAP_BLOCK; #define MemAlloc(s) pMemAlloc(s,__LINE__,__FILE__) #define MemReAlloc(s,n) pMemReAlloc(s,n,__LINE__,__FILE__) #define MemFree(p) pMemFree(p,__LINE__,__FILE__) #define CheckHeap(p) pCheckHeap(p,__LINE__,__FILE__) #define HeapDump(s) pHeapDump(s,__LINE__,__FILE__) #define MemSize(p) pMemSize(p) #define HeapInitList(p) InitializeListHead(p); #else #define MemAlloc(s) pMemAlloc(s) #define MemReAlloc(s,n) pMemReAlloc(s,n) #define MemFree(p) pMemFree(p) #define CheckHeap(p) #define HeapDump(s) #define MemSize(p) pMemSize(p) #define HeapInitList(p) #endif #ifdef IMAGEHLP_HEAP_DEBUG BOOL pCheckHeap( PVOID MemPtr, ULONG Line, LPSTR File ); BOOL pHeapDump( LPSTR sz, ULONG line, LPSTR file ); VOID PrintAllocations(VOID); #endif PVOID pMemAlloc( ULONG_PTR AllocSize #ifdef IMAGEHLP_HEAP_DEBUG ,ULONG Line ,LPSTR File #endif ); PVOID pMemReAlloc( PVOID OldAlloc, ULONG_PTR AllocSize #ifdef IMAGEHLP_HEAP_DEBUG ,ULONG Line ,LPSTR File #endif ); VOID pMemFree( PVOID MemPtr #ifdef IMAGEHLP_HEAP_DEBUG ,ULONG Line ,LPSTR File #endif ); ULONG_PTR pMemSize( PVOID MemPtr ); #define MAP_READONLY TRUE #define MAP_READWRITE FALSE BOOL MapIt( HANDLE FileHandle, PLOADED_IMAGE LoadedImage, BOOL ReadOnly ); VOID UnMapIt( PLOADED_IMAGE LoadedImage ); BOOL GrowMap( PLOADED_IMAGE LoadedImage, LONG lSizeOfDelta ); DWORD ImagepSetLastErrorFromStatus( IN DWORD Status ); BOOL UnloadAllImages( void ); #define CALLBACK_STACK(f) (f->KdHelp.ThCallbackStack) #define CALLBACK_BSTORE(f) (f->KdHelp.ThCallbackBStore) #define CALLBACK_NEXT(f) (f->KdHelp.NextCallback) #define CALLBACK_FUNC(f) (f->KdHelp.KiCallUserMode) #define CALLBACK_THREAD(f) (f->KdHelp.Thread) #define CALLBACK_FP(f) (f->KdHelp.FramePointer) #define CALLBACK_DISPATCHER(f) (f->KdHelp.KeUserCallbackDispatcher) #define SYSTEM_RANGE_START(f) (f->KdHelp.SystemRangeStart) // These modifications of the RF_ macros are required because of the need // for an explicit ULONG64 result #define ALPHA_RF_FIXED_RETURN64(RF) (((ULONG64)(RF)->ExceptionHandler) & (~3)) #define ALPHA_RF_ALT_PROLOG64(RF) (((ULONG64)(RF)->ExceptionHandler) & (~3)) extern ULONG g_vc7fpo; BOOL WalkX86( HANDLE hProcess, HANDLE hThread, LPSTACKFRAME64 StackFrame, PVOID ContextRecord, PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine, PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine, PGET_MODULE_BASE_ROUTINE64 GetModuleBase, PTRANSLATE_ADDRESS_ROUTINE64 TranslateAddress, DWORD flags ); BOOL WalkIa64( HANDLE hProcess, LPSTACKFRAME64 StackFrame, PVOID ContextRecord, PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine, PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine, PGET_MODULE_BASE_ROUTINE64 GetModuleBase ); BOOL WalkAlpha( HANDLE hProcess, LPSTACKFRAME64 StackFrame, PVOID ContextRecord, PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine, PGET_MODULE_BASE_ROUTINE64 GetModuleBase, PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine, BOOL Use64 ); BOOL WalkAmd64( HANDLE hProcess, LPSTACKFRAME64 StackFrame, PVOID ContextRecord, PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine, PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine, PGET_MODULE_BASE_ROUTINE64 GetModuleBase ); void ConvertAlphaRf32To64( PIMAGE_ALPHA_RUNTIME_FUNCTION_ENTRY rf32, PIMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY rf64 ); void SymParseArgs( LPCSTR args ); VOID EnsureTrailingBackslash( LPSTR sz ); enum { dsNone = 0, dsInProc, dsImage, dsDbg, dsPdb, dsDia, dsCallerData }; typedef struct _OMAP { ULONG rva; ULONG rvaTo; } OMAP, *POMAP; typedef struct _OMAPLIST { struct _OMAPLIST *next; OMAP omap; ULONG cb; } OMAPLIST, *POMAPLIST; enum { mdHeader = 100, mdSecHdrs, mdNum }; #define NUM_MODULE_DATA_ENTRIES 14 typedef BOOL (*PGETINFOPROC)(struct _IMGHLP_DEBUG_DATA *); typedef struct _MODULE_DATA { DWORD id; DWORD hint; DWORD src; BOOL required; PGETINFOPROC fn; } MODULE_DATA, *PMODULE_DATA; typedef struct _IMGHLP_DEBUG_DATA { PCHAR SymbolPath; ULONG64 InProcImageBase; ULONG64 ImageBaseFromImage; DWORD SizeOfImage; DWORD CheckSum; DWORD TimeDateStamp; DWORD Characteristics; USHORT Machine; CHAR ImageFilePath[_MAX_PATH]; CHAR OriginalImageFileName[_MAX_PATH]; // Retrieved from the .dbg file for cases when we only have a file handle... HANDLE ImageFileHandle; PVOID ImageMap; USHORT iohMagic; CHAR DbgFilePath[_MAX_PATH]; CHAR OriginalDbgFileName[_MAX_PATH]; HANDLE DbgFileHandle; PVOID DbgFileMap; DWORD PdbAge; DWORD PdbSignature; BOOL PdbRSDS; GUID PdbGUID; CHAR PdbFileName[_MAX_PATH]; CHAR PdbReferencePath[_MAX_PATH]; ULONG ImageType; ULONG ImageSrc; ULONG PdbSrc; PCHAR pMappedCv; PCHAR pMappedCoff; // PCHAR pMappedExportDirectory; PCHAR pMappedDbgFunction; // PIMAGE_FUNCTION_ENTRY from the .dbg file PVOID pFpo; PVOID pPData; // PIMAGE_RUNTIME_FUNCTION_ENTRY from the image. PVOID pXData; POMAP pOmapTo; POMAP pOmapFrom; PIMAGE_SECTION_HEADER pImageSections; PIMAGE_SECTION_HEADER pDbgSections; PIMAGE_SECTION_HEADER pOriginalSections; PIMAGE_SECTION_HEADER pCurrentSections; DWORD ddva; // only used by MapDebugInformation - virtual addr of debug dirs DWORD cdd; // only used by MapDebugInformation - number of debug dirs // ULONG NumberOfPdataFunctionEntries; ULONG cFpo; ULONG cPData; ULONG cbPData; ULONG cXData; ULONG cbXData; ULONG cOmapTo; ULONG cOmapFrom; ULONG cImageSections; ULONG cDbgSections; ULONG cOriginalSections; ULONG cCurrentSections; ULONG cMappedCv; ULONG cMappedCoff; ULONG ImageAlign; BOOL fPE64; BOOL fROM; BOOL fCoffMapped; BOOL fCvMapped; BOOL fFpoMapped; BOOL fPDataMapped; BOOL fXDataMapped; BOOL fOmapToMapped; BOOL fOmapFromMapped; BOOL fCurrentSectionsMapped; BOOL fInProcHeader; HANDLE hProcess; CHAR ImageName[_MAX_PATH]; DWORD dsExports; DWORD dsCoff; DWORD dsCV; DWORD dsMisc; DWORD dsFPO; DWORD dsOmapTo; DWORD dsOmapFrom; DWORD dsExceptions; IMAGE_EXPORT_DIRECTORY expdir; DWORD fNeedImage; PVOID dia; DWORD flags; PMODULE_DATA md; DWORD64 oExports; DWORD cExports; PMODLOAD_DATA mld; } IMGHLP_DEBUG_DATA, *PIMGHLP_DEBUG_DATA; typedef struct { DWORD rvaBeginAddress; DWORD rvaEndAddress; DWORD rvaPrologEndAddress; DWORD rvaExceptionHandler; DWORD rvaHandlerData; } IMGHLP_RVA_FUNCTION_DATA, *PIMGHLP_RVA_FUNCTION_DATA; #ifndef _WIN64 typedef struct { PIMGHLP_DEBUG_DATA pIDD; } PIDI_HEADER, *PPIDI_HEADER; typedef struct { PIDI_HEADER hdr; IMAGE_DEBUG_INFORMATION idi; } PIDI, *PPIDI; #endif PIMGHLP_DEBUG_DATA GetDebugData( HANDLE hProcess, HANDLE FileHandle, LPSTR FileName, LPSTR SymbolPath, ULONG64 ImageBase, PMODLOAD_DATA mld, ULONG dwFlags ); BOOL CopyPdb( CHAR const * SrcPdb, CHAR const * DestPdb, BOOL StripPrivate ); BOOL IMAGEAPI RemovePrivateCvSymbolic( PCHAR DebugData, PCHAR * NewDebugData, ULONG * NewDebugSize ); BOOL IMAGEAPI RemovePrivateCvSymbolicEx( PCHAR DebugData, ULONG DebugSize, PCHAR * NewDebugData, ULONG * NewDebugSize ); #define NO_PE64_IMAGES 0x01000 #define IMGHLP_FREE_ALL 0xffffffff #define IMGHLP_FREE_FPO 0x00000001 #define IMGHLP_FREE_PDATA 0x00000002 #define IMGHLP_FREE_OMAPT 0x00000004 #define IMGHLP_FREE_OMAPF 0x00000008 #define IMGHLP_FREE_PDB 0x00000010 #define IMGHLP_FREE_SYMPATH 0x00000020 #define IMGHLP_FREE_OSECT 0x00000040 #define IMGHLP_FREE_CSECT 0x00000080 #define IMGHLP_FREE_XDATA 0x00000100 PIMGHLP_DEBUG_DATA InitDebugData( VOID ); void ReleaseDebugData( PIMGHLP_DEBUG_DATA, DWORD ); ULONG ReadImageData( IN HANDLE hprocess, IN ULONG64 ul, IN ULONG64 addr, OUT LPVOID buffer, IN ULONG size ); #if DBG VOID __cdecl dbPrint( LPCSTR fmt, ... ); #else #define dbPrint #endif __inline BOOL IsPE64(PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER) OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR64_MAGIC ? TRUE : FALSE; } __inline UCHAR * OHMajorLinkerVersion(PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->MajorLinkerVersion); } __inline UCHAR * OHMinorLinkerVersion(PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->MinorLinkerVersion); } __inline ULONG * OHSizeOfCode (PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->SizeOfCode); } __inline ULONG * OHSizeOfInitializedData (PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->SizeOfInitializedData); } __inline ULONG * OHSizeOfUninitializedData (PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->SizeOfUninitializedData); } __inline ULONG * OHAddressOfEntryPoint (PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->AddressOfEntryPoint); } __inline ULONG * OHBaseOfCode (PVOID OptHeader) { return &(((PIMAGE_OPTIONAL_HEADER) OptHeader)->BaseOfCode); } __inline ULONG * OHImageBase (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->ImageBase) : (ULONG *)&(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->ImageBase); } __inline ULONG * OHSectionAlignment (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SectionAlignment) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SectionAlignment); } __inline ULONG * OHFileAlignment (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->FileAlignment) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->FileAlignment); } __inline USHORT * OHMajorOperatingSystemVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MajorOperatingSystemVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MajorOperatingSystemVersion); } __inline USHORT * OHMinorOperatingSystemVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MinorOperatingSystemVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MinorOperatingSystemVersion); } __inline USHORT * OHMajorImageVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MajorImageVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MajorImageVersion); } __inline USHORT * OHMinorImageVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MinorImageVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MinorImageVersion); } __inline USHORT * OHMajorSubsystemVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MajorSubsystemVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MajorSubsystemVersion); } __inline USHORT * OHMinorSubsystemVersion (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->MinorSubsystemVersion) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->MinorSubsystemVersion); } __inline ULONG * OHWin32VersionValue (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->Win32VersionValue) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->Win32VersionValue); } __inline ULONG * OHSizeOfImage (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfImage) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfImage); } __inline ULONG * OHSizeOfHeaders (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfHeaders) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfHeaders); } __inline ULONG * OHCheckSum (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->CheckSum) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->CheckSum); } __inline USHORT * OHSubsystem (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->Subsystem) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->Subsystem); } __inline USHORT * OHDllCharacteristics (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->DllCharacteristics) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->DllCharacteristics); } __inline ULONG * OHSizeOfStackReserve (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfStackReserve) : (ULONG *)&(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfStackReserve); } __inline ULONG * OHSizeOfStackCommit (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfStackCommit) : (ULONG *)&(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfStackCommit); } __inline ULONG * OHSizeOfHeapReserve (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfHeapReserve) : (ULONG *)&(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfHeapReserve); } __inline ULONG * OHSizeOfHeapCommit (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->SizeOfHeapCommit) : (ULONG *)&(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->SizeOfHeapCommit); } __inline ULONG * OHLoaderFlags (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->LoaderFlags) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->LoaderFlags); } __inline ULONG * OHNumberOfRvaAndSizes (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->NumberOfRvaAndSizes) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->NumberOfRvaAndSizes); } __inline IMAGE_DATA_DIRECTORY * OHDataDirectory (PVOID OptHeader) { return ((PIMAGE_OPTIONAL_HEADER)OptHeader)->Magic == IMAGE_NT_OPTIONAL_HDR32_MAGIC ? &(((PIMAGE_OPTIONAL_HEADER32) OptHeader)->DataDirectory[0]) : &(((PIMAGE_OPTIONAL_HEADER64) OptHeader)->DataDirectory[0]); } PVOID MapItRO( HANDLE FileHandle ); HANDLE IMAGEAPI fnFindDebugInfoFileEx( IN LPSTR FileName, IN LPSTR SymbolPath, OUT LPSTR DebugFilePath, IN PFIND_DEBUG_FILE_CALLBACK Callback, IN PVOID CallerData, IN DWORD flag ); BOOL GetFileFromSymbolServer( IN LPCSTR ServerInfo, IN LPCSTR FileName, IN GUID *id, IN DWORD two, IN DWORD three, OUT LPSTR FilePath ); void CloseSymbolServer( VOID ); void SetSymbolServerOptions( ULONG_PTR options, ULONG64 data ); void SetSymbolServerCallback( BOOL state ); #define fdifRECURSIVE 0x1 #ifdef __cplusplus } #endif #endif