/*++ Copyright(c) 1999-2002 Microsoft Corporation Module Name: mdump.h Abstract: Private header for minidump user-mode crashdump support. Author: Matthew D Hendel (math) 20-Aug-1999 --*/ #pragma once #define IsFlagSet(_var, _flag) ( ((_var) & (_flag)) != 0 ) #define IsFlagClear(_var, _flag) ( !IsFlagSet(_var, _flag) ) // // StartOfStack gives the lowest address of the stack. SizeOfStack gives // the size of the stack. Used together, they will give the memory region // used by the stack. // #define StartOfStack(_thread) ((_thread)->StackEnd) #define SizeOfStack(_thread) ((ULONG)((_thread)->StackBase - (_thread)->StackEnd))) // Types of memory regions. typedef enum { MEMBLOCK_OTHER, MEMBLOCK_MERGED, MEMBLOCK_STACK, MEMBLOCK_STORE, MEMBLOCK_DATA_SEG, MEMBLOCK_UNWIND_INFO, MEMBLOCK_INSTR_WINDOW, MEMBLOCK_PEB, MEMBLOCK_TEB, MEMBLOCK_INDIRECT, MEMBLOCK_PRIVATE_RW, MEMBLOCK_COR, MEMBLOCK_MEM_CALLBACK, } MEMBLOCK_TYPE; // // A VA_RANGE is a range of addresses that represents Size bytes beginning // at Start. // typedef struct _VA_RANGE { ULONG64 Start; ULONG Size; MEMBLOCK_TYPE Type; LIST_ENTRY NextLink; } VA_RANGE, *PVA_RANGE; // // INTERNAL_MODULE is the structure minidump uses internally to manage modules. // A linked list of INTERNAL_MODULE structures are built up when // GenGetProcessInfo is called. // typedef struct _INTERNAL_MODULE { // // File handle to the image. // HANDLE FileHandle; // // Base address, size, CheckSum, and TimeDateStamp for the image. // ULONG64 BaseOfImage; ULONG SizeOfImage; ULONG CheckSum; ULONG TimeDateStamp; // // Version information for the image. // VS_FIXEDFILEINFO VersionInfo; // // Buffer and size containing NB10 record for given module. // PVOID CvRecord; ULONG SizeOfCvRecord; // // Buffer and size of MISC debug record. We only get this with // images that have been split. // PVOID MiscRecord; ULONG SizeOfMiscRecord; // // Full path to the image. // WCHAR FullPath [ MAX_PATH + 1]; // Portion of full path to write in the module list. This // allows paths to be filtered out for privacy reasons. PWSTR SavePath; // // What sections of the module does the client want written. // ULONG WriteFlags; // // Next image pointer. // LIST_ENTRY ModulesLink; } INTERNAL_MODULE, *PINTERNAL_MODULE; // // INTERNAL_UNLOADED_MODULE is the structure minidump uses // internally to manage unloaded modules. // A linked list of INTERNAL_UNLOADED_MODULE structures are built up when // GenGetProcessInfo is called. // // typedef struct _INTERNAL_UNLOADED_MODULE { ULONG64 BaseOfImage; ULONG SizeOfImage; ULONG CheckSum; ULONG TimeDateStamp; // // As much of the path to the image as can be recovered. // WCHAR Path[MAX_PATH + 1]; // // Next image pointer. // LIST_ENTRY ModulesLink; } INTERNAL_UNLOADED_MODULE, *PINTERNAL_UNLOADED_MODULE; // // INTERNAL_THREAD is the structure the minidump uses internally to // manage threads. A list of INTERNAL_THREAD structures is built when // GenGetProcessInfo is called. // typedef struct _INTERNAL_THREAD { // // The Win32 thread id of the thread an an open handle for the // thread. // ULONG ThreadId; HANDLE ThreadHandle; // // Suspend count, priority, priority class for the thread. // ULONG SuspendCount; ULONG PriorityClass; ULONG Priority; // // Thread TEB, Context and Size of Context. // ULONG64 Teb; ULONG SizeOfTeb; PVOID ContextBuffer; // // Current program counter. // ULONG64 CurrentPc; // // Stack variables. Remember, the stack grows down, so StackBase is // the highest stack address and StackEnd is the lowest. // ULONG64 StackBase; ULONG64 StackEnd; // // Backing store variables. // ULONG64 BackingStoreBase; ULONG BackingStoreSize; // // What sections of the module we should actually write to the file. // ULONG WriteFlags; // // Link to next thread. // LIST_ENTRY ThreadsLink; } INTERNAL_THREAD, *PINTERNAL_THREAD; // // INTERNAL_FUNCTION_TABLE is the structure minidump uses // internally to manage function tables. // A linked list of INTERNAL_FUNCTION_TABLE structures is built up when // GenGetProcessInfo is called. // typedef struct _INTERNAL_FUNCTION_TABLE { ULONG64 MinimumAddress; ULONG64 MaximumAddress; ULONG64 BaseAddress; ULONG EntryCount; PVOID RawTable; PVOID RawEntries; LIST_ENTRY TableLink; } INTERNAL_FUNCTION_TABLE, *PINTERNAL_FUNCTION_TABLE; typedef struct _INTERNAL_PROCESS { // // The process id for the process. // ULONG ProcessId; // // Process data. // ULONG64 Peb; ULONG SizeOfPeb; // // Process run time information. // BOOL TimesValid; ULONG CreateTime; ULONG UserTime; ULONG KernelTime; // // An open handle to the process with read permissions. // HANDLE ProcessHandle; // // Number of threads for the process. // ULONG NumberOfThreads; ULONG NumberOfThreadsToWrite; ULONG MaxStackOrStoreSize; // // Number of modules for the process. // ULONG NumberOfModules; ULONG NumberOfModulesToWrite; // // Number of unloaded modules for the process. // ULONG NumberOfUnloadedModules; // // Number of function tables for the process. // ULONG NumberOfFunctionTables; // // Thread, module and function table lists for the process. // LIST_ENTRY ThreadList; LIST_ENTRY ModuleList; LIST_ENTRY UnloadedModuleList; LIST_ENTRY FunctionTableList; // // List of memory blocks to include for the process. // LIST_ENTRY MemoryBlocks; ULONG NumberOfMemoryBlocks; ULONG SizeOfMemoryBlocks; // // Indicates whether mscorwks, mscorsvr or mscoree is // present in the process. These DLLs are used as an indicator // of whether the runtime is running in the process or not. // PWSTR CorDllType; ULONG64 CorDllBase; VS_FIXEDFILEINFO CorDllVer; WCHAR CorDllPath[MAX_PATH + 1]; } INTERNAL_PROCESS, *PINTERNAL_PROCESS; // // The visible streams are: (1) machine info, (2) exception, (3) thread list, // (4) module list (5) memory list (6) misc info. // We also add two extra for post-processing tools that want to add data later. // #define NUMBER_OF_STREAMS (8) // // MINIDUMP_STREAM_INFO is the structure used by the minidump to manage // it's internal data streams. // typedef struct _MINIDUMP_STREAM_INFO { // // How many streams we have. // ULONG NumberOfStreams; // // Reserved space for header. // ULONG RvaOfHeader; ULONG SizeOfHeader; // // Reserved space for directory. // ULONG RvaOfDirectory; ULONG SizeOfDirectory; // // Reserved space for system info. // ULONG RvaOfSystemInfo; ULONG SizeOfSystemInfo; ULONG VersionStringLength; // // Reserved space for misc info. // ULONG RvaOfMiscInfo; // // Reserved space for exception list. // ULONG RvaOfException; ULONG SizeOfException; // // Reserved space for thread list. // ULONG RvaOfThreadList; ULONG SizeOfThreadList; ULONG RvaForCurThread; ULONG ThreadStructSize; // // Reserved space for module list. // ULONG RvaOfModuleList; ULONG SizeOfModuleList; ULONG RvaForCurModule; // // Reserved space for unloaded module list. // ULONG RvaOfUnloadedModuleList; ULONG SizeOfUnloadedModuleList; ULONG RvaForCurUnloadedModule; // // Reserved space for function table list. // ULONG RvaOfFunctionTableList; ULONG SizeOfFunctionTableList; // // Reserved space for memory descriptors. // ULONG RvaOfMemoryDescriptors; ULONG SizeOfMemoryDescriptors; ULONG RvaForCurMemoryDescriptor; // // Reserved space for actual memory data. // ULONG RvaOfMemoryData; ULONG SizeOfMemoryData; ULONG RvaForCurMemoryData; // // Reserved space for strings. // ULONG RvaOfStringPool; ULONG SizeOfStringPool; ULONG RvaForCurString; // // Reserved space for other data like contexts, debug info records, // etc. // ULONG RvaOfOther; ULONG SizeOfOther; ULONG RvaForCurOther; // // Reserved space for user streams. // ULONG RvaOfUserStreams; ULONG SizeOfUserStreams; // // Reserved space for handle data. // ULONG RvaOfHandleData; ULONG SizeOfHandleData; } MINIDUMP_STREAM_INFO, *PMINIDUMP_STREAM_INFO; typedef struct _EXCEPTION_INFO { DWORD ThreadId; MINIDUMP_EXCEPTION ExceptionRecord; PVOID ContextRecord; } EXCEPTION_INFO, *PEXCEPTION_INFO; // // Status flags for accumulated status. // // Ran out of memory during dump writing. #define MDSTATUS_OUT_OF_MEMORY 0x00000001 // Process memory read failed during dump writing. #define MDSTATUS_UNABLE_TO_READ_MEMORY 0x00000002 // OS routine failed during dump writing. #define MDSTATUS_CALL_FAILED 0x00000004 // Unexpected internal failure during dump writing. #define MDSTATUS_INTERNAL_ERROR 0x00000008 // // Global state carried through a entire dump write operation. // typedef struct _MINIDUMP_STATE { // // Input values. // HANDLE ProcessHandle; DWORD ProcessId; MiniDumpSystemProvider* SysProv; MiniDumpOutputProvider* OutProv; MiniDumpAllocationProvider* AllocProv; ULONG DumpType; MINIDUMP_CALLBACK_ROUTINE CallbackRoutine; PVOID CallbackParam; // // Global state. // ULONG CpuType; PCWSTR CpuTypeName; BOOL BackingStore; ULONG OsPlatformId; ULONG OsMajor; ULONG OsMinor; ULONG OsServicePack; ULONG OsBuildNumber; USHORT OsProductType; USHORT OsSuiteMask; ULONG ContextSize; ULONG RegScanOffset; ULONG RegScanCount; ULONG ExRecordSize; ULONG PtrSize; ULONG PageSize; ULONG FuncTableSize; ULONG FuncTableEntrySize; ULONG InstructionWindowSize; ULONG AccumStatus; } MINIDUMP_STATE, *PMINIDUMP_STATE;