windows-nt/Source/XPSP1/NT/base/tools/kdexts2/ready.c

129 lines
3.3 KiB
C
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/*++
Copyright (c) 1992 Microsoft Corporation
Module Name:
ready.c
Abstract:
WinDbg Extension Api
Author:
Ramon J San Andres (ramonsa) 8-Nov-1993
Environment:
User Mode.
Revision History:
Jamie Hankins (a-jamhan) 20-Oct-1997 Added CheckControlC to loop.
--*/
#include "precomp.h"
#pragma hdrstop
DECLARE_API( ready )
/*++
Routine Description:
Arguments:
args -
Return Value:
None
--*/
{
ULONG64 KiDispatcherReadyListHead;
ULONG ListEntrySize, WaitListOpffset;
ULONG result;
DWORD Flags = 6;
LONG i;
BOOLEAN ThreadDumped = FALSE;
ULONG dwProcessor=0;
GetCurrentProcessor(Client, &dwProcessor, NULL);
Flags = (ULONG)GetExpression(args);
KiDispatcherReadyListHead = GetExpression( "nt!KiDispatcherReadyListHead" );
if ( KiDispatcherReadyListHead ) {
ListEntrySize = GetTypeSize("nt!_LIST_ENTRY");
if (ListEntrySize == 0) {
ListEntrySize = DBG_PTR_SIZE * 2;
}
GetFieldOffset("nt!_ETHREAD", "Tcb.WaitListEntry", &WaitListOpffset);
for (i = MAXIMUM_PRIORITY-1; i >= 0 ; i -= 1 ) {
ULONG64 Flink, Blink;
if ( GetFieldValue( KiDispatcherReadyListHead + i*ListEntrySize,
"nt!_LIST_ENTRY",
"Flink",
Flink) ) {
dprintf(
"Could not read contents of KiDispatcherReadyListHead at %08p [%ld]\n",
(KiDispatcherReadyListHead + i * ListEntrySize), i
);
return E_INVALIDARG;
}
if (Flink != KiDispatcherReadyListHead+i*ListEntrySize) {
ULONG64 ThreadEntry, ThreadFlink;
dprintf("Ready Threads at priority %ld\n", i);
for (ThreadEntry = Flink ;
ThreadEntry != KiDispatcherReadyListHead+i*ListEntrySize ;
ThreadEntry = ThreadFlink ) {
ULONG64 ThreadBaseAddress = (ThreadEntry - WaitListOpffset);
if ( GetFieldValue( ThreadBaseAddress,
"nt!_ETHREAD",
"Tcb.WaitListEntry.Flink",
ThreadFlink) ) {
dprintf("Could not read contents of thread %p\n", ThreadBaseAddress);
}
if(CheckControlC()) {
return E_INVALIDARG;
}
DumpThreadEx(dwProcessor," ", ThreadBaseAddress, Flags, Client);
ThreadDumped = TRUE;
}
} else {
GetFieldValue( KiDispatcherReadyListHead + i*ListEntrySize,
"nt!_LIST_ENTRY",
"Blink",
Blink);
if (Flink != Blink) {
dprintf("Ready linked list may to be corrupt...\n");
}
}
}
if (!ThreadDumped) {
dprintf("No threads in READY state\n");
}
} else {
dprintf("Could not determine address of KiDispatcherReadyListHead\n");
return E_INVALIDARG;
}
return S_OK;
}