Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1174 lines
38 KiB

  1. //----------------------------------------------------------------------------
  2. //
  3. // Dump file support.
  4. //
  5. // Copyright (C) Microsoft Corporation, 1999-2002.
  6. //
  7. //----------------------------------------------------------------------------
  8. #ifndef __DUMP_HPP__
  9. #define __DUMP_HPP__
  10. #define HR_DATA_CORRUPT HRESULT_FROM_WIN32(ERROR_FILE_CORRUPT)
  11. #define MI_UNLOADED_DRIVERS 50
  12. #define IS_DUMP_TARGET(Target) \
  13. ((Target) && (Target)->m_Class != DEBUG_CLASS_UNINITIALIZED && \
  14. (Target)->m_ClassQualifier >= DEBUG_DUMP_SMALL && \
  15. (Target)->m_ClassQualifier <= DEBUG_DUMP_FULL)
  16. #define IS_USER_DUMP(Target) \
  17. (IS_USER_TARGET(Target) && IS_DUMP_TARGET(Target))
  18. #define IS_KERNEL_DUMP(Target) \
  19. (IS_KERNEL_TARGET(Target) && IS_DUMP_TARGET(Target))
  20. #define IS_KERNEL_SUMMARY_DUMP(Target) \
  21. (IS_KERNEL_TARGET(Target) && \
  22. (Target)->m_ClassQualifier == DEBUG_KERNEL_DUMP)
  23. #define IS_KERNEL_TRIAGE_DUMP(Target) \
  24. (IS_KERNEL_TARGET(Target) && \
  25. (Target)->m_ClassQualifier == DEBUG_KERNEL_SMALL_DUMP)
  26. #define IS_KERNEL_FULL_DUMP(Target) \
  27. (IS_KERNEL_TARGET(Target) && \
  28. (Target)->m_ClassQualifier == DEBUG_KERNEL_FULL_DUMP)
  29. #define IS_USER_FULL_DUMP(Target) \
  30. (IS_USER_TARGET(Target) && \
  31. (Target)->m_ClassQualifier == DEBUG_USER_WINDOWS_DUMP)
  32. #define IS_USER_MINI_DUMP(Target) \
  33. (IS_USER_TARGET(Target) && \
  34. (Target)->m_ClassQualifier == DEBUG_USER_WINDOWS_SMALL_DUMP)
  35. #define IS_DUMP_WITH_MAPPED_IMAGES(Target) \
  36. (IS_DUMP_TARGET(Target) && ((DumpTargetInfo*)(Target))->m_MappedImages)
  37. enum DTYPE
  38. {
  39. DTYPE_KERNEL_SUMMARY32,
  40. DTYPE_KERNEL_SUMMARY64,
  41. DTYPE_KERNEL_TRIAGE32,
  42. DTYPE_KERNEL_TRIAGE64,
  43. // Kernel full dumps must come after summary and triage
  44. // dumps so that the more specific dumps are identified first.
  45. DTYPE_KERNEL_FULL32,
  46. DTYPE_KERNEL_FULL64,
  47. DTYPE_USER_FULL32,
  48. DTYPE_USER_FULL64,
  49. DTYPE_USER_MINI_PARTIAL,
  50. DTYPE_USER_MINI_FULL,
  51. DTYPE_COUNT
  52. };
  53. enum
  54. {
  55. // Actual dump file.
  56. DUMP_INFO_DUMP,
  57. // Paging file information.
  58. DUMP_INFO_PAGE_FILE,
  59. DUMP_INFO_COUNT
  60. };
  61. // Converts DUMP_INFO value to DEBUG_DUMP_FILE value.
  62. extern ULONG g_DumpApiTypes[];
  63. HRESULT AddDumpInfoFile(PCWSTR FileName, ULONG64 FileHandle,
  64. ULONG Index, ULONG InitialView);
  65. class DumpTargetInfo* NewDumpTargetInfo(ULONG DumpType);
  66. HRESULT IdentifyDump(PCWSTR FileName, ULONG64 FileHandle,
  67. DumpTargetInfo** TargetRet);
  68. void DotDump(PDOT_COMMAND Cmd, DebugClient* Client);
  69. HRESULT WriteDumpFile(PCWSTR FileName, ULONG64 FileHandle,
  70. ULONG Qualifier, ULONG FormatFlags,
  71. PCSTR CommentA, PCWSTR CommentW);
  72. HRESULT CreateCabFromDump(PCSTR DumpFile, PCSTR CabFile, ULONG Flags);
  73. //----------------------------------------------------------------------------
  74. //
  75. // ViewMappedFile.
  76. //
  77. // ViewMappedFile layers on top of Win32 file mappings to provide
  78. // the illusion that the entire file is mapped into memory.
  79. // Internally ViewMappedFile caches and shifts Win32 views to
  80. // access the actual data.
  81. //
  82. //----------------------------------------------------------------------------
  83. class ViewMappedFile
  84. {
  85. public:
  86. ViewMappedFile(void);
  87. ~ViewMappedFile(void);
  88. void ResetCache(void);
  89. void ResetFile(void);
  90. void EmptyCache(void);
  91. ULONG ReadFileOffset(ULONG64 Offset, PVOID Buffer, ULONG BufferSize);
  92. ULONG WriteFileOffset(ULONG64 Offset, PVOID Buffer, ULONG BufferSize);
  93. HRESULT Open(PCWSTR FileName, ULONG64 FileHandle, ULONG InitialView);
  94. void Close(void);
  95. HRESULT RemapInitial(ULONG MapSize);
  96. void Transfer(ViewMappedFile* To);
  97. PWSTR m_FileNameW;
  98. PSTR m_FileNameA;
  99. HANDLE m_File;
  100. ULONG64 m_FileSize;
  101. HANDLE m_Map;
  102. PVOID m_MapBase;
  103. ULONG m_MapSize;
  104. private:
  105. struct CacheRecord
  106. {
  107. LIST_ENTRY InFileOrderList;
  108. LIST_ENTRY InLRUOrderList;
  109. //
  110. // Base address of mapped region.
  111. //
  112. PVOID MappedAddress;
  113. //
  114. // File page number of mapped region. pages are of
  115. // size == FileCacheData.Granularity.
  116. //
  117. // The virtual address of a page is not stored; it is
  118. // translated into a page number by the read routines
  119. // and all access is by page number.
  120. //
  121. ULONG64 PageNumber;
  122. //
  123. // A page may be locked into the cache, either because it is used
  124. // frequently or because it has been modified.
  125. //
  126. BOOL Locked;
  127. };
  128. CacheRecord* ReuseOldestCacheRecord(ULONG64 FileByteOffset);
  129. CacheRecord* FindCacheRecordForFileByteOffset
  130. (ULONG64 FileByteOffset);
  131. CacheRecord* CreateNewFileCacheRecord(ULONG64 FileByteOffset);
  132. PUCHAR FileOffsetToMappedAddress(ULONG64 FileOffset,
  133. BOOL LockCacheRecord,
  134. PULONG Avail);
  135. //
  136. // If a page is dirty, it will stay in the cache indefinitely.
  137. // A maximum of MAX_CLEAN_PAGE_RECORD clean pages are kept in
  138. // the LRU list.
  139. //
  140. ULONG m_ActiveCleanPages;
  141. //
  142. // This is a list of all mapped pages, dirty and clean.
  143. // This list is not intended to get very big: the page finder
  144. // searches it, so it is not a good data structure for a large
  145. // list. It is expected that MAX_CLEAN_PAGE_RECORD will be a
  146. // small number, and that there aren't going to be very many
  147. // pages dirtied in a typical debugging session, so this will
  148. // work well.
  149. //
  150. LIST_ENTRY m_InFileOrderList;
  151. //
  152. // This is a list of all clean pages. When the list is full
  153. // and a new page is mapped, the oldest page will be discarded.
  154. //
  155. LIST_ENTRY m_InLRUOrderList;
  156. // Granularity of cache view sizes.
  157. ULONG m_CacheGranularity;
  158. };
  159. //----------------------------------------------------------------------------
  160. //
  161. // DumpTargetInfo hierarchy.
  162. //
  163. // Each kind of dump has its own target for methods that are
  164. // specific to the kind of dump.
  165. //
  166. //----------------------------------------------------------------------------
  167. class DumpTargetInfo : public TargetInfo
  168. {
  169. public:
  170. DumpTargetInfo(ULONG Class, ULONG Qual, BOOL MappedImages);
  171. virtual ~DumpTargetInfo(void);
  172. // TargetInfo.
  173. virtual HRESULT ReadVirtual(
  174. IN ProcessInfo* Process,
  175. IN ULONG64 Offset,
  176. IN PVOID Buffer,
  177. IN ULONG BufferSize,
  178. OUT OPTIONAL PULONG BytesRead
  179. );
  180. virtual HRESULT WriteVirtual(
  181. IN ProcessInfo* Process,
  182. IN ULONG64 Offset,
  183. IN PVOID Buffer,
  184. IN ULONG BufferSize,
  185. OUT OPTIONAL PULONG BytesWritten
  186. );
  187. virtual HRESULT SwitchProcessors(ULONG Processor);
  188. virtual HRESULT WaitInitialize(ULONG Flags,
  189. ULONG Timeout,
  190. WAIT_INIT_TYPE First,
  191. PULONG DesiredTimeout);
  192. virtual HRESULT WaitForEvent(ULONG Flags, ULONG Timeout,
  193. ULONG ElapsedTime, PULONG EventStatus);
  194. //
  195. // DumpTargetInfo.
  196. //
  197. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize) = 0;
  198. virtual void DumpDebug(void) = 0;
  199. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  200. PULONG File, PULONG Avail) = 0;
  201. // Base implementation returns E_NOTIMPL.
  202. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  203. PCSTR CommentA, PCWSTR CommentW);
  204. virtual HRESULT FirstEvent(void) = 0;
  205. PVOID IndexByByte(PVOID Pointer, ULONG64 Index)
  206. {
  207. return (PVOID)((PUCHAR)Pointer + Index);
  208. }
  209. // Validates that the RVA and size fall within the current
  210. // mapped size. Primarily useful for minidumps.
  211. PVOID IndexRva(PVOID Base, RVA Rva, ULONG Size, PCSTR Title);
  212. HRESULT InitSystemInfo(ULONG BuildNumber, ULONG CheckedBuild,
  213. ULONG MachineType, ULONG PlatformId,
  214. ULONG MajorVersion, ULONG MinorVersion);
  215. HRESULT MapReadVirtual(ProcessInfo* Process,
  216. ULONG64 Offset,
  217. PVOID Buffer,
  218. ULONG BufferSize,
  219. PULONG BytesRead);
  220. void MapNearestDifferentlyValidOffsets(ULONG64 Offset,
  221. PULONG64 NextOffset,
  222. PULONG64 NextPage);
  223. ViewMappedFile m_InfoFiles[DUMP_INFO_COUNT];
  224. PVOID m_DumpBase;
  225. ULONG m_FormatFlags;
  226. BOOL m_MappedImages;
  227. // Image memory map can only be used if m_MappedImages is TRUE.
  228. MappedMemoryMap m_ImageMemMap;
  229. MappedMemoryMap m_DataMemMap;
  230. EXCEPTION_RECORD64 m_ExceptionRecord;
  231. ULONG m_ExceptionFirstChance;
  232. ULONG m_WriterStatus;
  233. };
  234. class KernelDumpTargetInfo : public DumpTargetInfo
  235. {
  236. public:
  237. KernelDumpTargetInfo(ULONG Qual, BOOL MappedImages)
  238. : DumpTargetInfo(DEBUG_CLASS_KERNEL, Qual, MappedImages)
  239. {
  240. m_HeaderContext = NULL;
  241. ZeroMemory(m_KiProcessors, sizeof(m_KiProcessors));
  242. m_TaggedOffset = 0;
  243. }
  244. // TargetInfo.
  245. virtual HRESULT ReadControl(
  246. IN ULONG Processor,
  247. IN ULONG64 Offset,
  248. OUT PVOID Buffer,
  249. IN ULONG BufferSize,
  250. OUT OPTIONAL PULONG BytesRead
  251. );
  252. virtual HRESULT GetProcessorId(
  253. ULONG Processor,
  254. PDEBUG_PROCESSOR_IDENTIFICATION_ALL Id
  255. );
  256. virtual HRESULT GetProcessorSpeed(
  257. ULONG Processor,
  258. PULONG Speed
  259. );
  260. virtual HRESULT GetTaggedBaseOffset(PULONG64 Offset);
  261. virtual HRESULT ReadTagged(ULONG64 Offset, PVOID Buffer, ULONG BufferSize);
  262. virtual HRESULT GetThreadIdByProcessor(
  263. IN ULONG Processor,
  264. OUT PULONG Id
  265. );
  266. virtual HRESULT GetThreadInfoDataOffset(ThreadInfo* Thread,
  267. ULONG64 ThreadHandle,
  268. PULONG64 Offset);
  269. virtual HRESULT GetProcessInfoDataOffset(ThreadInfo* Thread,
  270. ULONG Processor,
  271. ULONG64 ThreadData,
  272. PULONG64 Offset);
  273. virtual HRESULT GetThreadInfoTeb(ThreadInfo* Thread,
  274. ULONG Processor,
  275. ULONG64 ThreadData,
  276. PULONG64 Offset);
  277. virtual HRESULT GetProcessInfoPeb(ThreadInfo* Thread,
  278. ULONG Processor,
  279. ULONG64 ThreadData,
  280. PULONG64 Offset);
  281. virtual ULONG64 GetCurrentTimeDateN(void);
  282. virtual ULONG64 GetCurrentSystemUpTimeN(void);
  283. virtual HRESULT GetProductInfo(PULONG ProductType, PULONG SuiteMask);
  284. // DumpTargetInfo.
  285. virtual HRESULT FirstEvent(void);
  286. // KernelDumpTargetInfo.
  287. virtual ULONG GetCurrentProcessor(void) = 0;
  288. HRESULT InitGlobals32(PMEMORY_DUMP32 Dump);
  289. HRESULT InitGlobals64(PMEMORY_DUMP64 Dump);
  290. void DumpHeader32(PDUMP_HEADER32 Header);
  291. void DumpHeader64(PDUMP_HEADER64 Header);
  292. void InitDumpHeader32(PDUMP_HEADER32 Header,
  293. PCSTR CommentA, PCWSTR CommentW,
  294. ULONG BugCheckCodeModifier);
  295. void InitDumpHeader64(PDUMP_HEADER64 Header,
  296. PCSTR CommentA, PCWSTR CommentW,
  297. ULONG BugCheckCodeModifier);
  298. HRESULT ReadControlSpaceIa64(ULONG Processor,
  299. ULONG64 Offset,
  300. PVOID Buffer,
  301. ULONG BufferSize,
  302. PULONG BytesRead);
  303. HRESULT ReadControlSpaceAmd64(ULONG Processor,
  304. ULONG64 Offset,
  305. PVOID Buffer,
  306. ULONG BufferSize,
  307. PULONG BytesRead);
  308. PUCHAR m_HeaderContext;
  309. ULONG64 m_KiProcessors[MAXIMUM_PROCS];
  310. ULONG64 m_TaggedOffset;
  311. };
  312. class KernelFullSumDumpTargetInfo : public KernelDumpTargetInfo
  313. {
  314. public:
  315. KernelFullSumDumpTargetInfo(ULONG Qual)
  316. : KernelDumpTargetInfo(Qual, FALSE)
  317. {
  318. }
  319. // TargetInfo.
  320. virtual HRESULT ReadPhysical(
  321. IN ULONG64 Offset,
  322. OUT PVOID Buffer,
  323. IN ULONG BufferSize,
  324. IN ULONG Flags,
  325. OUT OPTIONAL PULONG BytesRead
  326. );
  327. virtual HRESULT WritePhysical(
  328. IN ULONG64 Offset,
  329. IN PVOID Buffer,
  330. IN ULONG BufferSize,
  331. IN ULONG Flags,
  332. OUT OPTIONAL PULONG BytesWritten
  333. );
  334. virtual HRESULT ReadPageFile(ULONG PfIndex, ULONG64 PfOffset,
  335. PVOID Buffer, ULONG Size);
  336. virtual HRESULT GetTargetContext(
  337. ULONG64 Thread,
  338. PVOID Context
  339. );
  340. virtual HRESULT GetSelDescriptor(ThreadInfo* Thread,
  341. MachineInfo* Machine,
  342. ULONG Selector,
  343. PDESCRIPTOR64 Desc);
  344. // DumpTargetInfo.
  345. virtual void DumpDebug(void);
  346. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  347. PULONG File, PULONG Avail);
  348. // KernelDumpTargetInfo.
  349. virtual ULONG GetCurrentProcessor(void);
  350. // KernelFullSumDumpTargetInfo.
  351. virtual ULONG64 PhysicalToOffset(ULONG64 Phys, BOOL Verbose,
  352. PULONG Avail) = 0;
  353. HRESULT PageFileOffset(ULONG PfIndex, ULONG64 PfOffset,
  354. PULONG64 FileOffset);
  355. };
  356. class KernelSummaryDumpTargetInfo : public KernelFullSumDumpTargetInfo
  357. {
  358. public:
  359. KernelSummaryDumpTargetInfo(void)
  360. : KernelFullSumDumpTargetInfo(DEBUG_KERNEL_DUMP)
  361. {
  362. m_LocationCache = NULL;
  363. m_PageBitmapSize = 0;
  364. }
  365. // KernelSummaryDumpTargetInfo.
  366. PULONG m_LocationCache;
  367. ULONG m_PageBitmapSize;
  368. RTL_BITMAP m_PageBitmap;
  369. void ConstructLocationCache(ULONG BitmapSize,
  370. ULONG SizeOfBitMap,
  371. IN PULONG Buffer);
  372. ULONG64 SumPhysicalToOffset(ULONG HeaderSize, ULONG64 Phys,
  373. BOOL Verbose, PULONG Avail);
  374. };
  375. class KernelSummary32DumpTargetInfo : public KernelSummaryDumpTargetInfo
  376. {
  377. public:
  378. // TargetInfo.
  379. virtual HRESULT Initialize(void);
  380. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  381. PULONG DescLen);
  382. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  383. // DumpTargetInfo.
  384. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  385. virtual void DumpDebug(void);
  386. // KernelFullSumDumpTargetInfo.
  387. virtual ULONG64 PhysicalToOffset(ULONG64 Phys, BOOL Verbose,
  388. PULONG Avail);
  389. // KernelSummary32DumpTargetInfo.
  390. PMEMORY_DUMP32 m_Dump;
  391. };
  392. class KernelSummary64DumpTargetInfo : public KernelSummaryDumpTargetInfo
  393. {
  394. public:
  395. // TargetInfo.
  396. virtual HRESULT Initialize(void);
  397. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  398. PULONG DescLen);
  399. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  400. // DumpTargetInfo.
  401. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  402. virtual void DumpDebug(void);
  403. // KernelFullSumDumpTargetInfo.
  404. virtual ULONG64 PhysicalToOffset(ULONG64 Phys, BOOL Verbose,
  405. PULONG Avail);
  406. // KernelSummary64DumpTargetInfo.
  407. PMEMORY_DUMP64 m_Dump;
  408. };
  409. class KernelTriageDumpTargetInfo : public KernelDumpTargetInfo
  410. {
  411. public:
  412. KernelTriageDumpTargetInfo(void)
  413. : KernelDumpTargetInfo(DEBUG_KERNEL_SMALL_DUMP, TRUE)
  414. {
  415. m_PrcbOffset = 0;
  416. m_HasDebuggerData = FALSE;
  417. }
  418. // TargetInfo.
  419. virtual void NearestDifferentlyValidOffsets(ULONG64 Offset,
  420. PULONG64 NextOffset,
  421. PULONG64 NextPage);
  422. virtual HRESULT ReadVirtual(
  423. IN ProcessInfo* Process,
  424. IN ULONG64 Offset,
  425. OUT PVOID Buffer,
  426. IN ULONG BufferSize,
  427. OUT OPTIONAL PULONG BytesRead
  428. );
  429. virtual HRESULT GetProcessorSystemDataOffset(
  430. IN ULONG Processor,
  431. IN ULONG Index,
  432. OUT PULONG64 Offset
  433. );
  434. virtual HRESULT GetTargetContext(
  435. ULONG64 Thread,
  436. PVOID Context
  437. );
  438. virtual HRESULT GetSelDescriptor(ThreadInfo* Thread,
  439. MachineInfo* Machine,
  440. ULONG Selector,
  441. PDESCRIPTOR64 Desc);
  442. virtual HRESULT SwitchProcessors(ULONG Processor);
  443. // DumpTargetInfo.
  444. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  445. PULONG File, PULONG Avail);
  446. // KernelDumpTargetInfo.
  447. virtual ULONG GetCurrentProcessor(void);
  448. // KernelTriageDumpTargetInfo.
  449. HRESULT MapMemoryRegions(ULONG PrcbOffset,
  450. ULONG ThreadOffset,
  451. ULONG ProcessOffset,
  452. ULONG64 TopOfStack,
  453. ULONG SizeOfCallStack,
  454. ULONG CallStackOffset,
  455. ULONG64 BStoreLimit,
  456. ULONG SizeOfBStore,
  457. ULONG BStoreOffset,
  458. ULONG64 DataPageAddress,
  459. ULONG DataPageOffset,
  460. ULONG DataPageSize,
  461. ULONG64 DebuggerDataAddress,
  462. ULONG DebuggerDataOffset,
  463. ULONG DebuggerDataSize,
  464. ULONG MmDataOffset,
  465. ULONG DataBlocksOffset,
  466. ULONG DataBlocksCount);
  467. void DumpDataBlocks(ULONG Offset, ULONG Count);
  468. ULONG m_PrcbOffset;
  469. BOOL m_HasDebuggerData;
  470. };
  471. class KernelTriage32DumpTargetInfo : public KernelTriageDumpTargetInfo
  472. {
  473. public:
  474. // TargetInfo.
  475. virtual HRESULT Initialize(void);
  476. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  477. PULONG DescLen);
  478. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  479. virtual ModuleInfo* GetModuleInfo(BOOL UserMode);
  480. virtual UnloadedModuleInfo* GetUnloadedModuleInfo(void);
  481. // DumpTargetInfo.
  482. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  483. virtual void DumpDebug(void);
  484. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  485. PCSTR CommentA, PCWSTR CommentW);
  486. // KernelTriage32DumpTargetInfo.
  487. PMEMORY_DUMP32 m_Dump;
  488. };
  489. class KernelTriage64DumpTargetInfo : public KernelTriageDumpTargetInfo
  490. {
  491. public:
  492. // TargetInfo.
  493. virtual HRESULT Initialize(void);
  494. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  495. PULONG DescLen);
  496. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  497. virtual ModuleInfo* GetModuleInfo(BOOL UserMode);
  498. virtual UnloadedModuleInfo* GetUnloadedModuleInfo(void);
  499. // DumpTargetInfo.
  500. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  501. virtual void DumpDebug(void);
  502. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  503. PCSTR CommentA, PCWSTR CommentW);
  504. // KernelTriage64DumpTargetInfo.
  505. PMEMORY_DUMP64 m_Dump;
  506. };
  507. class KernelFull32DumpTargetInfo : public KernelFullSumDumpTargetInfo
  508. {
  509. public:
  510. KernelFull32DumpTargetInfo(void)
  511. : KernelFullSumDumpTargetInfo(DEBUG_KERNEL_FULL_DUMP) {}
  512. // TargetInfo.
  513. virtual HRESULT Initialize(void);
  514. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  515. PULONG DescLen);
  516. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  517. // DumpTargetInfo.
  518. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  519. virtual void DumpDebug(void);
  520. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  521. PCSTR CommentA, PCWSTR CommentW);
  522. // KernelFullSumDumpTargetInfo.
  523. virtual ULONG64 PhysicalToOffset(ULONG64 Phys, BOOL Verbose,
  524. PULONG Avail);
  525. // KernelFull32DumpTargetInfo.
  526. PMEMORY_DUMP32 m_Dump;
  527. };
  528. class KernelFull64DumpTargetInfo : public KernelFullSumDumpTargetInfo
  529. {
  530. public:
  531. KernelFull64DumpTargetInfo(void)
  532. : KernelFullSumDumpTargetInfo(DEBUG_KERNEL_FULL_DUMP) {}
  533. // TargetInfo.
  534. virtual HRESULT Initialize(void);
  535. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  536. PULONG DescLen);
  537. virtual HRESULT ReadBugCheckData(PULONG Code, ULONG64 Args[4]);
  538. // DumpTargetInfo.
  539. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  540. virtual void DumpDebug(void);
  541. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  542. PCSTR CommentA, PCWSTR CommentW);
  543. // KernelFullSumDumpTargetInfo.
  544. virtual ULONG64 PhysicalToOffset(ULONG64 Phys, BOOL Verbose,
  545. PULONG Avail);
  546. // KernelFull64DumpTargetInfo.
  547. PMEMORY_DUMP64 m_Dump;
  548. };
  549. class UserDumpTargetInfo : public DumpTargetInfo
  550. {
  551. public:
  552. UserDumpTargetInfo(ULONG Qual, BOOL MappedImages)
  553. : DumpTargetInfo(DEBUG_CLASS_USER_WINDOWS, Qual, MappedImages)
  554. {
  555. m_HighestMemoryRegion32 = 0;
  556. m_EventProcessId = 0;
  557. m_EventProcessSymHandle = NULL;
  558. m_EventThreadId = 0;
  559. m_ThreadCount = 0;
  560. }
  561. // TargetInfo.
  562. virtual HRESULT GetThreadInfoDataOffset(ThreadInfo* Thread,
  563. ULONG64 ThreadHandle,
  564. PULONG64 Offset);
  565. virtual HRESULT GetProcessInfoDataOffset(ThreadInfo* Thread,
  566. ULONG Processor,
  567. ULONG64 ThreadData,
  568. PULONG64 Offset);
  569. virtual HRESULT GetThreadInfoTeb(ThreadInfo* Thread,
  570. ULONG Processor,
  571. ULONG64 ThreadData,
  572. PULONG64 Offset);
  573. virtual HRESULT GetProcessInfoPeb(ThreadInfo* Thread,
  574. ULONG Processor,
  575. ULONG64 ThreadData,
  576. PULONG64 Offset);
  577. virtual HRESULT GetSelDescriptor(ThreadInfo* Thread,
  578. MachineInfo* Machine,
  579. ULONG Selector,
  580. PDESCRIPTOR64 Desc);
  581. // DumpTargetInfo.
  582. virtual HRESULT FirstEvent(void);
  583. // UserDumpTargetInfo.
  584. ULONG m_HighestMemoryRegion32;
  585. ULONG m_EventProcessId;
  586. HANDLE m_EventProcessSymHandle;
  587. ULONG m_EventThreadId;
  588. ULONG m_ThreadCount;
  589. virtual HRESULT GetThreadInfo(ULONG Index,
  590. PULONG Id, PULONG Suspend, PULONG64 Teb) = 0;
  591. };
  592. class UserFullDumpTargetInfo : public UserDumpTargetInfo
  593. {
  594. public:
  595. UserFullDumpTargetInfo(void)
  596. : UserDumpTargetInfo(DEBUG_USER_WINDOWS_DUMP, FALSE) {}
  597. // DumpTargetInfo.
  598. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  599. PCSTR CommentA, PCWSTR CommentW);
  600. // UserFullDumpTargetInfo.
  601. HRESULT GetBuildAndPlatform(ULONG MachineType,
  602. PULONG MajorVersion, PULONG MinorVersion,
  603. PULONG BuildNumber, PULONG PlatformId);
  604. };
  605. class UserFull32DumpTargetInfo : public UserFullDumpTargetInfo
  606. {
  607. public:
  608. UserFull32DumpTargetInfo(void)
  609. : UserFullDumpTargetInfo()
  610. {
  611. m_Header = NULL;
  612. m_Memory = NULL;
  613. m_IgnoreGuardPages = FALSE;
  614. }
  615. // TargetInfo.
  616. virtual HRESULT Initialize(void);
  617. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  618. PULONG DescLen);
  619. virtual HRESULT GetTargetContext(
  620. ULONG64 Thread,
  621. PVOID Context
  622. );
  623. virtual ModuleInfo* GetModuleInfo(BOOL UserMode);
  624. virtual HRESULT QueryMemoryRegion(ProcessInfo* Process,
  625. PULONG64 Handle,
  626. BOOL HandleIsOffset,
  627. PMEMORY_BASIC_INFORMATION64 Info);
  628. // DumpTargetInfo.
  629. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  630. virtual void DumpDebug(void);
  631. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  632. PULONG File, PULONG Avail);
  633. // UserDumpTargetInfo.
  634. virtual HRESULT GetThreadInfo(ULONG Index,
  635. PULONG Id, PULONG Suspend, PULONG64 Teb);
  636. // UserFull32DumpTargetInfo.
  637. PUSERMODE_CRASHDUMP_HEADER32 m_Header;
  638. PMEMORY_BASIC_INFORMATION32 m_Memory;
  639. BOOL m_IgnoreGuardPages;
  640. BOOL VerifyModules(void);
  641. };
  642. class UserFull64DumpTargetInfo : public UserFullDumpTargetInfo
  643. {
  644. public:
  645. UserFull64DumpTargetInfo(void)
  646. : UserFullDumpTargetInfo()
  647. {
  648. m_Header = NULL;
  649. m_Memory = NULL;
  650. }
  651. // TargetInfo.
  652. virtual HRESULT Initialize(void);
  653. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  654. PULONG DescLen);
  655. virtual HRESULT GetTargetContext(
  656. ULONG64 Thread,
  657. PVOID Context
  658. );
  659. virtual ModuleInfo* GetModuleInfo(BOOL UserMode);
  660. virtual HRESULT QueryMemoryRegion(ProcessInfo* Process,
  661. PULONG64 Handle,
  662. BOOL HandleIsOffset,
  663. PMEMORY_BASIC_INFORMATION64 Info);
  664. // DumpTargetInfo.
  665. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  666. virtual void DumpDebug(void);
  667. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  668. PULONG File, PULONG Avail);
  669. // UserDumpTargetInfo.
  670. virtual HRESULT GetThreadInfo(ULONG Index,
  671. PULONG Id, PULONG Suspend, PULONG64 Teb);
  672. // UserFull64DumpTargetInfo.
  673. PUSERMODE_CRASHDUMP_HEADER64 m_Header;
  674. PMEMORY_BASIC_INFORMATION64 m_Memory;
  675. };
  676. class UserMiniDumpTargetInfo : public UserDumpTargetInfo
  677. {
  678. public:
  679. UserMiniDumpTargetInfo(BOOL MappedImages)
  680. : UserDumpTargetInfo(DEBUG_USER_WINDOWS_SMALL_DUMP, MappedImages)
  681. {
  682. m_Header = NULL;
  683. m_SysInfo = NULL;
  684. ZeroMemory(&m_MiscInfo, sizeof(m_MiscInfo));
  685. m_ActualThreadCount = 0;
  686. m_ThreadStructSize = 0;
  687. m_Threads = NULL;
  688. m_Memory = NULL;
  689. m_Memory64 = NULL;
  690. m_Memory64DataBase = 0;
  691. m_Modules = NULL;
  692. m_UnlModules = NULL;
  693. m_Exception = NULL;
  694. m_Handles = NULL;
  695. m_FunctionTables = NULL;
  696. m_ImageType = 0;
  697. }
  698. // TargetInfo.
  699. virtual HRESULT Initialize(void);
  700. virtual void NearestDifferentlyValidOffsets(ULONG64 Offset,
  701. PULONG64 NextOffset,
  702. PULONG64 NextPage);
  703. virtual HRESULT ReadHandleData(
  704. IN ProcessInfo* Process,
  705. IN ULONG64 Handle,
  706. IN ULONG DataType,
  707. OUT OPTIONAL PVOID Buffer,
  708. IN ULONG BufferSize,
  709. OUT OPTIONAL PULONG DataSize
  710. );
  711. virtual HRESULT GetProcessorId(
  712. ULONG Processor,
  713. PDEBUG_PROCESSOR_IDENTIFICATION_ALL Id
  714. );
  715. virtual HRESULT GetProcessorSpeed(
  716. ULONG Processor,
  717. PULONG Speed
  718. );
  719. virtual HRESULT GetGenericProcessorFeatures(
  720. ULONG Processor,
  721. PULONG64 Features,
  722. ULONG FeaturesSize,
  723. PULONG Used
  724. );
  725. virtual HRESULT GetSpecificProcessorFeatures(
  726. ULONG Processor,
  727. PULONG64 Features,
  728. ULONG FeaturesSize,
  729. PULONG Used
  730. );
  731. virtual PVOID FindDynamicFunctionEntry(ProcessInfo* Process,
  732. ULONG64 Address);
  733. virtual ULONG64 GetDynamicFunctionTableBase(ProcessInfo* Process,
  734. ULONG64 Address);
  735. virtual HRESULT EnumFunctionTables(IN ProcessInfo* Process,
  736. IN OUT PULONG64 Start,
  737. IN OUT PULONG64 Handle,
  738. OUT PULONG64 MinAddress,
  739. OUT PULONG64 MaxAddress,
  740. OUT PULONG64 BaseAddress,
  741. OUT PULONG EntryCount,
  742. OUT PCROSS_PLATFORM_DYNAMIC_FUNCTION_TABLE RawTable,
  743. OUT PVOID* RawEntries);
  744. virtual HRESULT GetTargetContext(
  745. ULONG64 Thread,
  746. PVOID Context
  747. );
  748. virtual ModuleInfo* GetModuleInfo(BOOL UserMode);
  749. virtual HRESULT GetImageVersionInformation(ProcessInfo* Process,
  750. PCSTR ImagePath,
  751. ULONG64 ImageBase,
  752. PCSTR Item,
  753. PVOID Buffer,
  754. ULONG BufferSize,
  755. PULONG VerInfoSize);
  756. virtual HRESULT GetExceptionContext(PCROSS_PLATFORM_CONTEXT Context);
  757. virtual ULONG64 GetCurrentTimeDateN(void);
  758. virtual ULONG64 GetProcessUpTimeN(ProcessInfo* Process);
  759. virtual HRESULT GetProcessTimes(ProcessInfo* Process,
  760. PULONG64 Create,
  761. PULONG64 Exit,
  762. PULONG64 Kernel,
  763. PULONG64 User);
  764. virtual HRESULT GetProductInfo(PULONG ProductType, PULONG SuiteMask);
  765. // DumpTargetInfo.
  766. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  767. virtual void DumpDebug(void);
  768. virtual HRESULT Write(HANDLE hFile, ULONG FormatFlags,
  769. PCSTR CommentA, PCWSTR CommentW);
  770. // UserDumpTargetInfo.
  771. virtual HRESULT GetThreadInfo(ULONG Index,
  772. PULONG Id, PULONG Suspend, PULONG64 Teb);
  773. // UserMiniDumpTargetInfo.
  774. PVOID IndexDirectory(ULONG Index, MINIDUMP_DIRECTORY UNALIGNED *Dir,
  775. PVOID* Store);
  776. MINIDUMP_THREAD_EX UNALIGNED *IndexThreads(ULONG Index)
  777. {
  778. // Only a MINIDUMP_THREAD's worth of data may be valid
  779. // here if the dump only contains MINIDUMP_THREADs.
  780. // Check m_ThreadStructSize in any place that it matters.
  781. return (MINIDUMP_THREAD_EX UNALIGNED *)
  782. (m_Threads + Index * m_ThreadStructSize);
  783. }
  784. PMINIDUMP_HEADER m_Header;
  785. MINIDUMP_SYSTEM_INFO UNALIGNED * m_SysInfo;
  786. MINIDUMP_MISC_INFO m_MiscInfo;
  787. ULONG m_ActualThreadCount;
  788. ULONG m_ThreadStructSize;
  789. PUCHAR m_Threads;
  790. MINIDUMP_MEMORY_LIST UNALIGNED * m_Memory;
  791. MINIDUMP_MEMORY64_LIST UNALIGNED * m_Memory64;
  792. RVA64 m_Memory64DataBase;
  793. MINIDUMP_MODULE_LIST UNALIGNED * m_Modules;
  794. MINIDUMP_UNLOADED_MODULE_LIST UNALIGNED * m_UnlModules;
  795. MINIDUMP_EXCEPTION_STREAM UNALIGNED * m_Exception;
  796. MINIDUMP_HANDLE_DATA_STREAM UNALIGNED *m_Handles;
  797. MINIDUMP_FUNCTION_TABLE_STREAM UNALIGNED* m_FunctionTables;
  798. ULONG m_ImageType;
  799. };
  800. class UserMiniPartialDumpTargetInfo : public UserMiniDumpTargetInfo
  801. {
  802. public:
  803. UserMiniPartialDumpTargetInfo(void)
  804. : UserMiniDumpTargetInfo(TRUE) {}
  805. // TargetInfo.
  806. virtual HRESULT Initialize(void);
  807. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  808. PULONG DescLen);
  809. virtual HRESULT ReadVirtual(
  810. IN ProcessInfo* Process,
  811. IN ULONG64 Offset,
  812. OUT PVOID Buffer,
  813. IN ULONG BufferSize,
  814. OUT OPTIONAL PULONG BytesRead
  815. );
  816. virtual HRESULT QueryMemoryRegion(ProcessInfo* Process,
  817. PULONG64 Handle,
  818. BOOL HandleIsOffset,
  819. PMEMORY_BASIC_INFORMATION64 Info);
  820. virtual UnloadedModuleInfo* GetUnloadedModuleInfo(void);
  821. // DumpTargetInfo.
  822. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  823. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  824. PULONG File, PULONG Avail);
  825. };
  826. class UserMiniFullDumpTargetInfo : public UserMiniDumpTargetInfo
  827. {
  828. public:
  829. UserMiniFullDumpTargetInfo(void)
  830. : UserMiniDumpTargetInfo(FALSE) {}
  831. // TargetInfo.
  832. virtual HRESULT Initialize(void);
  833. virtual HRESULT GetDescription(PSTR Buffer, ULONG BufferLen,
  834. PULONG DescLen);
  835. virtual HRESULT QueryMemoryRegion(ProcessInfo* Process,
  836. PULONG64 Handle,
  837. BOOL HandleIsOffset,
  838. PMEMORY_BASIC_INFORMATION64 Info);
  839. virtual UnloadedModuleInfo* GetUnloadedModuleInfo(void);
  840. // DumpTargetInfo.
  841. virtual HRESULT IdentifyDump(PULONG64 BaseMapSize);
  842. virtual ULONG64 VirtualToOffset(ULONG64 Virt,
  843. PULONG File, PULONG Avail);
  844. };
  845. //----------------------------------------------------------------------------
  846. //
  847. // ModuleInfo implementations.
  848. //
  849. //----------------------------------------------------------------------------
  850. class KernelTriage32ModuleInfo : public ModuleInfo
  851. {
  852. public:
  853. virtual HRESULT Initialize(ThreadInfo* Thread);
  854. virtual HRESULT GetEntry(PMODULE_INFO_ENTRY Entry);
  855. private:
  856. KernelTriage32DumpTargetInfo* m_DumpTarget;
  857. ULONG m_Count;
  858. ULONG m_Cur;
  859. };
  860. extern KernelTriage32ModuleInfo g_KernelTriage32ModuleIterator;
  861. class KernelTriage64ModuleInfo : public ModuleInfo
  862. {
  863. public:
  864. virtual HRESULT Initialize(ThreadInfo* Thread);
  865. virtual HRESULT GetEntry(PMODULE_INFO_ENTRY Entry);
  866. private:
  867. KernelTriage64DumpTargetInfo* m_DumpTarget;
  868. ULONG m_Count;
  869. ULONG m_Cur;
  870. };
  871. extern KernelTriage64ModuleInfo g_KernelTriage64ModuleIterator;
  872. class UserFull32ModuleInfo : public ModuleInfo
  873. {
  874. public:
  875. virtual HRESULT Initialize(ThreadInfo* Thread);
  876. virtual HRESULT GetEntry(PMODULE_INFO_ENTRY Entry);
  877. private:
  878. UserFull32DumpTargetInfo* m_DumpTarget;
  879. ULONG64 m_Offset;
  880. ULONG m_Count;
  881. ULONG m_Cur;
  882. };
  883. extern UserFull32ModuleInfo g_UserFull32ModuleIterator;
  884. class UserFull64ModuleInfo : public ModuleInfo
  885. {
  886. public:
  887. virtual HRESULT Initialize(ThreadInfo* Thread);
  888. virtual HRESULT GetEntry(PMODULE_INFO_ENTRY Entry);
  889. private:
  890. UserFull64DumpTargetInfo* m_DumpTarget;
  891. ULONG64 m_Offset;
  892. ULONG m_Count;
  893. ULONG m_Cur;
  894. };
  895. extern UserFull64ModuleInfo g_UserFull64ModuleIterator;
  896. class UserMiniModuleInfo : public ModuleInfo
  897. {
  898. public:
  899. virtual HRESULT Initialize(ThreadInfo* Thread);
  900. virtual HRESULT GetEntry(PMODULE_INFO_ENTRY Entry);
  901. private:
  902. UserMiniDumpTargetInfo* m_DumpTarget;
  903. ULONG m_Count;
  904. ULONG m_Cur;
  905. };
  906. extern UserMiniModuleInfo g_UserMiniModuleIterator;
  907. class UserMiniUnloadedModuleInfo : public UnloadedModuleInfo
  908. {
  909. public:
  910. virtual HRESULT Initialize(ThreadInfo* Thread);
  911. virtual HRESULT GetEntry(PSTR Name, PDEBUG_MODULE_PARAMETERS Params);
  912. private:
  913. UserMiniDumpTargetInfo* m_DumpTarget;
  914. ULONG m_Index;
  915. };
  916. extern UserMiniUnloadedModuleInfo g_UserMiniUnloadedModuleIterator;
  917. class KernelTriage32UnloadedModuleInfo : public UnloadedModuleInfo
  918. {
  919. public:
  920. virtual HRESULT Initialize(ThreadInfo* Thread);
  921. virtual HRESULT GetEntry(PSTR Name, PDEBUG_MODULE_PARAMETERS Params);
  922. private:
  923. KernelTriage32DumpTargetInfo* m_DumpTarget;
  924. PDUMP_UNLOADED_DRIVERS32 m_Cur, m_End;
  925. };
  926. extern KernelTriage32UnloadedModuleInfo g_KernelTriage32UnloadedModuleIterator;
  927. class KernelTriage64UnloadedModuleInfo : public UnloadedModuleInfo
  928. {
  929. public:
  930. virtual HRESULT Initialize(ThreadInfo* Thread);
  931. virtual HRESULT GetEntry(PSTR Name, PDEBUG_MODULE_PARAMETERS Params);
  932. private:
  933. KernelTriage64DumpTargetInfo* m_DumpTarget;
  934. PDUMP_UNLOADED_DRIVERS64 m_Cur, m_End;
  935. };
  936. extern KernelTriage64UnloadedModuleInfo g_KernelTriage64UnloadedModuleIterator;
  937. //----------------------------------------------------------------------------
  938. //
  939. // Temporary class to generate kernel minidump class
  940. //
  941. //----------------------------------------------------------------------------
  942. class CCrashDumpWrapper32
  943. {
  944. public:
  945. void WriteDriverList(BYTE *pb, TRIAGE_DUMP32 *ptdh);
  946. void WriteUnloadedDrivers(BYTE *pb);
  947. void WriteMmTriageInformation(BYTE *pb);
  948. };
  949. class CCrashDumpWrapper64
  950. {
  951. public:
  952. void WriteDriverList(BYTE *pb, TRIAGE_DUMP64 *ptdh);
  953. void WriteUnloadedDrivers(BYTE *pb);
  954. void WriteMmTriageInformation(BYTE *pb);
  955. };
  956. #endif // #ifndef __DUMP_HPP__