2005-04-25 14:44:48 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* FILE: ntoskrnl/kd/kdinit.c
|
2008-12-29 14:26:01 +00:00
|
|
|
* PURPOSE: Kernel Debugger Initialization
|
2005-05-09 01:38:29 +00:00
|
|
|
*
|
2005-04-25 14:44:48 +00:00
|
|
|
* PROGRAMMERS: Alex Ionescu (alex@relsoft.net)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <ntoskrnl.h>
|
|
|
|
#define NDEBUG
|
2008-08-30 16:31:06 +00:00
|
|
|
#include <debug.h>
|
2005-04-25 14:44:48 +00:00
|
|
|
|
|
|
|
/* VARIABLES ***************************************************************/
|
|
|
|
|
2005-11-22 02:30:18 +00:00
|
|
|
BOOLEAN KdDebuggerEnabled = FALSE;
|
|
|
|
BOOLEAN KdEnteredDebugger = FALSE;
|
|
|
|
BOOLEAN KdDebuggerNotPresent = TRUE;
|
2007-01-24 19:48:34 +00:00
|
|
|
BOOLEAN KdBreakAfterSymbolLoad = FALSE;
|
2009-10-17 14:31:38 +00:00
|
|
|
BOOLEAN KdpBreakPending = FALSE;
|
2007-03-05 01:35:43 +00:00
|
|
|
BOOLEAN KdPitchDebugger = TRUE;
|
2009-10-17 14:31:38 +00:00
|
|
|
BOOLEAN KdIgnoreUmExceptions = FALSE;
|
2009-11-02 17:45:51 +00:00
|
|
|
KD_CONTEXT KdpContext;
|
|
|
|
ULONG Kd_WIN2000_Mask;
|
2008-11-29 20:47:48 +00:00
|
|
|
VOID NTAPI PspDumpThreads(BOOLEAN SystemThreads);
|
2005-04-25 14:44:48 +00:00
|
|
|
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
ULONG ComponentId;
|
|
|
|
ULONG Level;
|
|
|
|
} KD_COMPONENT_DATA;
|
|
|
|
#define MAX_KD_COMPONENT_TABLE_ENTRIES 128
|
|
|
|
KD_COMPONENT_DATA KdComponentTable[MAX_KD_COMPONENT_TABLE_ENTRIES];
|
|
|
|
ULONG KdComponentTableEntries = 0;
|
|
|
|
|
2008-01-08 09:51:53 +00:00
|
|
|
ULONG Kd_DEFAULT_MASK = 1 << DPFLTR_ERROR_LEVEL;
|
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* PRIVATE FUNCTIONS *********************************************************/
|
|
|
|
|
|
|
|
ULONG
|
2008-11-29 20:47:48 +00:00
|
|
|
NTAPI
|
2005-04-25 14:44:48 +00:00
|
|
|
KdpServiceDispatcher(ULONG Service,
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
PVOID Buffer1,
|
|
|
|
ULONG Buffer1Length)
|
2005-04-25 14:44:48 +00:00
|
|
|
{
|
|
|
|
ULONG Result = 0;
|
|
|
|
|
|
|
|
switch (Service)
|
|
|
|
{
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
case BREAKPOINT_PRINT: /* DbgPrint */
|
|
|
|
Result = KdpPrintString(Buffer1, Buffer1Length);
|
2005-04-25 14:44:48 +00:00
|
|
|
break;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2009-06-17 12:44:05 +00:00
|
|
|
#if DBG
|
2009-08-24 18:19:53 +00:00
|
|
|
case ' soR': /* ROS-INTERNAL */
|
2005-04-25 14:44:48 +00:00
|
|
|
{
|
2010-01-13 22:35:43 +00:00
|
|
|
switch ((ULONG_PTR)Buffer1)
|
2005-04-25 14:44:48 +00:00
|
|
|
{
|
|
|
|
case ManualBugCheck:
|
2008-08-24 15:48:05 +00:00
|
|
|
KeBugCheck(MANUALLY_INITIATED_CRASH);
|
2005-04-25 14:44:48 +00:00
|
|
|
break;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
case DumpAllThreads:
|
|
|
|
PspDumpThreads(TRUE);
|
|
|
|
break;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
case DumpUserThreads:
|
|
|
|
PspDumpThreads(FALSE);
|
|
|
|
break;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
case EnterDebugger:
|
|
|
|
DbgBreakPoint();
|
|
|
|
break;
|
2009-06-27 09:54:56 +00:00
|
|
|
|
2010-11-02 14:58:39 +00:00
|
|
|
case KdSpare3:
|
|
|
|
MmDumpArmPfnDatabase(FALSE);
|
2009-06-27 09:54:56 +00:00
|
|
|
break;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2008-12-16 17:51:57 +00:00
|
|
|
break;
|
2005-04-25 14:44:48 +00:00
|
|
|
}
|
2008-12-16 15:25:51 +00:00
|
|
|
|
|
|
|
/* Special case for stack frame dumps */
|
2009-08-24 18:19:53 +00:00
|
|
|
case 'DsoR':
|
2008-12-16 15:25:51 +00:00
|
|
|
{
|
|
|
|
KeRosDumpStackFrames((PULONG)Buffer1, Buffer1Length);
|
|
|
|
break;
|
|
|
|
}
|
2005-05-26 13:42:41 +00:00
|
|
|
#endif
|
2005-04-25 14:44:48 +00:00
|
|
|
default:
|
|
|
|
HalDisplayString ("Invalid debug service call!\n");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
2006-09-17 07:06:35 +00:00
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
KdpEnterDebuggerException(IN PKTRAP_FRAME TrapFrame,
|
|
|
|
IN PKEXCEPTION_FRAME ExceptionFrame,
|
|
|
|
IN PEXCEPTION_RECORD ExceptionRecord,
|
|
|
|
IN PCONTEXT Context,
|
|
|
|
IN KPROCESSOR_MODE PreviousMode,
|
|
|
|
IN BOOLEAN SecondChance)
|
|
|
|
{
|
2009-06-22 13:47:10 +00:00
|
|
|
KD_CONTINUE_TYPE Return = kdHandleException;
|
2007-03-03 17:24:58 +00:00
|
|
|
ULONG ExceptionCommand = ExceptionRecord->ExceptionInformation[0];
|
|
|
|
|
|
|
|
/* Check if this was a breakpoint due to DbgPrint or Load/UnloadSymbols */
|
|
|
|
if ((ExceptionRecord->ExceptionCode == STATUS_BREAKPOINT) &&
|
|
|
|
(ExceptionRecord->NumberParameters > 0) &&
|
|
|
|
((ExceptionCommand == BREAKPOINT_LOAD_SYMBOLS) ||
|
|
|
|
(ExceptionCommand == BREAKPOINT_UNLOAD_SYMBOLS) ||
|
|
|
|
(ExceptionCommand == BREAKPOINT_COMMAND_STRING) ||
|
2009-10-23 22:51:39 +00:00
|
|
|
(ExceptionCommand == BREAKPOINT_PRINT) ||
|
|
|
|
(ExceptionCommand == BREAKPOINT_PROMPT)))
|
2007-03-03 17:24:58 +00:00
|
|
|
{
|
|
|
|
/* Check if this is a debug print */
|
|
|
|
if (ExceptionCommand == BREAKPOINT_PRINT)
|
|
|
|
{
|
|
|
|
/* Print the string */
|
|
|
|
KdpServiceDispatcher(BREAKPOINT_PRINT,
|
|
|
|
(PVOID)ExceptionRecord->ExceptionInformation[1],
|
|
|
|
ExceptionRecord->ExceptionInformation[2]);
|
2009-10-04 16:53:15 +00:00
|
|
|
|
|
|
|
/* Return success */
|
|
|
|
KeSetContextReturnRegister(Context, STATUS_SUCCESS);
|
2007-03-03 17:24:58 +00:00
|
|
|
}
|
2009-10-23 22:51:39 +00:00
|
|
|
#ifdef KDBG
|
2007-07-06 09:02:16 +00:00
|
|
|
else if (ExceptionCommand == BREAKPOINT_LOAD_SYMBOLS)
|
|
|
|
{
|
2009-09-22 21:31:55 +00:00
|
|
|
PLDR_DATA_TABLE_ENTRY LdrEntry;
|
|
|
|
|
2007-07-06 09:02:16 +00:00
|
|
|
/* Load symbols. Currently implemented only for KDBG! */
|
2009-09-22 21:31:55 +00:00
|
|
|
if(KdbpSymFindModule(((PKD_SYMBOLS_INFO)ExceptionRecord->ExceptionInformation[2])->BaseOfDll, NULL, -1, &LdrEntry))
|
|
|
|
KdbSymProcessSymbols(LdrEntry);
|
2007-07-06 09:02:16 +00:00
|
|
|
}
|
2009-10-23 22:51:39 +00:00
|
|
|
else if (ExceptionCommand == BREAKPOINT_PROMPT)
|
|
|
|
{
|
|
|
|
ULONG ReturnValue;
|
|
|
|
LPSTR OutString;
|
|
|
|
USHORT OutStringLength;
|
|
|
|
|
|
|
|
/* Get the response string and length */
|
|
|
|
OutString = (LPSTR)Context->Ebx;
|
|
|
|
OutStringLength = (USHORT)Context->Edi;
|
|
|
|
|
|
|
|
/* Call KDBG */
|
|
|
|
ReturnValue = KdpPrompt((LPSTR)ExceptionRecord->
|
|
|
|
ExceptionInformation[1],
|
|
|
|
(USHORT)ExceptionRecord->
|
|
|
|
ExceptionInformation[2],
|
|
|
|
OutString,
|
|
|
|
OutStringLength);
|
|
|
|
|
|
|
|
/* Return the number of characters that we received */
|
|
|
|
Context->Eax = ReturnValue;
|
|
|
|
}
|
|
|
|
#endif
|
2006-09-17 07:06:35 +00:00
|
|
|
|
2009-10-04 16:53:15 +00:00
|
|
|
/* This we can handle: simply bump the Program Counter */
|
|
|
|
KeSetContextPc(Context, KeGetContextPc(Context) + KD_BREAKPOINT_SIZE);
|
2007-03-03 19:49:36 +00:00
|
|
|
return TRUE;
|
2007-03-03 17:24:58 +00:00
|
|
|
}
|
2006-09-17 07:06:35 +00:00
|
|
|
|
2009-10-23 22:51:39 +00:00
|
|
|
#ifdef KDBG
|
|
|
|
/* Check if this is an assertion failure */
|
|
|
|
if (ExceptionRecord->ExceptionCode == STATUS_ASSERTION_FAILURE)
|
|
|
|
{
|
|
|
|
/* Warn about it */
|
|
|
|
DbgPrint("\n!!! Assertion Failure at Address 0x%p !!!\n\n",
|
|
|
|
(PVOID)Context->Eip);
|
|
|
|
|
|
|
|
/* Bump EIP to the instruction following the int 2C and return */
|
|
|
|
Context->Eip += 2;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2006-09-17 07:06:35 +00:00
|
|
|
/* Get out of here if the Debugger isn't connected */
|
|
|
|
if (KdDebuggerNotPresent) return FALSE;
|
|
|
|
|
2009-06-22 11:32:58 +00:00
|
|
|
#ifdef KDBG
|
2006-09-17 07:06:35 +00:00
|
|
|
/* Call KDBG if available */
|
|
|
|
Return = KdbEnterDebuggerException(ExceptionRecord,
|
|
|
|
PreviousMode,
|
|
|
|
Context,
|
|
|
|
TrapFrame,
|
|
|
|
!SecondChance);
|
2009-06-22 11:32:58 +00:00
|
|
|
#else /* not KDBG */
|
|
|
|
if (WrapperInitRoutine)
|
|
|
|
{
|
|
|
|
/* Call GDB */
|
|
|
|
Return = WrapperTable.KdpExceptionRoutine(ExceptionRecord,
|
|
|
|
Context,
|
|
|
|
TrapFrame);
|
|
|
|
}
|
|
|
|
#endif /* not KDBG */
|
2006-09-17 07:06:35 +00:00
|
|
|
|
2008-06-12 08:56:13 +00:00
|
|
|
/* Debugger didn't handle it, please handle! */
|
|
|
|
if (Return == kdHandleException) return FALSE;
|
|
|
|
|
|
|
|
/* Debugger handled it */
|
2008-06-11 11:34:04 +00:00
|
|
|
return TRUE;
|
2006-09-17 07:06:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
KdpCallGdb(IN PKTRAP_FRAME TrapFrame,
|
|
|
|
IN PEXCEPTION_RECORD ExceptionRecord,
|
|
|
|
IN PCONTEXT Context)
|
2005-04-25 14:44:48 +00:00
|
|
|
{
|
2006-09-17 07:06:35 +00:00
|
|
|
KD_CONTINUE_TYPE Return = kdDoNotHandleException;
|
|
|
|
|
2006-08-30 05:22:56 +00:00
|
|
|
/* Get out of here if the Debugger isn't connected */
|
2006-09-17 07:06:35 +00:00
|
|
|
if (KdDebuggerNotPresent) return FALSE;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* FIXME:
|
|
|
|
* Right now, the GDB wrapper seems to handle exceptions differntly
|
|
|
|
* from KDGB and both are called at different times, while the GDB
|
|
|
|
* one is only called once and that's it. I don't really have the knowledge
|
|
|
|
* to fix the GDB stub, so until then, we'll be using this hack
|
|
|
|
*/
|
2006-09-17 07:06:35 +00:00
|
|
|
if (WrapperInitRoutine)
|
2005-04-25 14:44:48 +00:00
|
|
|
{
|
2006-09-17 07:06:35 +00:00
|
|
|
Return = WrapperTable.KdpExceptionRoutine(ExceptionRecord,
|
|
|
|
Context,
|
|
|
|
TrapFrame);
|
2005-04-25 14:44:48 +00:00
|
|
|
}
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2008-06-12 08:56:13 +00:00
|
|
|
/* Debugger didn't handle it, please handle! */
|
|
|
|
if (Return == kdHandleException) return FALSE;
|
|
|
|
|
|
|
|
/* Debugger handled it */
|
2008-06-11 11:34:04 +00:00
|
|
|
return TRUE;
|
2005-04-25 14:44:48 +00:00
|
|
|
}
|
|
|
|
|
2009-10-17 14:31:38 +00:00
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
KdIsThisAKdTrap(IN PEXCEPTION_RECORD ExceptionRecord,
|
|
|
|
IN PCONTEXT Context,
|
|
|
|
IN KPROCESSOR_MODE PreviousMode)
|
|
|
|
{
|
|
|
|
/* KDBG has its own mechanism for ignoring user mode exceptions */
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* PUBLIC FUNCTIONS *********************************************************/
|
|
|
|
|
- Export KeI386MachineType and KeInitializeThreadedDpc
- Stubplement and export IoEnumerateRegisteredFiltersList, IoGetPagingIoPriority, KdRefreshDebuggerNotPresent, KeAcquireInStackQueuedSpinLockForDpc, KeReleaseInStackQueuedSpinLockForDpc, KeAcquireSpinLockForDpc, KeReleaseSpinLockForDpc, KeRegisterNmiCallback, KeDeregisterNmiCallback, KeInitializeCrashDumpHeader, KeTestSpinLock and MmAllocatePagesForMdlEx
- Add IO_PAGING_PRIORITY enumeration and PNMI_CALLBACK prototype to headers
svn path=/trunk/; revision=35103
2008-08-04 15:48:46 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
KdRefreshDebuggerNotPresent(VOID)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
|
|
|
|
/* Just return whatever was set previously -- FIXME! */
|
|
|
|
return KdDebuggerNotPresent;
|
|
|
|
}
|
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2006-09-07 22:38:06 +00:00
|
|
|
NTSTATUS
|
2008-11-29 20:47:48 +00:00
|
|
|
NTAPI
|
2005-04-25 14:44:48 +00:00
|
|
|
KdDisableDebugger(VOID)
|
|
|
|
{
|
|
|
|
KIRQL OldIrql;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Raise IRQL */
|
|
|
|
KeRaiseIrql(DISPATCH_LEVEL, &OldIrql);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* TODO: Disable any breakpoints */
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Disable the Debugger */
|
|
|
|
KdDebuggerEnabled = FALSE;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Lower the IRQL */
|
|
|
|
KeLowerIrql(OldIrql);
|
2006-09-07 22:38:06 +00:00
|
|
|
|
|
|
|
/* Return success */
|
|
|
|
return STATUS_SUCCESS;
|
2005-04-25 14:44:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2006-09-07 22:38:06 +00:00
|
|
|
NTSTATUS
|
2008-11-29 20:47:48 +00:00
|
|
|
NTAPI
|
2005-04-25 14:44:48 +00:00
|
|
|
KdEnableDebugger(VOID)
|
|
|
|
{
|
|
|
|
KIRQL OldIrql;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Raise IRQL */
|
|
|
|
KeRaiseIrql(DISPATCH_LEVEL, &OldIrql);
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* TODO: Re-enable any breakpoints */
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Enable the Debugger */
|
|
|
|
KdDebuggerEnabled = TRUE;
|
2005-05-09 01:38:29 +00:00
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* Lower the IRQL */
|
|
|
|
KeLowerIrql(OldIrql);
|
2006-09-07 22:38:06 +00:00
|
|
|
|
|
|
|
/* Return success */
|
|
|
|
return STATUS_SUCCESS;
|
2005-04-25 14:44:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2005-05-09 01:38:29 +00:00
|
|
|
BOOLEAN
|
2008-11-29 20:47:48 +00:00
|
|
|
NTAPI
|
2005-04-25 14:44:48 +00:00
|
|
|
KdPollBreakIn(VOID)
|
|
|
|
{
|
|
|
|
return KdpBreakPending;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
NTSTATUS
|
2008-11-29 20:47:48 +00:00
|
|
|
NTAPI
|
2005-04-25 14:44:48 +00:00
|
|
|
KdPowerTransition(ULONG PowerState)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
|
2006-12-06 20:55:42 +00:00
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
2007-03-02 18:25:23 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
2006-12-06 20:55:42 +00:00
|
|
|
KdChangeOption(IN KD_OPTION Option,
|
|
|
|
IN ULONG InBufferLength OPTIONAL,
|
|
|
|
IN PVOID InBuffer,
|
|
|
|
IN ULONG OutBufferLength OPTIONAL,
|
|
|
|
OUT PVOID OutBuffer,
|
|
|
|
OUT PULONG OutBufferRequiredLength OPTIONAL)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
2007-03-02 18:25:23 +00:00
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
2006-12-06 20:55:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
NTSTATUS
|
2008-01-08 09:51:53 +00:00
|
|
|
NTAPI
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
NtQueryDebugFilterState(IN ULONG ComponentId,
|
|
|
|
IN ULONG Level)
|
|
|
|
{
|
2008-01-08 09:51:53 +00:00
|
|
|
ULONG i;
|
|
|
|
|
|
|
|
/* Convert Level to mask if it isn't already one */
|
|
|
|
if (Level < 32)
|
|
|
|
Level = 1 << Level;
|
|
|
|
|
|
|
|
/* Check if it is not the default component */
|
|
|
|
if (ComponentId != DPFLTR_DEFAULT_ID)
|
|
|
|
{
|
|
|
|
/* No, search for an existing entry in the table */
|
|
|
|
for (i = 0; i < KdComponentTableEntries; i++)
|
|
|
|
{
|
|
|
|
/* Check if it is the right component */
|
|
|
|
if (ComponentId == KdComponentTable[i].ComponentId)
|
|
|
|
{
|
|
|
|
/* Check if mask are matching */
|
2009-10-25 15:56:38 +00:00
|
|
|
return (Level & KdComponentTable[i].Level) ? TRUE : FALSE;
|
2008-01-08 09:51:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Entry not found in the table, use default mask */
|
2009-10-25 15:56:38 +00:00
|
|
|
return (Level & Kd_DEFAULT_MASK) ? TRUE : FALSE;
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NTSTATUS
|
2008-01-08 09:51:53 +00:00
|
|
|
NTAPI
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
NtSetDebugFilterState(IN ULONG ComponentId,
|
|
|
|
IN ULONG Level,
|
|
|
|
IN BOOLEAN State)
|
|
|
|
{
|
2008-01-08 09:51:53 +00:00
|
|
|
ULONG i;
|
|
|
|
|
|
|
|
/* Convert Level to mask if it isn't already one */
|
2007-12-25 10:45:14 +00:00
|
|
|
if (Level < 32)
|
|
|
|
Level = 1 << Level;
|
2008-05-15 20:43:26 +00:00
|
|
|
Level &= ~DPFLTR_MASK;
|
2007-12-25 10:45:14 +00:00
|
|
|
|
2008-01-08 09:51:53 +00:00
|
|
|
/* Check if it is the default component */
|
|
|
|
if (ComponentId == DPFLTR_DEFAULT_ID)
|
|
|
|
{
|
|
|
|
/* Yes, modify the default mask */
|
|
|
|
if (State)
|
|
|
|
Kd_DEFAULT_MASK |= Level;
|
|
|
|
else
|
|
|
|
Kd_DEFAULT_MASK &= ~Level;
|
|
|
|
|
|
|
|
return STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Search for an existing entry */
|
|
|
|
for (i = 0; i < KdComponentTableEntries; i++ )
|
|
|
|
{
|
|
|
|
if (ComponentId == KdComponentTable[i].ComponentId)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check if we have found an existing entry */
|
|
|
|
if (i == KdComponentTableEntries)
|
|
|
|
{
|
|
|
|
/* Check if we have enough space in the table */
|
|
|
|
if (i == MAX_KD_COMPONENT_TABLE_ENTRIES)
|
|
|
|
return STATUS_INVALID_PARAMETER_1;
|
|
|
|
|
|
|
|
/* Add a new entry */
|
|
|
|
++KdComponentTableEntries;
|
|
|
|
KdComponentTable[i].ComponentId = ComponentId;
|
|
|
|
KdComponentTable[i].Level = Kd_DEFAULT_MASK;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Update entry table */
|
|
|
|
if (State)
|
|
|
|
KdComponentTable[i].Level |= Level;
|
|
|
|
else
|
|
|
|
KdComponentTable[i].Level &= ~Level;
|
|
|
|
|
|
|
|
return STATUS_SUCCESS;
|
- More sharing between ntdll/ntoskrnl: shared Dbg code.
- Added NtCreateDebugObject, NtDebugContinue, NtQueryDebugFilterState, NtSetDebugFilterState, NtWaitForDebugEvent to system call list.
- Added some debug constants to headers
- Updated RtlpCheckForActiveDebugger in ntoskrnl to return whatever we're expecting as the "normal" case.
- Added RtlpSetInDbgPrint to rtl support library for special DbgPrint implementation difference in user-mode
- Removed all the deprecated debug APIs in ntdll.
- Implemented NtQueryDebugFilterState and NtSetDebugFilterState based on royce's implementation.
- Started modifications on KeDebugService, and implemented DebugService in rtl
- Implemented all the Dbg* APIs in RTL.
- Implemented DbgUiConnectToDbg, DbgUiContinue, DbgUiWaitStateChange, DbgUiRemoteBreakin, DbgUiIssueRemoteBreakin
- Changed KD Print callbacks to also receive the length of the string.
Right now, one call that should be shared still isn't (the final DebugPrint call) because calling KeDebugService from kernel-mode seems to cause a hang. Also, DebugService does not currently cause an exception like it should (instead it still calls the Kdp handler), because those changes would've made the patch even bigger and are still untested.
svn path=/trunk/; revision=18078
2005-09-26 04:59:48 +00:00
|
|
|
}
|
|
|
|
|
2007-03-04 19:54:39 +00:00
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
2007-03-04 19:20:03 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
KdSystemDebugControl(IN SYSDBG_COMMAND Command,
|
|
|
|
IN PVOID InputBuffer,
|
|
|
|
IN ULONG InputBufferLength,
|
|
|
|
OUT PVOID OutputBuffer,
|
|
|
|
IN ULONG OutputBufferLength,
|
|
|
|
IN OUT PULONG ReturnLength,
|
|
|
|
IN KPROCESSOR_MODE PreviousMode)
|
|
|
|
{
|
|
|
|
/* HACK */
|
|
|
|
return KdpServiceDispatcher(Command, InputBuffer, InputBufferLength);
|
|
|
|
}
|
|
|
|
|
2006-09-17 07:06:35 +00:00
|
|
|
PKDEBUG_ROUTINE KiDebugRoutine = KdpEnterDebuggerException;
|
|
|
|
|
2005-04-25 14:44:48 +00:00
|
|
|
/* EOF */
|