mirror of https://github.com/tongzx/nt5src
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.
186 lines
4.1 KiB
186 lines
4.1 KiB
/*++
|
|
|
|
Copyright (c) 1990-2002 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
dump.c
|
|
|
|
Abstract:
|
|
|
|
This module supplies support for building a mini-dump file.
|
|
|
|
Author:
|
|
|
|
Oleg Kagan (olegk) Jun. 2002
|
|
|
|
Environment:
|
|
|
|
kernel mode only
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
|
|
#include "videoprt.h"
|
|
|
|
#define TRIAGE_DUMP_DATA_SIZE (TRIAGE_DUMP_SIZE - sizeof(ULONG))
|
|
|
|
ULONG
|
|
pVpAppendSecondaryMinidumpData(
|
|
PVOID pvSecondaryData,
|
|
ULONG ulSecondaryDataSize,
|
|
PVOID pvDump
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Adds precollected video driver specific data
|
|
|
|
Arguments:
|
|
|
|
pvDump - points to the begiinig of the dump buffer
|
|
pvSecondaryDumpData - points to the secondary data buffer
|
|
ulSecondaryDataSize - size of the secondary data buffer
|
|
|
|
Return Value:
|
|
|
|
Resulting length of the minidump
|
|
|
|
--*/
|
|
|
|
{
|
|
PMEMORY_DUMP pDump = (PMEMORY_DUMP)pvDump;
|
|
ULONG_PTR DumpDataEnd = (ULONG_PTR)pDump + TRIAGE_DUMP_DATA_SIZE;
|
|
PDUMP_HEADER pdh = &(pDump->Header);
|
|
|
|
PVOID pBuffer = (PVOID)((ULONG_PTR)pvDump + TRIAGE_DUMP_SIZE);
|
|
PDUMP_BLOB_FILE_HEADER BlobFileHdr = (PDUMP_BLOB_FILE_HEADER)(pBuffer);
|
|
PDUMP_BLOB_HEADER BlobHdr = (PDUMP_BLOB_HEADER)(BlobFileHdr + 1);
|
|
|
|
if (!pvDump) return 0;
|
|
|
|
if (pvSecondaryData && ulSecondaryDataSize) {
|
|
|
|
if (ulSecondaryDataSize > MAX_SECONDARY_DUMP_SIZE)
|
|
ulSecondaryDataSize = MAX_SECONDARY_DUMP_SIZE;
|
|
|
|
pdh->RequiredDumpSpace.QuadPart = TRIAGE_DUMP_SIZE + ulSecondaryDataSize;
|
|
|
|
BlobFileHdr->Signature1 = DUMP_BLOB_SIGNATURE1;
|
|
BlobFileHdr->Signature2 = DUMP_BLOB_SIGNATURE2;
|
|
BlobFileHdr->HeaderSize = sizeof(*BlobFileHdr);
|
|
BlobFileHdr->BuildNumber = NtBuildNumber;
|
|
|
|
BlobHdr->HeaderSize = sizeof(*BlobHdr);
|
|
BlobHdr->Tag = VpBugcheckGUID;
|
|
BlobHdr->PrePad = 0;
|
|
BlobHdr->PostPad = MAX_SECONDARY_DUMP_SIZE - ulSecondaryDataSize;
|
|
BlobHdr->DataSize = ulSecondaryDataSize;
|
|
|
|
RtlCopyMemory((PVOID)(BlobHdr + 1), pvSecondaryData, ulSecondaryDataSize);
|
|
}
|
|
|
|
return (ULONG)pdh->RequiredDumpSpace.QuadPart;
|
|
}
|
|
|
|
VOID
|
|
VpNotifyEaData(
|
|
PDEVICE_OBJECT DeviceObject,
|
|
PVOID pvDump
|
|
)
|
|
|
|
{
|
|
PDEVICE_OBJECT pPdo = IoGetDeviceAttachmentBaseRef(DeviceObject);
|
|
|
|
if (pPdo) {
|
|
|
|
//
|
|
// Find the FDO that matches this PDO
|
|
//
|
|
|
|
PFDO_EXTENSION CurrFdo = FdoHead;
|
|
|
|
while (CurrFdo) {
|
|
|
|
if (CurrFdo->PhysicalDeviceObject == pPdo) {
|
|
VpBugcheckDeviceObject = CurrFdo->FunctionalDeviceObject;
|
|
}
|
|
|
|
CurrFdo = CurrFdo->NextFdoExtension;
|
|
}
|
|
|
|
ASSERT(VpBugcheckDeviceObject != NULL);
|
|
|
|
if (pvDump) {
|
|
if (!VpDump) {
|
|
VpDump = ExAllocatePoolWithTag(PagedPool,
|
|
TRIAGE_DUMP_SIZE + 0x1000, // XXX olegk - why 1000? why not 2*TRIAGE_DUMP_SIZE?
|
|
VP_TAG);
|
|
}
|
|
|
|
if (VpDump) memcpy(VpDump, pvDump, TRIAGE_DUMP_SIZE + 0x1000);
|
|
}
|
|
|
|
ObDereferenceObject(pPdo);
|
|
}
|
|
}
|
|
|
|
PRTL_PROCESS_MODULES
|
|
WdpGetLoadedModuleList(
|
|
VOID
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine returns a pointer to a list of loaded modules.
|
|
|
|
Arguments:
|
|
|
|
None.
|
|
|
|
Return Value:
|
|
|
|
A pointer to memory with the loaded module list.
|
|
|
|
Notes:
|
|
|
|
The caller is responsible for freeing the memory when no longer needed.
|
|
|
|
--*/
|
|
|
|
{
|
|
PRTL_PROCESS_MODULES Buffer = NULL;
|
|
ULONG BufferSize;
|
|
ULONG ReturnLength = 4096;
|
|
NTSTATUS Status;
|
|
|
|
do
|
|
{
|
|
if (Buffer)
|
|
{
|
|
ExFreePool(Buffer);
|
|
}
|
|
|
|
BufferSize = ReturnLength;
|
|
|
|
Buffer = ExAllocatePoolWithTag(NonPagedPool, BufferSize, VP_TAG);
|
|
|
|
if (Buffer == NULL)
|
|
{
|
|
break;
|
|
}
|
|
|
|
Status = ZwQuerySystemInformation(SystemModuleInformation,
|
|
Buffer,
|
|
BufferSize,
|
|
&ReturnLength);
|
|
|
|
} while (Status == STATUS_INFO_LENGTH_MISMATCH);
|
|
|
|
return Buffer;
|
|
}
|