mirror of
https://github.com/reactos/reactos.git
synced 2024-12-05 09:23:32 +08:00
[NTOS:KD64][NTOS:KDBG] Fix spinlocks use
Raise IRQL before entering debugger, so that KeAcquireSpinLockAtDpcLevel works as expected. - HIGH_LEVEL since we don't know where we are coming from. Do not try to read debug symbol from files in KDBG. - There is no reason that this works if Mm didn't map it in the first place.
This commit is contained in:
parent
5c332f6d36
commit
608032bd08
@ -92,7 +92,9 @@ KdPollBreakIn(VOID)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
KIRQL OldIrql;
|
||||||
/* Try to acquire the lock */
|
/* Try to acquire the lock */
|
||||||
|
KeRaiseIrql(HIGH_LEVEL, &OldIrql);
|
||||||
if (KeTryToAcquireSpinLockAtDpcLevel(&KdpDebuggerLock))
|
if (KeTryToAcquireSpinLockAtDpcLevel(&KdpDebuggerLock))
|
||||||
{
|
{
|
||||||
/* Now get a packet */
|
/* Now get a packet */
|
||||||
@ -110,6 +112,7 @@ KdPollBreakIn(VOID)
|
|||||||
/* Let go of the port */
|
/* Let go of the port */
|
||||||
KdpPortUnlock();
|
KdpPortUnlock();
|
||||||
}
|
}
|
||||||
|
KeLowerIrql(OldIrql);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Re-enable interrupts if they were enabled previously */
|
/* Re-enable interrupts if they were enabled previously */
|
||||||
|
@ -144,6 +144,10 @@ KdpTrap(IN PKTRAP_FRAME TrapFrame,
|
|||||||
BOOLEAN Handled;
|
BOOLEAN Handled;
|
||||||
NTSTATUS ReturnStatus;
|
NTSTATUS ReturnStatus;
|
||||||
USHORT ReturnLength;
|
USHORT ReturnLength;
|
||||||
|
KIRQL OldIrql;
|
||||||
|
|
||||||
|
/* Raise as high as we can. */
|
||||||
|
KeRaiseIrql(HIGH_LEVEL, &OldIrql);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check if we got a STATUS_BREAKPOINT with a SubID for Print, Prompt or
|
* Check if we got a STATUS_BREAKPOINT with a SubID for Print, Prompt or
|
||||||
@ -257,6 +261,8 @@ KdpTrap(IN PKTRAP_FRAME TrapFrame,
|
|||||||
SecondChanceException);
|
SecondChanceException);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
KeLowerIrql(OldIrql);
|
||||||
|
|
||||||
/* Return TRUE or FALSE to caller */
|
/* Return TRUE or FALSE to caller */
|
||||||
return Handled;
|
return Handled;
|
||||||
}
|
}
|
||||||
|
@ -244,11 +244,10 @@ KdbpSymFindCachedFile(
|
|||||||
{
|
{
|
||||||
PIMAGE_SYMBOL_INFO_CACHE Current;
|
PIMAGE_SYMBOL_INFO_CACHE Current;
|
||||||
PLIST_ENTRY CurrentEntry;
|
PLIST_ENTRY CurrentEntry;
|
||||||
KIRQL Irql;
|
|
||||||
|
|
||||||
DPRINT("Looking for cached symbol file %wZ\n", FileName);
|
DPRINT("Looking for cached symbol file %wZ\n", FileName);
|
||||||
|
|
||||||
KeAcquireSpinLock(&SymbolFileListLock, &Irql);
|
KeAcquireSpinLockAtDpcLevel(&SymbolFileListLock);
|
||||||
|
|
||||||
CurrentEntry = SymbolFileListHead.Flink;
|
CurrentEntry = SymbolFileListHead.Flink;
|
||||||
while (CurrentEntry != (&SymbolFileListHead))
|
while (CurrentEntry != (&SymbolFileListHead))
|
||||||
@ -259,7 +258,7 @@ KdbpSymFindCachedFile(
|
|||||||
if (RtlEqualUnicodeString(&Current->FileName, FileName, TRUE))
|
if (RtlEqualUnicodeString(&Current->FileName, FileName, TRUE))
|
||||||
{
|
{
|
||||||
Current->RefCount++;
|
Current->RefCount++;
|
||||||
KeReleaseSpinLock(&SymbolFileListLock, Irql);
|
KeReleaseSpinLockFromDpcLevel(&SymbolFileListLock);
|
||||||
DPRINT("Found cached file!\n");
|
DPRINT("Found cached file!\n");
|
||||||
return Current->RosSymInfo;
|
return Current->RosSymInfo;
|
||||||
}
|
}
|
||||||
@ -267,7 +266,7 @@ KdbpSymFindCachedFile(
|
|||||||
CurrentEntry = CurrentEntry->Flink;
|
CurrentEntry = CurrentEntry->Flink;
|
||||||
}
|
}
|
||||||
|
|
||||||
KeReleaseSpinLock(&SymbolFileListLock, Irql);
|
KeReleaseSpinLockFromDpcLevel(&SymbolFileListLock);
|
||||||
|
|
||||||
DPRINT("Cached file not found!\n");
|
DPRINT("Cached file not found!\n");
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -355,81 +354,6 @@ KdbpSymRemoveCachedFile(
|
|||||||
DPRINT1("Warning: Removing unknown symbol file: RosSymInfo = %p\n", RosSymInfo);
|
DPRINT1("Warning: Removing unknown symbol file: RosSymInfo = %p\n", RosSymInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*! \brief Loads a symbol file.
|
|
||||||
*
|
|
||||||
* \param FileName Filename of the symbol file to load.
|
|
||||||
* \param RosSymInfo Pointer to a ROSSYM_INFO which gets filled.
|
|
||||||
*
|
|
||||||
* \sa KdbpSymUnloadModuleSymbols
|
|
||||||
*/
|
|
||||||
static VOID
|
|
||||||
KdbpSymLoadModuleSymbols(
|
|
||||||
IN PUNICODE_STRING FileName,
|
|
||||||
OUT PROSSYM_INFO *RosSymInfo)
|
|
||||||
{
|
|
||||||
OBJECT_ATTRIBUTES ObjectAttributes;
|
|
||||||
HANDLE FileHandle;
|
|
||||||
NTSTATUS Status;
|
|
||||||
IO_STATUS_BLOCK IoStatusBlock;
|
|
||||||
BOOLEAN Result;
|
|
||||||
|
|
||||||
/* Allow KDB to break on module load */
|
|
||||||
KdbModuleLoaded(FileName);
|
|
||||||
|
|
||||||
if (!LoadSymbols)
|
|
||||||
{
|
|
||||||
*RosSymInfo = NULL;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Try to find cached (already loaded) symbol file */
|
|
||||||
*RosSymInfo = KdbpSymFindCachedFile(FileName);
|
|
||||||
if (*RosSymInfo)
|
|
||||||
{
|
|
||||||
DPRINT("Found cached symbol file %wZ\n", FileName);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open the file */
|
|
||||||
InitializeObjectAttributes(&ObjectAttributes,
|
|
||||||
FileName,
|
|
||||||
OBJ_CASE_INSENSITIVE | OBJ_KERNEL_HANDLE,
|
|
||||||
NULL,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
DPRINT("Attempting to open image: %wZ\n", FileName);
|
|
||||||
|
|
||||||
Status = ZwOpenFile(&FileHandle,
|
|
||||||
FILE_READ_ACCESS | SYNCHRONIZE,
|
|
||||||
&ObjectAttributes,
|
|
||||||
&IoStatusBlock,
|
|
||||||
FILE_SHARE_READ | FILE_SHARE_WRITE,
|
|
||||||
FILE_SYNCHRONOUS_IO_NONALERT);
|
|
||||||
if (!NT_SUCCESS(Status))
|
|
||||||
{
|
|
||||||
DPRINT("Could not open image file: %wZ\n", FileName);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
DPRINT("Loading symbols from %wZ...\n", FileName);
|
|
||||||
|
|
||||||
Result = RosSymCreateFromFile(&FileHandle, RosSymInfo);
|
|
||||||
ZwClose(FileHandle);
|
|
||||||
|
|
||||||
if (!Result)
|
|
||||||
{
|
|
||||||
DPRINT("Failed to load symbols from %wZ\n", FileName);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
DPRINT("Symbols loaded.\n");
|
|
||||||
|
|
||||||
/* add file to cache */
|
|
||||||
KdbpSymAddCachedFile(FileName, *RosSymInfo);
|
|
||||||
|
|
||||||
DPRINT("Installed symbols: %wZ %p\n", FileName, *RosSymInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
KdbSymProcessSymbols(
|
KdbSymProcessSymbols(
|
||||||
IN PLDR_DATA_TABLE_ENTRY LdrEntry)
|
IN PLDR_DATA_TABLE_ENTRY LdrEntry)
|
||||||
@ -444,21 +368,17 @@ KdbSymProcessSymbols(
|
|||||||
if (LdrEntry->PatchInformation)
|
if (LdrEntry->PatchInformation)
|
||||||
KdbpSymRemoveCachedFile(LdrEntry->PatchInformation);
|
KdbpSymRemoveCachedFile(LdrEntry->PatchInformation);
|
||||||
|
|
||||||
/* Load new symbol information */
|
/* Check cache */
|
||||||
if (! RosSymCreateFromMem(LdrEntry->DllBase,
|
LdrEntry->PatchInformation = KdbpSymFindCachedFile(&LdrEntry->FullDllName);
|
||||||
LdrEntry->SizeOfImage,
|
|
||||||
(PROSSYM_INFO*)&LdrEntry->PatchInformation))
|
|
||||||
{
|
|
||||||
/* Error loading symbol info, try to load it from file */
|
|
||||||
KdbpSymLoadModuleSymbols(&LdrEntry->FullDllName,
|
|
||||||
(PROSSYM_INFO*)&LdrEntry->PatchInformation);
|
|
||||||
|
|
||||||
/* It already added symbols to cache */
|
if (!LdrEntry->PatchInformation)
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
/* Add file to cache */
|
/* Load new symbol information */
|
||||||
KdbpSymAddCachedFile(&LdrEntry->FullDllName, LdrEntry->PatchInformation);
|
if (RosSymCreateFromMem(LdrEntry->DllBase, LdrEntry->SizeOfImage, (PROSSYM_INFO*)&LdrEntry->PatchInformation))
|
||||||
|
{
|
||||||
|
/* Add file to cache */
|
||||||
|
KdbpSymAddCachedFile(&LdrEntry->FullDllName, LdrEntry->PatchInformation);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DPRINT("Installed symbols: %wZ@%p-%p %p\n",
|
DPRINT("Installed symbols: %wZ@%p-%p %p\n",
|
||||||
@ -466,7 +386,6 @@ KdbSymProcessSymbols(
|
|||||||
LdrEntry->DllBase,
|
LdrEntry->DllBase,
|
||||||
(PVOID)(LdrEntry->SizeOfImage + (ULONG_PTR)LdrEntry->DllBase),
|
(PVOID)(LdrEntry->SizeOfImage + (ULONG_PTR)LdrEntry->DllBase),
|
||||||
LdrEntry->PatchInformation);
|
LdrEntry->PatchInformation);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
@ -567,14 +486,17 @@ KdbInitialize(
|
|||||||
}
|
}
|
||||||
else if (BootPhase == 1)
|
else if (BootPhase == 1)
|
||||||
{
|
{
|
||||||
|
KIRQL OldIrql;
|
||||||
/* Load symbols for NTOSKRNL.EXE.
|
/* Load symbols for NTOSKRNL.EXE.
|
||||||
It is always the first module in PsLoadedModuleList. KeLoaderBlock can't be used here as its content is just temporary. */
|
It is always the first module in PsLoadedModuleList. KeLoaderBlock can't be used here as its content is just temporary. */
|
||||||
|
OldIrql = KeRaiseIrqlToDpcLevel();
|
||||||
LdrEntry = CONTAINING_RECORD(PsLoadedModuleList.Flink, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks);
|
LdrEntry = CONTAINING_RECORD(PsLoadedModuleList.Flink, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks);
|
||||||
KdbSymProcessSymbols(LdrEntry);
|
KdbSymProcessSymbols(LdrEntry);
|
||||||
|
|
||||||
/* Also load them for HAL.DLL. */
|
/* Also load them for HAL.DLL. */
|
||||||
LdrEntry = CONTAINING_RECORD(PsLoadedModuleList.Flink->Flink, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks);
|
LdrEntry = CONTAINING_RECORD(PsLoadedModuleList.Flink->Flink, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks);
|
||||||
KdbSymProcessSymbols(LdrEntry);
|
KdbSymProcessSymbols(LdrEntry);
|
||||||
|
KeLowerIrql(OldIrql);
|
||||||
|
|
||||||
KdbpSymbolsInitialized = TRUE;
|
KdbpSymbolsInitialized = TRUE;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user