1 /**
2  * This file has no copyright assigned and is placed in the Public Domain.
3  * This file is part of the mingw-w64 runtime package.
4  * No warranty is given; refer to the file DISCLAIMER.PD within this package.
5  */
6 #ifndef __DBGENG_H__
7 #define __DBGENG_H__
8 
9 #include <stdarg.h>
10 #include <objbase.h>
11 
12 #ifndef _WDBGEXTS_
13 typedef struct _WINDBG_EXTENSION_APIS32 *PWINDBG_EXTENSION_APIS32;
14 typedef struct _WINDBG_EXTENSION_APIS64 *PWINDBG_EXTENSION_APIS64;
15 #endif
16 
17 #ifndef _CRASHLIB_
18 typedef struct _MEMORY_BASIC_INFORMATION64 *PMEMORY_BASIC_INFORMATION64;
19 #endif
20 
21 #ifdef __cplusplus
22 extern "C" {
23 #endif
24 
25   DEFINE_GUID(IID_IDebugAdvanced,0xf2df5f53,0x071f,0x47bd,0x9d,0xe6,0x57,0x34,0xc3,0xfe,0xd6,0x89);
26   DEFINE_GUID(IID_IDebugBreakpoint,0x5bd9d474,0x5975,0x423a,0xb8,0x8b,0x65,0xa8,0xe7,0x11,0x0e,0x65);
27   DEFINE_GUID(IID_IDebugClient,0x27fe5639,0x8407,0x4f47,0x83,0x64,0xee,0x11,0x8f,0xb0,0x8a,0xc8);
28   DEFINE_GUID(IID_IDebugClient2,0xedbed635,0x372e,0x4dab,0xbb,0xfe,0xed,0x0d,0x2f,0x63,0xbe,0x81);
29   DEFINE_GUID(IID_IDebugClient3,0xdd492d7f,0x71b8,0x4ad6,0xa8,0xdc,0x1c,0x88,0x74,0x79,0xff,0x91);
30   DEFINE_GUID(IID_IDebugClient4,0xca83c3de,0x5089,0x4cf8,0x93,0xc8,0xd8,0x92,0x38,0x7f,0x2a,0x5e);
31   DEFINE_GUID(IID_IDebugControl,0x5182e668,0x105e,0x416e,0xad,0x92,0x24,0xef,0x80,0x04,0x24,0xba);
32   DEFINE_GUID(IID_IDebugControl2,0xd4366723,0x44df,0x4bed,0x8c,0x7e,0x4c,0x05,0x42,0x4f,0x45,0x88);
33   DEFINE_GUID(IID_IDebugControl3,0x7df74a86,0xb03f,0x407f,0x90,0xab,0xa2,0x0d,0xad,0xce,0xad,0x08);
34   DEFINE_GUID(IID_IDebugDataSpaces,0x88f7dfab,0x3ea7,0x4c3a,0xae,0xfb,0xc4,0xe8,0x10,0x61,0x73,0xaa);
35   DEFINE_GUID(IID_IDebugDataSpaces2,0x7a5e852f,0x96e9,0x468f,0xac,0x1b,0x0b,0x3a,0xdd,0xc4,0xa0,0x49);
36   DEFINE_GUID(IID_IDebugDataSpaces3,0x23f79d6c,0x8aaf,0x4f7c,0xa6,0x07,0x99,0x95,0xf5,0x40,0x7e,0x63);
37   DEFINE_GUID(IID_IDebugEventCallbacks,0x337be28b,0x5036,0x4d72,0xb6,0xbf,0xc4,0x5f,0xbb,0x9f,0x2e,0xaa);
38   DEFINE_GUID(IID_IDebugInputCallbacks,0x9f50e42c,0xf136,0x499e,0x9a,0x97,0x73,0x03,0x6c,0x94,0xed,0x2d);
39   DEFINE_GUID(IID_IDebugOutputCallbacks,0x4bf58045,0xd654,0x4c40,0xb0,0xaf,0x68,0x30,0x90,0xf3,0x56,0xdc);
40   DEFINE_GUID(IID_IDebugRegisters,0xce289126,0x9e84,0x45a7,0x93,0x7e,0x67,0xbb,0x18,0x69,0x14,0x93);
41   DEFINE_GUID(IID_IDebugSymbolGroup,0xf2528316,0x0f1a,0x4431,0xae,0xed,0x11,0xd0,0x96,0xe1,0xe2,0xab);
42   DEFINE_GUID(IID_IDebugSymbols,0x8c31e98c,0x983a,0x48a5,0x90,0x16,0x6f,0xe5,0xd6,0x67,0xa9,0x50);
43   DEFINE_GUID(IID_IDebugSymbols2,0x3a707211,0xafdd,0x4495,0xad,0x4f,0x56,0xfe,0xcd,0xf8,0x16,0x3f);
44   DEFINE_GUID(IID_IDebugSystemObjects,0x6b86fe2c,0x2c4f,0x4f0c,0x9d,0xa2,0x17,0x43,0x11,0xac,0xc3,0x27);
45   DEFINE_GUID(IID_IDebugSystemObjects2,0x0ae9f5ff,0x1852,0x4679,0xb0,0x55,0x49,0x4b,0xee,0x64,0x07,0xee);
46   DEFINE_GUID(IID_IDebugSystemObjects3,0xe9676e2f,0xe286,0x4ea3,0xb0,0xf9,0xdf,0xe5,0xd9,0xfc,0x33,0x0e);
47 
48   typedef struct IDebugAdvanced *PDEBUG_ADVANCED;
49   typedef struct IDebugBreakpoint *PDEBUG_BREAKPOINT;
50   typedef struct IDebugClient *PDEBUG_CLIENT;
51   typedef struct IDebugClient2 *PDEBUG_CLIENT2;
52   typedef struct IDebugClient3 *PDEBUG_CLIENT3;
53   typedef struct IDebugClient4 *PDEBUG_CLIENT4;
54   typedef struct IDebugControl *PDEBUG_CONTROL;
55   typedef struct IDebugControl2 *PDEBUG_CONTROL2;
56   typedef struct IDebugControl3 *PDEBUG_CONTROL3;
57   typedef struct IDebugDataSpaces *PDEBUG_DATA_SPACES;
58   typedef struct IDebugDataSpaces2 *PDEBUG_DATA_SPACES2;
59   typedef struct IDebugDataSpaces3 *PDEBUG_DATA_SPACES3;
60   typedef struct IDebugEventCallbacks *PDEBUG_EVENT_CALLBACKS;
61   typedef struct IDebugInputCallbacks *PDEBUG_INPUT_CALLBACKS;
62   typedef struct IDebugOutputCallbacks *PDEBUG_OUTPUT_CALLBACKS;
63   typedef struct IDebugRegisters *PDEBUG_REGISTERS;
64   typedef struct IDebugSymbolGroup *PDEBUG_SYMBOL_GROUP;
65   typedef struct IDebugSymbols *PDEBUG_SYMBOLS;
66   typedef struct IDebugSymbols2 *PDEBUG_SYMBOLS2;
67   typedef struct IDebugSystemObjects *PDEBUG_SYSTEM_OBJECTS;
68   typedef struct IDebugSystemObjects2 *PDEBUG_SYSTEM_OBJECTS2;
69   typedef struct IDebugSystemObjects3 *PDEBUG_SYSTEM_OBJECTS3;
70 
71 #define DEBUG_EXTEND64(Addr) ((ULONG64)(LONG64)(LONG)(Addr))
72 
73   STDAPI DebugConnect(PCSTR RemoteOptions,REFIID InterfaceId,PVOID *Interface);
74   STDAPI DebugCreate(REFIID InterfaceId,PVOID *Interface);
75 
76 #undef INTERFACE
77 #define INTERFACE IDebugAdvanced
DECLARE_INTERFACE_(IDebugAdvanced,IUnknown)78   DECLARE_INTERFACE_(IDebugAdvanced,IUnknown) {
79     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
80     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
81     STDMETHOD_(ULONG,Release)(THIS) PURE;
82     STDMETHOD(GetThreadContext)(THIS_ PVOID Context,ULONG ContextSize) PURE;
83     STDMETHOD(SetThreadContext)(THIS_ PVOID Context,ULONG ContextSize) PURE;
84   };
85 
86 #define DEBUG_BREAKPOINT_CODE 0
87 #define DEBUG_BREAKPOINT_DATA 1
88 
89 #define DEBUG_BREAKPOINT_GO_ONLY 0x00000001
90 #define DEBUG_BREAKPOINT_DEFERRED 0x00000002
91 #define DEBUG_BREAKPOINT_ENABLED 0x00000004
92 #define DEBUG_BREAKPOINT_ADDER_ONLY 0x00000008
93 #define DEBUG_BREAKPOINT_ONE_SHOT 0x00000010
94 
95 #define DEBUG_BREAK_READ 0x00000001
96 #define DEBUG_BREAK_WRITE 0x00000002
97 #define DEBUG_BREAK_EXECUTE 0x00000004
98 #define DEBUG_BREAK_IO 0x00000008
99 
100   typedef struct _DEBUG_BREAKPOINT_PARAMETERS {
101     ULONG64 Offset;
102     ULONG Id;
103     ULONG BreakType;
104     ULONG ProcType;
105     ULONG Flags;
106     ULONG DataSize;
107     ULONG DataAccessType;
108     ULONG PassCount;
109     ULONG CurrentPassCount;
110     ULONG MatchThread;
111     ULONG CommandSize;
112     ULONG OffsetExpressionSize;
113   } DEBUG_BREAKPOINT_PARAMETERS,*PDEBUG_BREAKPOINT_PARAMETERS;
114 
115 #undef INTERFACE
116 #define INTERFACE IDebugBreakpoint
DECLARE_INTERFACE_(IDebugBreakpoint,IUnknown)117   DECLARE_INTERFACE_(IDebugBreakpoint,IUnknown) {
118     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
119     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
120     STDMETHOD_(ULONG,Release)(THIS) PURE;
121     STDMETHOD(GetId)(THIS_ PULONG Id) PURE;
122     STDMETHOD(GetType)(THIS_ PULONG BreakType,PULONG ProcType) PURE;
123     STDMETHOD(GetAdder)(THIS_ PDEBUG_CLIENT *Adder) PURE;
124     STDMETHOD(GetFlags)(THIS_ PULONG Flags) PURE;
125     STDMETHOD(AddFlags)(THIS_ ULONG Flags) PURE;
126     STDMETHOD(RemoveFlags)(THIS_ ULONG Flags) PURE;
127     STDMETHOD(SetFlags)(THIS_ ULONG Flags) PURE;
128     STDMETHOD(GetOffset)(THIS_ PULONG64 Offset) PURE;
129     STDMETHOD(SetOffset)(THIS_ ULONG64 Offset) PURE;
130     STDMETHOD(GetDataParameters)(THIS_ PULONG Size,PULONG AccessType) PURE;
131     STDMETHOD(SetDataParameters)(THIS_ ULONG Size,ULONG AccessType) PURE;
132     STDMETHOD(GetPassCount)(THIS_ PULONG Count) PURE;
133     STDMETHOD(SetPassCount)(THIS_ ULONG Count) PURE;
134     STDMETHOD(GetCurrentPassCount)(THIS_ PULONG Count) PURE;
135     STDMETHOD(GetMatchThreadId)(THIS_ PULONG Id) PURE;
136     STDMETHOD(SetMatchThreadId)(THIS_ ULONG Thread) PURE;
137     STDMETHOD(GetCommand)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
138     STDMETHOD(SetCommand)(THIS_ PCSTR Command) PURE;
139     STDMETHOD(GetOffsetExpression)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG ExpressionSize) PURE;
140     STDMETHOD(SetOffsetExpression)(THIS_ PCSTR Expression) PURE;
141     STDMETHOD(GetParameters)(THIS_ PDEBUG_BREAKPOINT_PARAMETERS Params) PURE;
142   };
143 
144 #define DEBUG_ATTACH_KERNEL_CONNECTION 0x00000000
145 #define DEBUG_ATTACH_LOCAL_KERNEL 0x00000001
146 #define DEBUG_ATTACH_EXDI_DRIVER 0x00000002
147 
148 #define DEBUG_GET_PROC_DEFAULT 0x00000000
149 #define DEBUG_GET_PROC_FULL_MATCH 0x00000001
150 #define DEBUG_GET_PROC_ONLY_MATCH 0x00000002
151 
152 #define DEBUG_PROC_DESC_DEFAULT 0x00000000
153 #define DEBUG_PROC_DESC_NO_PATHS 0x00000001
154 #define DEBUG_PROC_DESC_NO_SERVICES 0x00000002
155 #define DEBUG_PROC_DESC_NO_MTS_PACKAGES 0x00000004
156 #define DEBUG_PROC_DESC_NO_COMMAND_LINE 0x00000008
157 
158 #define DEBUG_ATTACH_DEFAULT 0x00000000
159 #define DEBUG_ATTACH_NONINVASIVE 0x00000001
160 #define DEBUG_ATTACH_EXISTING 0x00000002
161 #define DEBUG_ATTACH_NONINVASIVE_NO_SUSPEND 0x00000004
162 #define DEBUG_ATTACH_INVASIVE_NO_INITIAL_BREAK 0x00000008
163 #define DEBUG_ATTACH_INVASIVE_RESUME_PROCESS 0x00000010
164 
165 #define DEBUG_CREATE_PROCESS_NO_DEBUG_HEAP CREATE_UNICODE_ENVIRONMENT
166 #define DEBUG_CREATE_PROCESS_THROUGH_RTL STACK_SIZE_PARAM_IS_A_RESERVATION
167 
168 #define DEBUG_PROCESS_DETACH_ON_EXIT 0x00000001
169 #define DEBUG_PROCESS_ONLY_THIS_PROCESS 0x00000002
170 
171 #define DEBUG_CONNECT_SESSION_DEFAULT 0x00000000
172 #define DEBUG_CONNECT_SESSION_NO_VERSION 0x00000001
173 #define DEBUG_CONNECT_SESSION_NO_ANNOUNCE 0x00000002
174 
175 #define DEBUG_SERVERS_DEBUGGER 0x00000001
176 #define DEBUG_SERVERS_PROCESS 0x00000002
177 #define DEBUG_SERVERS_ALL 0x00000003
178 
179 #define DEBUG_END_PASSIVE 0x00000000
180 #define DEBUG_END_ACTIVE_TERMINATE 0x00000001
181 #define DEBUG_END_ACTIVE_DETACH 0x00000002
182 #define DEBUG_END_REENTRANT 0x00000003
183 #define DEBUG_END_DISCONNECT 0x00000004
184 
185 #define DEBUG_OUTPUT_NORMAL 0x00000001
186 #define DEBUG_OUTPUT_ERROR 0x00000002
187 #define DEBUG_OUTPUT_WARNING 0x00000004
188 #define DEBUG_OUTPUT_VERBOSE 0x00000008
189 #define DEBUG_OUTPUT_PROMPT 0x00000010
190 #define DEBUG_OUTPUT_PROMPT_REGISTERS 0x00000020
191 #define DEBUG_OUTPUT_EXTENSION_WARNING 0x00000040
192 #define DEBUG_OUTPUT_DEBUGGEE 0x00000080
193 #define DEBUG_OUTPUT_DEBUGGEE_PROMPT 0x00000100
194 #define DEBUG_OUTPUT_SYMBOLS 0x00000200
195 
196 #define DEBUG_OUTPUT_IDENTITY_DEFAULT 0x00000000
197 
198 #define DEBUG_IOUTPUT_KD_PROTOCOL 0x80000000
199 #define DEBUG_IOUTPUT_REMOTING 0x40000000
200 #define DEBUG_IOUTPUT_BREAKPOINT 0x20000000
201 #define DEBUG_IOUTPUT_EVENT 0x10000000
202 
203 #undef INTERFACE
204 #define INTERFACE IDebugClient
DECLARE_INTERFACE_(IDebugClient,IUnknown)205   DECLARE_INTERFACE_(IDebugClient,IUnknown) {
206     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
207     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
208     STDMETHOD_(ULONG,Release)(THIS) PURE;
209     STDMETHOD(AttachKernel)(THIS_ ULONG Flags,PCSTR ConnectOptions) PURE;
210     STDMETHOD(GetKernelConnectionOptions)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG OptionsSize) PURE;
211     STDMETHOD(SetKernelConnectionOptions)(THIS_ PCSTR Options) PURE;
212     STDMETHOD(StartProcessServer)(THIS_ ULONG Flags,PCSTR Options,PVOID Reserved) PURE;
213     STDMETHOD(ConnectProcessServer)(THIS_ PCSTR RemoteOptions,PULONG64 Server) PURE;
214     STDMETHOD(DisconnectProcessServer)(THIS_ ULONG64 Server) PURE;
215     STDMETHOD(GetRunningProcessSystemIds)(THIS_ ULONG64 Server,PULONG Ids,ULONG Count,PULONG ActualCount) PURE;
216     STDMETHOD(GetRunningProcessSystemIdByExecutableName)(THIS_ ULONG64 Server,PCSTR ExeName,ULONG Flags,PULONG Id) PURE;
217     STDMETHOD(GetRunningProcessDescription)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
218     STDMETHOD(AttachProcess)(THIS_ ULONG64 Server,ULONG ProcessId,ULONG AttachFlags) PURE;
219     STDMETHOD(CreateProcess)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags) PURE;
220     STDMETHOD(CreateProcessAndAttach)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
221     STDMETHOD(GetProcessOptions)(THIS_ PULONG Options) PURE;
222     STDMETHOD(AddProcessOptions)(THIS_ ULONG Options) PURE;
223     STDMETHOD(RemoveProcessOptions)(THIS_ ULONG Options) PURE;
224     STDMETHOD(SetProcessOptions)(THIS_ ULONG Options) PURE;
225     STDMETHOD(OpenDumpFile)(THIS_ PCSTR DumpFile) PURE;
226     STDMETHOD(WriteDumpFile)(THIS_ PCSTR DumpFile,ULONG Qualifier) PURE;
227     STDMETHOD(ConnectSession)(THIS_ ULONG Flags,ULONG HistoryLimit) PURE;
228     STDMETHOD(StartServer)(THIS_ PCSTR Options) PURE;
229     STDMETHOD(OutputServers)(THIS_ ULONG OutputControl,PCSTR Machine,ULONG Flags) PURE;
230     STDMETHOD(TerminateProcesses)(THIS) PURE;
231     STDMETHOD(DetachProcesses)(THIS) PURE;
232     STDMETHOD(EndSession)(THIS_ ULONG Flags) PURE;
233     STDMETHOD(GetExitCode)(THIS_ PULONG Code) PURE;
234     STDMETHOD(DispatchCallbacks)(THIS_ ULONG Timeout) PURE;
235     STDMETHOD(ExitDispatch)(THIS_ PDEBUG_CLIENT Client) PURE;
236     STDMETHOD(CreateClient)(THIS_ PDEBUG_CLIENT *Client) PURE;
237     STDMETHOD(GetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS *Callbacks) PURE;
238     STDMETHOD(SetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS Callbacks) PURE;
239     STDMETHOD(GetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS *Callbacks) PURE;
240     STDMETHOD(SetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS Callbacks) PURE;
241     STDMETHOD(GetOutputMask)(THIS_ PULONG Mask) PURE;
242     STDMETHOD(SetOutputMask)(THIS_ ULONG Mask) PURE;
243     STDMETHOD(GetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,PULONG Mask) PURE;
244     STDMETHOD(SetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,ULONG Mask) PURE;
245     STDMETHOD(GetOutputWidth)(THIS_ PULONG Columns) PURE;
246     STDMETHOD(SetOutputWidth)(THIS_ ULONG Columns) PURE;
247     STDMETHOD(GetOutputLinePrefix)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PrefixSize) PURE;
248     STDMETHOD(SetOutputLinePrefix)(THIS_ PCSTR Prefix) PURE;
249     STDMETHOD(GetIdentity)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG IdentitySize) PURE;
250     STDMETHOD(OutputIdentity)(THIS_ ULONG OutputControl,ULONG Flags,PCSTR Format) PURE;
251     STDMETHOD(GetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS *Callbacks) PURE;
252     STDMETHOD(SetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS Callbacks) PURE;
253     STDMETHOD(FlushCallbacks)(THIS) PURE;
254   };
255 
256 #define DEBUG_FORMAT_DEFAULT 0x00000000
257 #define DEBUG_FORMAT_WRITE_CAB 0x20000000
258 #define DEBUG_FORMAT_CAB_SECONDARY_FILES 0x40000000
259 #define DEBUG_FORMAT_NO_OVERWRITE 0x80000000
260 #define DEBUG_FORMAT_USER_SMALL_FULL_MEMORY 0x00000001
261 #define DEBUG_FORMAT_USER_SMALL_HANDLE_DATA 0x00000002
262 #define DEBUG_FORMAT_USER_SMALL_UNLOADED_MODULES 0x00000004
263 #define DEBUG_FORMAT_USER_SMALL_INDIRECT_MEMORY 0x00000008
264 #define DEBUG_FORMAT_USER_SMALL_DATA_SEGMENTS 0x00000010
265 #define DEBUG_FORMAT_USER_SMALL_FILTER_MEMORY 0x00000020
266 #define DEBUG_FORMAT_USER_SMALL_FILTER_PATHS 0x00000040
267 #define DEBUG_FORMAT_USER_SMALL_PROCESS_THREAD_DATA 0x00000080
268 #define DEBUG_FORMAT_USER_SMALL_PRIVATE_READ_WRITE_MEMORY 0x00000100
269 
270 #define DEBUG_DUMP_FILE_BASE 0xffffffff
271 #define DEBUG_DUMP_FILE_PAGE_FILE_DUMP 0x00000000
272 #define DEBUG_DUMP_FILE_LOAD_FAILED_INDEX 0xffffffff
273 
274 #undef INTERFACE
275 #define INTERFACE IDebugClient2
DECLARE_INTERFACE_(IDebugClient2,IUnknown)276   DECLARE_INTERFACE_(IDebugClient2,IUnknown) {
277     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
278     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
279     STDMETHOD_(ULONG,Release)(THIS) PURE;
280     STDMETHOD(AttachKernel)(THIS_ ULONG Flags,PCSTR ConnectOptions) PURE;
281     STDMETHOD(GetKernelConnectionOptions)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG OptionsSize) PURE;
282     STDMETHOD(SetKernelConnectionOptions)(THIS_ PCSTR Options) PURE;
283     STDMETHOD(StartProcessServer)(THIS_ ULONG Flags,PCSTR Options,PVOID Reserved) PURE;
284     STDMETHOD(ConnectProcessServer)(THIS_ PCSTR RemoteOptions,PULONG64 Server) PURE;
285     STDMETHOD(DisconnectProcessServer)(THIS_ ULONG64 Server) PURE;
286     STDMETHOD(GetRunningProcessSystemIds)(THIS_ ULONG64 Server,PULONG Ids,ULONG Count,PULONG ActualCount) PURE;
287     STDMETHOD(GetRunningProcessSystemIdByExecutableName)(THIS_ ULONG64 Server,PCSTR ExeName,ULONG Flags,PULONG Id) PURE;
288     STDMETHOD(GetRunningProcessDescription)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
289     STDMETHOD(AttachProcess)(THIS_ ULONG64 Server,ULONG ProcessId,ULONG AttachFlags) PURE;
290     STDMETHOD(CreateProcess)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags) PURE;
291     STDMETHOD(CreateProcessAndAttach)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
292     STDMETHOD(GetProcessOptions)(THIS_ PULONG Options) PURE;
293     STDMETHOD(AddProcessOptions)(THIS_ ULONG Options) PURE;
294     STDMETHOD(RemoveProcessOptions)(THIS_ ULONG Options) PURE;
295     STDMETHOD(SetProcessOptions)(THIS_ ULONG Options) PURE;
296     STDMETHOD(OpenDumpFile)(THIS_ PCSTR DumpFile) PURE;
297     STDMETHOD(WriteDumpFile)(THIS_ PCSTR DumpFile,ULONG Qualifier) PURE;
298     STDMETHOD(ConnectSession)(THIS_ ULONG Flags,ULONG HistoryLimit) PURE;
299     STDMETHOD(StartServer)(THIS_ PCSTR Options) PURE;
300     STDMETHOD(OutputServers)(THIS_ ULONG OutputControl,PCSTR Machine,ULONG Flags) PURE;
301     STDMETHOD(TerminateProcesses)(THIS) PURE;
302     STDMETHOD(DetachProcesses)(THIS) PURE;
303     STDMETHOD(EndSession)(THIS_ ULONG Flags) PURE;
304     STDMETHOD(GetExitCode)(THIS_ PULONG Code) PURE;
305     STDMETHOD(DispatchCallbacks)(THIS_ ULONG Timeout) PURE;
306     STDMETHOD(ExitDispatch)(THIS_ PDEBUG_CLIENT Client) PURE;
307     STDMETHOD(CreateClient)(THIS_ PDEBUG_CLIENT *Client) PURE;
308     STDMETHOD(GetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS *Callbacks) PURE;
309     STDMETHOD(SetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS Callbacks) PURE;
310     STDMETHOD(GetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS *Callbacks) PURE;
311     STDMETHOD(SetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS Callbacks) PURE;
312     STDMETHOD(GetOutputMask)(THIS_ PULONG Mask) PURE;
313     STDMETHOD(SetOutputMask)(THIS_ ULONG Mask) PURE;
314     STDMETHOD(GetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,PULONG Mask) PURE;
315     STDMETHOD(SetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,ULONG Mask) PURE;
316     STDMETHOD(GetOutputWidth)(THIS_ PULONG Columns) PURE;
317     STDMETHOD(SetOutputWidth)(THIS_ ULONG Columns) PURE;
318     STDMETHOD(GetOutputLinePrefix)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PrefixSize) PURE;
319     STDMETHOD(SetOutputLinePrefix)(THIS_ PCSTR Prefix) PURE;
320     STDMETHOD(GetIdentity)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG IdentitySize) PURE;
321     STDMETHOD(OutputIdentity)(THIS_ ULONG OutputControl,ULONG Flags,PCSTR Format) PURE;
322     STDMETHOD(GetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS *Callbacks) PURE;
323     STDMETHOD(SetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS Callbacks) PURE;
324     STDMETHOD(FlushCallbacks)(THIS) PURE;
325     STDMETHOD(WriteDumpFile2)(THIS_ PCSTR DumpFile,ULONG Qualifier,ULONG FormatFlags,PCSTR Comment) PURE;
326     STDMETHOD(AddDumpInformationFile)(THIS_ PCSTR InfoFile,ULONG Type) PURE;
327     STDMETHOD(EndProcessServer)(THIS_ ULONG64 Server) PURE;
328     STDMETHOD(WaitForProcessServerEnd)(THIS_ ULONG Timeout) PURE;
329     STDMETHOD(IsKernelDebuggerEnabled)(THIS) PURE;
330     STDMETHOD(TerminateCurrentProcess)(THIS) PURE;
331     STDMETHOD(DetachCurrentProcess)(THIS) PURE;
332     STDMETHOD(AbandonCurrentProcess)(THIS) PURE;
333   };
334 
335 #undef INTERFACE
336 #define INTERFACE IDebugClient3
DECLARE_INTERFACE_(IDebugClient3,IUnknown)337   DECLARE_INTERFACE_(IDebugClient3,IUnknown) {
338     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
339     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
340     STDMETHOD_(ULONG,Release)(THIS) PURE;
341     STDMETHOD(AttachKernel)(THIS_
342       ULONG Flags,PCSTR ConnectOptions) PURE;
343     STDMETHOD(GetKernelConnectionOptions)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG OptionsSize) PURE;
344     STDMETHOD(SetKernelConnectionOptions)(THIS_ PCSTR Options) PURE;
345     STDMETHOD(StartProcessServer)(THIS_ ULONG Flags,PCSTR Options,PVOID Reserved) PURE;
346     STDMETHOD(ConnectProcessServer)(THIS_ PCSTR RemoteOptions,PULONG64 Server) PURE;
347     STDMETHOD(DisconnectProcessServer)(THIS_ ULONG64 Server) PURE;
348     STDMETHOD(GetRunningProcessSystemIds)(THIS_ ULONG64 Server,PULONG Ids,ULONG Count,PULONG ActualCount) PURE;
349     STDMETHOD(GetRunningProcessSystemIdByExecutableName)(THIS_ ULONG64 Server,PCSTR ExeName,ULONG Flags,PULONG Id) PURE;
350     STDMETHOD(GetRunningProcessDescription)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
351     STDMETHOD(AttachProcess)(THIS_ ULONG64 Server,ULONG ProcessId,ULONG AttachFlags) PURE;
352     STDMETHOD(CreateProcess)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags) PURE;
353     STDMETHOD(CreateProcessAndAttach)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
354     STDMETHOD(GetProcessOptions)(THIS_ PULONG Options) PURE;
355     STDMETHOD(AddProcessOptions)(THIS_ ULONG Options) PURE;
356     STDMETHOD(RemoveProcessOptions)(THIS_ ULONG Options) PURE;
357     STDMETHOD(SetProcessOptions)(THIS_ ULONG Options) PURE;
358     STDMETHOD(OpenDumpFile)(THIS_ PCSTR DumpFile) PURE;
359     STDMETHOD(WriteDumpFile)(THIS_ PCSTR DumpFile,ULONG Qualifier) PURE;
360     STDMETHOD(ConnectSession)(THIS_ ULONG Flags,ULONG HistoryLimit) PURE;
361     STDMETHOD(StartServer)(THIS_ PCSTR Options) PURE;
362     STDMETHOD(OutputServers)(THIS_ ULONG OutputControl,PCSTR Machine,ULONG Flags) PURE;
363     STDMETHOD(TerminateProcesses)(THIS) PURE;
364     STDMETHOD(DetachProcesses)(THIS) PURE;
365     STDMETHOD(EndSession)(THIS_ ULONG Flags) PURE;
366     STDMETHOD(GetExitCode)(THIS_ PULONG Code) PURE;
367     STDMETHOD(DispatchCallbacks)(THIS_ ULONG Timeout) PURE;
368     STDMETHOD(ExitDispatch)(THIS_ PDEBUG_CLIENT Client) PURE;
369     STDMETHOD(CreateClient)(THIS_ PDEBUG_CLIENT *Client) PURE;
370     STDMETHOD(GetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS *Callbacks) PURE;
371     STDMETHOD(SetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS Callbacks) PURE;
372     STDMETHOD(GetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS *Callbacks) PURE;
373     STDMETHOD(SetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS Callbacks) PURE;
374     STDMETHOD(GetOutputMask)(THIS_ PULONG Mask) PURE;
375     STDMETHOD(SetOutputMask)(THIS_ ULONG Mask) PURE;
376     STDMETHOD(GetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,PULONG Mask) PURE;
377     STDMETHOD(SetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,ULONG Mask) PURE;
378     STDMETHOD(GetOutputWidth)(THIS_ PULONG Columns) PURE;
379     STDMETHOD(SetOutputWidth)(THIS_ ULONG Columns) PURE;
380     STDMETHOD(GetOutputLinePrefix)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PrefixSize) PURE;
381     STDMETHOD(SetOutputLinePrefix)(THIS_ PCSTR Prefix) PURE;
382     STDMETHOD(GetIdentity)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG IdentitySize) PURE;
383     STDMETHOD(OutputIdentity)(THIS_ ULONG OutputControl,ULONG Flags,PCSTR Format) PURE;
384     STDMETHOD(GetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS *Callbacks) PURE;
385     STDMETHOD(SetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS Callbacks) PURE;
386     STDMETHOD(FlushCallbacks)(THIS) PURE;
387     STDMETHOD(WriteDumpFile2)(THIS_ PCSTR DumpFile,ULONG Qualifier,ULONG FormatFlags,PCSTR Comment) PURE;
388     STDMETHOD(AddDumpInformationFile)(THIS_ PCSTR InfoFile,ULONG Type) PURE;
389     STDMETHOD(EndProcessServer)(THIS_ ULONG64 Server) PURE;
390     STDMETHOD(WaitForProcessServerEnd)(THIS_ ULONG Timeout) PURE;
391     STDMETHOD(IsKernelDebuggerEnabled)(THIS) PURE;
392     STDMETHOD(TerminateCurrentProcess)(THIS) PURE;
393     STDMETHOD(DetachCurrentProcess)(THIS) PURE;
394     STDMETHOD(AbandonCurrentProcess)(THIS) PURE;
395     STDMETHOD(GetRunningProcessSystemIdByExecutableNameWide)(THIS_ ULONG64 Server,PCWSTR ExeName,ULONG Flags,PULONG Id) PURE;
396     STDMETHOD(GetRunningProcessDescriptionWide)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PWSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PWSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
397     STDMETHOD(CreateProcessWide)(THIS_ ULONG64 Server,PWSTR CommandLine,ULONG CreateFlags) PURE;
398     STDMETHOD(CreateProcessAndAttachWide)(THIS_ ULONG64 Server,PWSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
399   };
400 
401 #undef INTERFACE
402 #define INTERFACE IDebugClient4
DECLARE_INTERFACE_(IDebugClient4,IUnknown)403   DECLARE_INTERFACE_(IDebugClient4,IUnknown) {
404     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
405     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
406     STDMETHOD_(ULONG,Release)(THIS) PURE;
407     STDMETHOD(AttachKernel)(THIS_ ULONG Flags,PCSTR ConnectOptions) PURE;
408     STDMETHOD(GetKernelConnectionOptions)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG OptionsSize) PURE;
409     STDMETHOD(SetKernelConnectionOptions)(THIS_ PCSTR Options) PURE;
410     STDMETHOD(StartProcessServer)(THIS_ ULONG Flags,PCSTR Options,PVOID Reserved) PURE;
411     STDMETHOD(ConnectProcessServer)(THIS_ PCSTR RemoteOptions,PULONG64 Server) PURE;
412     STDMETHOD(DisconnectProcessServer)(THIS_ ULONG64 Server) PURE;
413     STDMETHOD(GetRunningProcessSystemIds)(THIS_ ULONG64 Server,PULONG Ids,ULONG Count,PULONG ActualCount) PURE;
414     STDMETHOD(GetRunningProcessSystemIdByExecutableName)(THIS_ ULONG64 Server,PCSTR ExeName,ULONG Flags,PULONG Id) PURE;
415     STDMETHOD(GetRunningProcessDescription)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
416     STDMETHOD(AttachProcess)(THIS_ ULONG64 Server,ULONG ProcessId,ULONG AttachFlags) PURE;
417     STDMETHOD(CreateProcess)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags) PURE;
418     STDMETHOD(CreateProcessAndAttach)(THIS_ ULONG64 Server,PSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
419     STDMETHOD(GetProcessOptions)(THIS_ PULONG Options) PURE;
420     STDMETHOD(AddProcessOptions)(THIS_ ULONG Options) PURE;
421     STDMETHOD(RemoveProcessOptions)(THIS_ ULONG Options) PURE;
422     STDMETHOD(SetProcessOptions)(THIS_ ULONG Options) PURE;
423     STDMETHOD(OpenDumpFile)(THIS_ PCSTR DumpFile) PURE;
424     STDMETHOD(WriteDumpFile)(THIS_ PCSTR DumpFile,ULONG Qualifier) PURE;
425     STDMETHOD(ConnectSession)(THIS_ ULONG Flags,ULONG HistoryLimit) PURE;
426     STDMETHOD(StartServer)(THIS_ PCSTR Options) PURE;
427     STDMETHOD(OutputServers)(THIS_ ULONG OutputControl,PCSTR Machine,ULONG Flags) PURE;
428     STDMETHOD(TerminateProcesses)(THIS) PURE;
429     STDMETHOD(DetachProcesses)(THIS) PURE;
430     STDMETHOD(EndSession)(THIS_ ULONG Flags) PURE;
431     STDMETHOD(GetExitCode)(THIS_ PULONG Code) PURE;
432     STDMETHOD(DispatchCallbacks)(THIS_ ULONG Timeout) PURE;
433     STDMETHOD(ExitDispatch)(THIS_ PDEBUG_CLIENT Client) PURE;
434     STDMETHOD(CreateClient)(THIS_ PDEBUG_CLIENT *Client) PURE;
435     STDMETHOD(GetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS *Callbacks) PURE;
436     STDMETHOD(SetInputCallbacks)(THIS_ PDEBUG_INPUT_CALLBACKS Callbacks) PURE;
437     STDMETHOD(GetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS *Callbacks) PURE;
438     STDMETHOD(SetOutputCallbacks)(THIS_ PDEBUG_OUTPUT_CALLBACKS Callbacks) PURE;
439     STDMETHOD(GetOutputMask)(THIS_ PULONG Mask) PURE;
440     STDMETHOD(SetOutputMask)(THIS_ ULONG Mask) PURE;
441     STDMETHOD(GetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,PULONG Mask) PURE;
442     STDMETHOD(SetOtherOutputMask)(THIS_ PDEBUG_CLIENT Client,ULONG Mask) PURE;
443     STDMETHOD(GetOutputWidth)(THIS_ PULONG Columns) PURE;
444     STDMETHOD(SetOutputWidth)(THIS_ ULONG Columns) PURE;
445     STDMETHOD(GetOutputLinePrefix)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PrefixSize) PURE;
446     STDMETHOD(SetOutputLinePrefix)(THIS_ PCSTR Prefix) PURE;
447     STDMETHOD(GetIdentity)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG IdentitySize) PURE;
448     STDMETHOD(OutputIdentity)(THIS_ ULONG OutputControl,ULONG Flags,PCSTR Format) PURE;
449     STDMETHOD(GetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS *Callbacks) PURE;
450     STDMETHOD(SetEventCallbacks)(THIS_ PDEBUG_EVENT_CALLBACKS Callbacks) PURE;
451     STDMETHOD(FlushCallbacks)(THIS) PURE;
452     STDMETHOD(WriteDumpFile2)(THIS_ PCSTR DumpFile,ULONG Qualifier,ULONG FormatFlags,PCSTR Comment) PURE;
453     STDMETHOD(AddDumpInformationFile)(THIS_ PCSTR InfoFile,ULONG Type) PURE;
454     STDMETHOD(EndProcessServer)(THIS_ ULONG64 Server) PURE;
455     STDMETHOD(WaitForProcessServerEnd)(THIS_ ULONG Timeout) PURE;
456     STDMETHOD(IsKernelDebuggerEnabled)(THIS) PURE;
457     STDMETHOD(TerminateCurrentProcess)(THIS) PURE;
458     STDMETHOD(DetachCurrentProcess)(THIS) PURE;
459     STDMETHOD(AbandonCurrentProcess)(THIS) PURE;
460     STDMETHOD(GetRunningProcessSystemIdByExecutableNameWide)(THIS_ ULONG64 Server,PCWSTR ExeName,ULONG Flags,PULONG Id) PURE;
461     STDMETHOD(GetRunningProcessDescriptionWide)(THIS_ ULONG64 Server,ULONG SystemId,ULONG Flags,PWSTR ExeName,ULONG ExeNameSize,PULONG ActualExeNameSize,PWSTR Description,ULONG DescriptionSize,PULONG ActualDescriptionSize) PURE;
462     STDMETHOD(CreateProcessWide)(THIS_ ULONG64 Server,PWSTR CommandLine,ULONG CreateFlags) PURE;
463     STDMETHOD(CreateProcessAndAttachWide)(THIS_ ULONG64 Server,PWSTR CommandLine,ULONG CreateFlags,ULONG ProcessId,ULONG AttachFlags) PURE;
464     STDMETHOD(OpenDumpFileWide)(THIS_ PCWSTR FileName,ULONG64 FileHandle) PURE;
465     STDMETHOD(WriteDumpFileWide)(THIS_ PCWSTR FileName,ULONG64 FileHandle,ULONG Qualifier,ULONG FormatFlags,PCWSTR Comment) PURE;
466     STDMETHOD(AddDumpInformationFileWide)(THIS_ PCWSTR FileName,ULONG64 FileHandle,ULONG Type) PURE;
467     STDMETHOD(GetNumberDumpFiles)(THIS_ PULONG Number) PURE;
468     STDMETHOD(GetDumpFile)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG NameSize,PULONG64 Handle,PULONG Type) PURE;
469     STDMETHOD(GetDumpFileWide)(THIS_ ULONG Index,PWSTR Buffer,ULONG BufferSize,PULONG NameSize,PULONG64 Handle,PULONG Type) PURE;
470   };
471 
472 #define DEBUG_STATUS_NO_CHANGE 0
473 #define DEBUG_STATUS_GO 1
474 #define DEBUG_STATUS_GO_HANDLED 2
475 #define DEBUG_STATUS_GO_NOT_HANDLED 3
476 #define DEBUG_STATUS_STEP_OVER 4
477 #define DEBUG_STATUS_STEP_INTO 5
478 #define DEBUG_STATUS_BREAK 6
479 #define DEBUG_STATUS_NO_DEBUGGEE 7
480 #define DEBUG_STATUS_STEP_BRANCH 8
481 #define DEBUG_STATUS_IGNORE_EVENT 9
482 
483 #define DEBUG_STATUS_MASK 0xf
484 
485 #define DEBUG_STATUS_INSIDE_WAIT 0x100000000
486 #define DEBUG_OUTCTL_THIS_CLIENT 0x00000000
487 #define DEBUG_OUTCTL_ALL_CLIENTS 0x00000001
488 #define DEBUG_OUTCTL_ALL_OTHER_CLIENTS 0x00000002
489 #define DEBUG_OUTCTL_IGNORE 0x00000003
490 #define DEBUG_OUTCTL_LOG_ONLY 0x00000004
491 #define DEBUG_OUTCTL_SEND_MASK 0x00000007
492 #define DEBUG_OUTCTL_NOT_LOGGED 0x00000008
493 #define DEBUG_OUTCTL_OVERRIDE_MASK 0x00000010
494 #define DEBUG_OUTCTL_AMBIENT 0xffffffff
495 
496 #define DEBUG_INTERRUPT_ACTIVE 0
497 #define DEBUG_INTERRUPT_PASSIVE 1
498 #define DEBUG_INTERRUPT_EXIT 2
499 
500 #define DEBUG_CURRENT_DEFAULT 0x0000000f
501 #define DEBUG_CURRENT_SYMBOL 0x00000001
502 #define DEBUG_CURRENT_DISASM 0x00000002
503 #define DEBUG_CURRENT_REGISTERS 0x00000004
504 #define DEBUG_CURRENT_SOURCE_LINE 0x00000008
505 
506 #define DEBUG_DISASM_EFFECTIVE_ADDRESS 0x00000001
507 #define DEBUG_DISASM_MATCHING_SYMBOLS 0x00000002
508 
509 #define DEBUG_LEVEL_SOURCE 0
510 #define DEBUG_LEVEL_ASSEMBLY 1
511 
512 #define DEBUG_ENGOPT_IGNORE_DBGHELP_VERSION 0x00000001
513 #define DEBUG_ENGOPT_IGNORE_EXTENSION_VERSIONS 0x00000002
514 
515 #define DEBUG_ENGOPT_ALLOW_NETWORK_PATHS 0x00000004
516 #define DEBUG_ENGOPT_DISALLOW_NETWORK_PATHS 0x00000008
517 #define DEBUG_ENGOPT_NETWORK_PATHS (0x00000004 | 0x00000008)
518 #define DEBUG_ENGOPT_IGNORE_LOADER_EXCEPTIONS 0x00000010
519 #define DEBUG_ENGOPT_INITIAL_BREAK 0x00000020
520 #define DEBUG_ENGOPT_INITIAL_MODULE_BREAK 0x00000040
521 #define DEBUG_ENGOPT_FINAL_BREAK 0x00000080
522 #define DEBUG_ENGOPT_NO_EXECUTE_REPEAT 0x00000100
523 #define DEBUG_ENGOPT_FAIL_INCOMPLETE_INFORMATION 0x00000200
524 #define DEBUG_ENGOPT_ALLOW_READ_ONLY_BREAKPOINTS 0x00000400
525 #define DEBUG_ENGOPT_SYNCHRONIZE_BREAKPOINTS 0x00000800
526 #define DEBUG_ENGOPT_DISALLOW_SHELL_COMMANDS 0x00001000
527 #define DEBUG_ENGOPT_ALL 0x00001FFF
528 
529 #define DEBUG_ANY_ID 0xffffffff
530 
531   typedef struct _DEBUG_STACK_FRAME {
532     ULONG64 InstructionOffset;
533     ULONG64 ReturnOffset;
534     ULONG64 FrameOffset;
535     ULONG64 StackOffset;
536     ULONG64 FuncTableEntry;
537     ULONG64 Params[4];
538     ULONG64 Reserved[6];
539     WINBOOL Virtual;
540     ULONG FrameNumber;
541   } DEBUG_STACK_FRAME,*PDEBUG_STACK_FRAME;
542 
543 #define DEBUG_STACK_ARGUMENTS 0x00000001
544 #define DEBUG_STACK_FUNCTION_INFO 0x00000002
545 #define DEBUG_STACK_SOURCE_LINE 0x00000004
546 #define DEBUG_STACK_FRAME_ADDRESSES 0x00000008
547 #define DEBUG_STACK_COLUMN_NAMES 0x00000010
548 #define DEBUG_STACK_NONVOLATILE_REGISTERS 0x00000020
549 #define DEBUG_STACK_FRAME_NUMBERS 0x00000040
550 #define DEBUG_STACK_PARAMETERS 0x00000080
551 #define DEBUG_STACK_FRAME_ADDRESSES_RA_ONLY 0x00000100
552 #define DEBUG_STACK_FRAME_MEMORY_USAGE 0x00000200
553 
554 #define DEBUG_CLASS_UNINITIALIZED 0
555 #define DEBUG_CLASS_KERNEL 1
556 #define DEBUG_CLASS_USER_WINDOWS 2
557 
558 #define DEBUG_DUMP_SMALL 1024
559 #define DEBUG_DUMP_DEFAULT 1025
560 #define DEBUG_DUMP_FULL 1026
561 
562 #define DEBUG_KERNEL_CONNECTION 0
563 #define DEBUG_KERNEL_LOCAL 1
564 #define DEBUG_KERNEL_EXDI_DRIVER 2
565 #define DEBUG_KERNEL_SMALL_DUMP DEBUG_DUMP_SMALL
566 #define DEBUG_KERNEL_DUMP DEBUG_DUMP_DEFAULT
567 #define DEBUG_KERNEL_FULL_DUMP DEBUG_DUMP_FULL
568 
569 #define DEBUG_USER_WINDOWS_PROCESS 0
570 #define DEBUG_USER_WINDOWS_PROCESS_SERVER 1
571 #define DEBUG_USER_WINDOWS_SMALL_DUMP DEBUG_DUMP_SMALL
572 #define DEBUG_USER_WINDOWS_DUMP DEBUG_DUMP_DEFAULT
573 
574 #define DEBUG_EXTENSION_AT_ENGINE 0x00000000
575 
576 #define DEBUG_EXECUTE_DEFAULT 0x00000000
577 #define DEBUG_EXECUTE_ECHO 0x00000001
578 #define DEBUG_EXECUTE_NOT_LOGGED 0x00000002
579 #define DEBUG_EXECUTE_NO_REPEAT 0x00000004
580 
581 #define DEBUG_FILTER_CREATE_THREAD 0x00000000
582 #define DEBUG_FILTER_EXIT_THREAD 0x00000001
583 #define DEBUG_FILTER_CREATE_PROCESS 0x00000002
584 #define DEBUG_FILTER_EXIT_PROCESS 0x00000003
585 #define DEBUG_FILTER_LOAD_MODULE 0x00000004
586 #define DEBUG_FILTER_UNLOAD_MODULE 0x00000005
587 #define DEBUG_FILTER_SYSTEM_ERROR 0x00000006
588 #define DEBUG_FILTER_INITIAL_BREAKPOINT 0x00000007
589 #define DEBUG_FILTER_INITIAL_MODULE_LOAD 0x00000008
590 #define DEBUG_FILTER_DEBUGGEE_OUTPUT 0x00000009
591 
592 #define DEBUG_FILTER_BREAK 0x00000000
593 
594 #define DEBUG_FILTER_SECOND_CHANCE_BREAK 0x00000001
595 #define DEBUG_FILTER_OUTPUT 0x00000002
596 #define DEBUG_FILTER_IGNORE 0x00000003
597 #define DEBUG_FILTER_REMOVE 0x00000004
598 
599 #define DEBUG_FILTER_GO_HANDLED 0x00000000
600 #define DEBUG_FILTER_GO_NOT_HANDLED 0x00000001
601 
602   typedef struct _DEBUG_SPECIFIC_FILTER_PARAMETERS {
603     ULONG ExecutionOption;
604     ULONG ContinueOption;
605     ULONG TextSize;
606     ULONG CommandSize;
607     ULONG ArgumentSize;
608   } DEBUG_SPECIFIC_FILTER_PARAMETERS,*PDEBUG_SPECIFIC_FILTER_PARAMETERS;
609 
610   typedef struct _DEBUG_EXCEPTION_FILTER_PARAMETERS {
611     ULONG ExecutionOption;
612     ULONG ContinueOption;
613     ULONG TextSize;
614     ULONG CommandSize;
615     ULONG SecondCommandSize;
616     ULONG ExceptionCode;
617   } DEBUG_EXCEPTION_FILTER_PARAMETERS,*PDEBUG_EXCEPTION_FILTER_PARAMETERS;
618 
619 #define DEBUG_WAIT_DEFAULT 0x00000000
620 
621   typedef struct _DEBUG_LAST_EVENT_INFO_BREAKPOINT {
622     ULONG Id;
623   } DEBUG_LAST_EVENT_INFO_BREAKPOINT,*PDEBUG_LAST_EVENT_INFO_BREAKPOINT;
624 
625   typedef struct _DEBUG_LAST_EVENT_INFO_EXCEPTION {
626     EXCEPTION_RECORD64 ExceptionRecord;
627     ULONG FirstChance;
628   } DEBUG_LAST_EVENT_INFO_EXCEPTION,*PDEBUG_LAST_EVENT_INFO_EXCEPTION;
629 
630   typedef struct _DEBUG_LAST_EVENT_INFO_EXIT_THREAD {
631     ULONG ExitCode;
632   } DEBUG_LAST_EVENT_INFO_EXIT_THREAD,*PDEBUG_LAST_EVENT_INFO_EXIT_THREAD;
633 
634   typedef struct _DEBUG_LAST_EVENT_INFO_EXIT_PROCESS {
635     ULONG ExitCode;
636   } DEBUG_LAST_EVENT_INFO_EXIT_PROCESS,*PDEBUG_LAST_EVENT_INFO_EXIT_PROCESS;
637 
638   typedef struct _DEBUG_LAST_EVENT_INFO_LOAD_MODULE {
639     ULONG64 Base;
640   } DEBUG_LAST_EVENT_INFO_LOAD_MODULE,*PDEBUG_LAST_EVENT_INFO_LOAD_MODULE;
641 
642   typedef struct _DEBUG_LAST_EVENT_INFO_UNLOAD_MODULE {
643     ULONG64 Base;
644   } DEBUG_LAST_EVENT_INFO_UNLOAD_MODULE,*PDEBUG_LAST_EVENT_INFO_UNLOAD_MODULE;
645 
646   typedef struct _DEBUG_LAST_EVENT_INFO_SYSTEM_ERROR {
647     ULONG Error;
648     ULONG Level;
649   } DEBUG_LAST_EVENT_INFO_SYSTEM_ERROR,*PDEBUG_LAST_EVENT_INFO_SYSTEM_ERROR;
650 
651 #define DEBUG_VALUE_INVALID 0
652 #define DEBUG_VALUE_INT8 1
653 #define DEBUG_VALUE_INT16 2
654 #define DEBUG_VALUE_INT32 3
655 #define DEBUG_VALUE_INT64 4
656 #define DEBUG_VALUE_FLOAT32 5
657 #define DEBUG_VALUE_FLOAT64 6
658 #define DEBUG_VALUE_FLOAT80 7
659 #define DEBUG_VALUE_FLOAT82 8
660 #define DEBUG_VALUE_FLOAT128 9
661 #define DEBUG_VALUE_VECTOR64 10
662 #define DEBUG_VALUE_VECTOR128 11
663 
664 #define DEBUG_VALUE_TYPES 12
665 
666   typedef struct _DEBUG_VALUE {
667     __C89_NAMELESS union {
668       UCHAR I8;
669       USHORT I16;
670       ULONG I32;
671       __C89_NAMELESS struct {
672 	ULONG64 I64;
673 	WINBOOL Nat;
674       };
675       float F32;
676       double F64;
677       UCHAR F80Bytes[10];
678       UCHAR F82Bytes[11];
679       UCHAR F128Bytes[16];
680       UCHAR VI8[16];
681       USHORT VI16[8];
682       ULONG VI32[4];
683       ULONG64 VI64[2];
684       float VF32[4];
685       double VF64[2];
686       struct {
687 	ULONG LowPart;
688 	ULONG HighPart;
689       } I64Parts32;
690       struct {
691 	ULONG64 LowPart;
692 	LONG64 HighPart;
693       } F128Parts64;
694       UCHAR RawBytes[24];
695     };
696     ULONG TailOfRawBytes;
697     ULONG Type;
698   } DEBUG_VALUE,*PDEBUG_VALUE;
699 
700 #undef INTERFACE
701 #define INTERFACE IDebugControl
DECLARE_INTERFACE_(IDebugControl,IUnknown)702   DECLARE_INTERFACE_(IDebugControl,IUnknown) {
703     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
704     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
705     STDMETHOD_(ULONG,Release)(THIS) PURE;
706     STDMETHOD(GetInterrupt)(THIS) PURE;
707     STDMETHOD(SetInterrupt)(THIS_ ULONG Flags) PURE;
708     STDMETHOD(GetInterruptTimeout)(THIS_ PULONG Seconds) PURE;
709     STDMETHOD(SetInterruptTimeout)(THIS_ ULONG Seconds) PURE;
710     STDMETHOD(GetLogFile)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG FileSize,PBOOL Append) PURE;
711     STDMETHOD(OpenLogFile)(THIS_ PCSTR File,WINBOOL Append) PURE;
712     STDMETHOD(CloseLogFile)(THIS) PURE;
713     STDMETHOD(GetLogMask)(THIS_ PULONG Mask) PURE;
714     STDMETHOD(SetLogMask)(THIS_ ULONG Mask) PURE;
715     STDMETHOD(Input)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG InputSize) PURE;
716     STDMETHOD(ReturnInput)(THIS_ PCSTR Buffer) PURE;
717     STDMETHODV(Output)(THIS_ ULONG Mask,PCSTR Format,...) PURE;
718     STDMETHOD(OutputVaList)(THIS_ ULONG Mask,PCSTR Format,va_list Args) PURE;
719     STDMETHODV(ControlledOutput)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,...) PURE;
720     STDMETHOD(ControlledOutputVaList)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,va_list Args) PURE;
721     STDMETHODV(OutputPrompt)(THIS_ ULONG OutputControl,PCSTR Format,...) PURE;
722     STDMETHOD(OutputPromptVaList)(THIS_ ULONG OutputControl,PCSTR Format,va_list Args) PURE;
723     STDMETHOD(GetPromptText)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
724     STDMETHOD(OutputCurrentState)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
725     STDMETHOD(OutputVersionInformation)(THIS_ ULONG OutputControl) PURE;
726     STDMETHOD(GetNotifyEventHandle)(THIS_ PULONG64 Handle) PURE;
727     STDMETHOD(SetNotifyEventHandle)(THIS_ ULONG64 Handle) PURE;
728     STDMETHOD(Assemble)(THIS_ ULONG64 Offset,PCSTR Instr,PULONG64 EndOffset) PURE;
729     STDMETHOD(Disassemble)(THIS_ ULONG64 Offset,ULONG Flags,PSTR Buffer,ULONG BufferSize,PULONG DisassemblySize,PULONG64 EndOffset) PURE;
730     STDMETHOD(GetDisassembleEffectiveOffset)(THIS_ PULONG64 Offset) PURE;
731     STDMETHOD(OutputDisassembly)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG Flags,PULONG64 EndOffset) PURE;
732     STDMETHOD(OutputDisassemblyLines)(THIS_ ULONG OutputControl,ULONG PreviousLines,ULONG TotalLines,ULONG64 Offset,ULONG Flags,PULONG OffsetLine,PULONG64 StartOffset,PULONG64 EndOffset,PULONG64 LineOffsets) PURE;
733     STDMETHOD(GetNearInstruction)(THIS_ ULONG64 Offset,LONG Delta,PULONG64 NearOffset) PURE;
734     STDMETHOD(GetStackTrace)(THIS_ ULONG64 FrameOffset,ULONG64 StackOffset,ULONG64 InstructionOffset,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,PULONG FramesFilled) PURE;
735     STDMETHOD(GetReturnOffset)(THIS_ PULONG64 Offset) PURE;
736     STDMETHOD(OutputStackTrace)(THIS_ ULONG OutputControl,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,ULONG Flags) PURE;
737     STDMETHOD(GetDebuggeeType)(THIS_ PULONG Class,PULONG Qualifier) PURE;
738     STDMETHOD(GetActualProcessorType)(THIS_ PULONG Type) PURE;
739     STDMETHOD(GetExecutingProcessorType)(THIS_ PULONG Type) PURE;
740     STDMETHOD(GetNumberPossibleExecutingProcessorTypes)(THIS_ PULONG Number) PURE;
741     STDMETHOD(GetPossibleExecutingProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
742     STDMETHOD(GetNumberProcessors)(THIS_ PULONG Number) PURE;
743     STDMETHOD(GetSystemVersion)(THIS_ PULONG PlatformId,PULONG Major,PULONG Minor,PSTR ServicePackString,ULONG ServicePackStringSize,PULONG ServicePackStringUsed,PULONG ServicePackNumber,PSTR BuildString,ULONG BuildStringSize,PULONG BuildStringUsed) PURE;
744     STDMETHOD(GetPageSize)(THIS_ PULONG Size) PURE;
745     STDMETHOD(IsPointer64Bit)(THIS) PURE;
746     STDMETHOD(ReadBugCheckData)(THIS_ PULONG Code,PULONG64 Arg1,PULONG64 Arg2,PULONG64 Arg3,PULONG64 Arg4) PURE;
747     STDMETHOD(GetNumberSupportedProcessorTypes)(THIS_ PULONG Number) PURE;
748     STDMETHOD(GetSupportedProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
749     STDMETHOD(GetProcessorTypeNames)(THIS_ ULONG Type,PSTR FullNameBuffer,ULONG FullNameBufferSize,PULONG FullNameSize,PSTR AbbrevNameBuffer,ULONG AbbrevNameBufferSize,PULONG AbbrevNameSize) PURE;
750     STDMETHOD(GetEffectiveProcessorType)(THIS_ PULONG Type) PURE;
751     STDMETHOD(SetEffectiveProcessorType)(THIS_ ULONG Type) PURE;
752     STDMETHOD(GetExecutionStatus)(THIS_ PULONG Status) PURE;
753     STDMETHOD(SetExecutionStatus)(THIS_ ULONG Status) PURE;
754     STDMETHOD(GetCodeLevel)(THIS_ PULONG Level) PURE;
755     STDMETHOD(SetCodeLevel)(THIS_ ULONG Level) PURE;
756     STDMETHOD(GetEngineOptions)(THIS_ PULONG Options) PURE;
757     STDMETHOD(AddEngineOptions)(THIS_ ULONG Options) PURE;
758     STDMETHOD(RemoveEngineOptions)(THIS_ ULONG Options) PURE;
759     STDMETHOD(SetEngineOptions)(THIS_ ULONG Options) PURE;
760     STDMETHOD(GetSystemErrorControl)(THIS_ PULONG OutputLevel,PULONG BreakLevel) PURE;
761     STDMETHOD(SetSystemErrorControl)(THIS_ ULONG OutputLevel,ULONG BreakLevel) PURE;
762     STDMETHOD(GetTextMacro)(THIS_ ULONG Slot,PSTR Buffer,ULONG BufferSize,PULONG MacroSize) PURE;
763     STDMETHOD(SetTextMacro)(THIS_ ULONG Slot,PCSTR Macro) PURE;
764     STDMETHOD(GetRadix)(THIS_ PULONG Radix) PURE;
765     STDMETHOD(SetRadix)(THIS_ ULONG Radix) PURE;
766     STDMETHOD(Evaluate)(THIS_ PCSTR Expression,ULONG DesiredType,PDEBUG_VALUE Value,PULONG RemainderIndex) PURE;
767     STDMETHOD(CoerceValue)(THIS_ PDEBUG_VALUE In,ULONG OutType,PDEBUG_VALUE Out) PURE;
768     STDMETHOD(CoerceValues)(THIS_ ULONG Count,PDEBUG_VALUE In,PULONG OutTypes,PDEBUG_VALUE Out) PURE;
769     STDMETHOD(Execute)(THIS_ ULONG OutputControl,PCSTR Command,ULONG Flags) PURE;
770     STDMETHOD(ExecuteCommandFile)(THIS_ ULONG OutputControl,PCSTR CommandFile,ULONG Flags) PURE;
771     STDMETHOD(GetNumberBreakpoints)(THIS_ PULONG Number) PURE;
772     STDMETHOD(GetBreakpointByIndex)(THIS_ ULONG Index,PDEBUG_BREAKPOINT *Bp) PURE;
773     STDMETHOD(GetBreakpointById)(THIS_ ULONG Id,PDEBUG_BREAKPOINT *Bp) PURE;
774     STDMETHOD(GetBreakpointParameters)(THIS_ ULONG Count,PULONG Ids,ULONG Start,PDEBUG_BREAKPOINT_PARAMETERS Params) PURE;
775     STDMETHOD(AddBreakpoint)(THIS_ ULONG Type,ULONG DesiredId,PDEBUG_BREAKPOINT *Bp) PURE;
776     STDMETHOD(RemoveBreakpoint)(THIS_ PDEBUG_BREAKPOINT Bp) PURE;
777     STDMETHOD(AddExtension)(THIS_ PCSTR Path,ULONG Flags,PULONG64 Handle) PURE;
778     STDMETHOD(RemoveExtension)(THIS_ ULONG64 Handle) PURE;
779     STDMETHOD(GetExtensionByPath)(THIS_ PCSTR Path,PULONG64 Handle) PURE;
780     STDMETHOD(CallExtension)(THIS_ ULONG64 Handle,PCSTR Function,PCSTR Arguments) PURE;
781     STDMETHOD(GetExtensionFunction)(THIS_ ULONG64 Handle,PCSTR FuncName,FARPROC *Function) PURE;
782     STDMETHOD(GetWindbgExtensionApis32)(THIS_ PWINDBG_EXTENSION_APIS32 Api) PURE;
783     STDMETHOD(GetWindbgExtensionApis64)(THIS_ PWINDBG_EXTENSION_APIS64 Api) PURE;
784     STDMETHOD(GetNumberEventFilters)(THIS_ PULONG SpecificEvents,PULONG SpecificExceptions,PULONG ArbitraryExceptions) PURE;
785     STDMETHOD(GetEventFilterText)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
786     STDMETHOD(GetEventFilterCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
787     STDMETHOD(SetEventFilterCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
788     STDMETHOD(GetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
789     STDMETHOD(SetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
790     STDMETHOD(GetSpecificFilterArgument)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG ArgumentSize) PURE;
791     STDMETHOD(SetSpecificFilterArgument)(THIS_ ULONG Index,PCSTR Argument) PURE;
792     STDMETHOD(GetExceptionFilterParameters)(THIS_ ULONG Count,PULONG Codes,ULONG Start,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
793     STDMETHOD(SetExceptionFilterParameters)(THIS_ ULONG Count,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
794     STDMETHOD(GetExceptionFilterSecondCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
795     STDMETHOD(SetExceptionFilterSecondCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
796     STDMETHOD(WaitForEvent)(THIS_ ULONG Flags,ULONG Timeout) PURE;
797     STDMETHOD(GetLastEventInformation)(THIS_ PULONG Type,PULONG ProcessId,PULONG ThreadId,PVOID ExtraInformation,ULONG ExtraInformationSize,PULONG ExtraInformationUsed,PSTR Description,ULONG DescriptionSize,PULONG DescriptionUsed) PURE;
798   };
799 
800 #define DEBUG_OUT_TEXT_REPL_DEFAULT 0x00000000
801 
802 #undef INTERFACE
803 #define INTERFACE IDebugControl2
DECLARE_INTERFACE_(IDebugControl2,IUnknown)804   DECLARE_INTERFACE_(IDebugControl2,IUnknown) {
805     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
806     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
807     STDMETHOD_(ULONG,Release)(THIS) PURE;
808     STDMETHOD(GetInterrupt)(THIS) PURE;
809     STDMETHOD(SetInterrupt)(THIS_ ULONG Flags) PURE;
810     STDMETHOD(GetInterruptTimeout)(THIS_ PULONG Seconds) PURE;
811     STDMETHOD(SetInterruptTimeout)(THIS_ ULONG Seconds) PURE;
812     STDMETHOD(GetLogFile)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG FileSize,PBOOL Append) PURE;
813     STDMETHOD(OpenLogFile)(THIS_ PCSTR File,WINBOOL Append) PURE;
814     STDMETHOD(CloseLogFile)(THIS) PURE;
815     STDMETHOD(GetLogMask)(THIS_ PULONG Mask) PURE;
816     STDMETHOD(SetLogMask)(THIS_ ULONG Mask) PURE;
817     STDMETHOD(Input)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG InputSize) PURE;
818     STDMETHOD(ReturnInput)(THIS_ PCSTR Buffer) PURE;
819     STDMETHODV(Output)(THIS_ ULONG Mask,PCSTR Format,...) PURE;
820     STDMETHOD(OutputVaList)(THIS_ ULONG Mask,PCSTR Format,va_list Args) PURE;
821     STDMETHODV(ControlledOutput)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,...) PURE;
822     STDMETHOD(ControlledOutputVaList)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,va_list Args) PURE;
823     STDMETHODV(OutputPrompt)(THIS_ ULONG OutputControl,PCSTR Format,...) PURE;
824     STDMETHOD(OutputPromptVaList)(THIS_ ULONG OutputControl,PCSTR Format,va_list Args) PURE;
825     STDMETHOD(GetPromptText)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
826     STDMETHOD(OutputCurrentState)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
827     STDMETHOD(OutputVersionInformation)(THIS_ ULONG OutputControl) PURE;
828     STDMETHOD(GetNotifyEventHandle)(THIS_ PULONG64 Handle) PURE;
829     STDMETHOD(SetNotifyEventHandle)(THIS_ ULONG64 Handle) PURE;
830     STDMETHOD(Assemble)(THIS_ ULONG64 Offset,PCSTR Instr,PULONG64 EndOffset) PURE;
831     STDMETHOD(Disassemble)(THIS_ ULONG64 Offset,ULONG Flags,PSTR Buffer,ULONG BufferSize,PULONG DisassemblySize,PULONG64 EndOffset) PURE;
832     STDMETHOD(GetDisassembleEffectiveOffset)(THIS_ PULONG64 Offset) PURE;
833     STDMETHOD(OutputDisassembly)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG Flags,PULONG64 EndOffset) PURE;
834     STDMETHOD(OutputDisassemblyLines)(THIS_ ULONG OutputControl,ULONG PreviousLines,ULONG TotalLines,ULONG64 Offset,ULONG Flags,PULONG OffsetLine,PULONG64 StartOffset,PULONG64 EndOffset,PULONG64 LineOffsets) PURE;
835     STDMETHOD(GetNearInstruction)(THIS_ ULONG64 Offset,LONG Delta,PULONG64 NearOffset) PURE;
836     STDMETHOD(GetStackTrace)(THIS_ ULONG64 FrameOffset,ULONG64 StackOffset,ULONG64 InstructionOffset,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,PULONG FramesFilled) PURE;
837     STDMETHOD(GetReturnOffset)(THIS_ PULONG64 Offset) PURE;
838     STDMETHOD(OutputStackTrace)(THIS_ ULONG OutputControl,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,ULONG Flags) PURE;
839     STDMETHOD(GetDebuggeeType)(THIS_ PULONG Class,PULONG Qualifier) PURE;
840     STDMETHOD(GetActualProcessorType)(THIS_ PULONG Type) PURE;
841     STDMETHOD(GetExecutingProcessorType)(THIS_ PULONG Type) PURE;
842     STDMETHOD(GetNumberPossibleExecutingProcessorTypes)(THIS_ PULONG Number) PURE;
843     STDMETHOD(GetPossibleExecutingProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
844     STDMETHOD(GetNumberProcessors)(THIS_ PULONG Number) PURE;
845     STDMETHOD(GetSystemVersion)(THIS_ PULONG PlatformId,PULONG Major,PULONG Minor,PSTR ServicePackString,ULONG ServicePackStringSize,PULONG ServicePackStringUsed,PULONG ServicePackNumber,PSTR BuildString,ULONG BuildStringSize,PULONG BuildStringUsed) PURE;
846     STDMETHOD(GetPageSize)(THIS_ PULONG Size) PURE;
847     STDMETHOD(IsPointer64Bit)(THIS) PURE;
848     STDMETHOD(ReadBugCheckData)(THIS_ PULONG Code,PULONG64 Arg1,PULONG64 Arg2,PULONG64 Arg3,PULONG64 Arg4) PURE;
849     STDMETHOD(GetNumberSupportedProcessorTypes)(THIS_ PULONG Number) PURE;
850     STDMETHOD(GetSupportedProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
851     STDMETHOD(GetProcessorTypeNames)(THIS_ ULONG Type,PSTR FullNameBuffer,ULONG FullNameBufferSize,PULONG FullNameSize,PSTR AbbrevNameBuffer,ULONG AbbrevNameBufferSize,PULONG AbbrevNameSize) PURE;
852     STDMETHOD(GetEffectiveProcessorType)(THIS_ PULONG Type) PURE;
853     STDMETHOD(SetEffectiveProcessorType)(THIS_ ULONG Type) PURE;
854     STDMETHOD(GetExecutionStatus)(THIS_ PULONG Status) PURE;
855     STDMETHOD(SetExecutionStatus)(THIS_ ULONG Status) PURE;
856     STDMETHOD(GetCodeLevel)(THIS_ PULONG Level) PURE;
857     STDMETHOD(SetCodeLevel)(THIS_ ULONG Level) PURE;
858     STDMETHOD(GetEngineOptions)(THIS_ PULONG Options) PURE;
859     STDMETHOD(AddEngineOptions)(THIS_ ULONG Options) PURE;
860     STDMETHOD(RemoveEngineOptions)(THIS_ ULONG Options) PURE;
861     STDMETHOD(SetEngineOptions)(THIS_ ULONG Options) PURE;
862     STDMETHOD(GetSystemErrorControl)(THIS_ PULONG OutputLevel,PULONG BreakLevel) PURE;
863     STDMETHOD(SetSystemErrorControl)(THIS_ ULONG OutputLevel,ULONG BreakLevel) PURE;
864     STDMETHOD(GetTextMacro)(THIS_ ULONG Slot,PSTR Buffer,ULONG BufferSize,PULONG MacroSize) PURE;
865     STDMETHOD(SetTextMacro)(THIS_ ULONG Slot,PCSTR Macro) PURE;
866     STDMETHOD(GetRadix)(THIS_ PULONG Radix) PURE;
867     STDMETHOD(SetRadix)(THIS_ ULONG Radix) PURE;
868     STDMETHOD(Evaluate)(THIS_ PCSTR Expression,ULONG DesiredType,PDEBUG_VALUE Value,PULONG RemainderIndex) PURE;
869     STDMETHOD(CoerceValue)(THIS_ PDEBUG_VALUE In,ULONG OutType,PDEBUG_VALUE Out) PURE;
870     STDMETHOD(CoerceValues)(THIS_ ULONG Count,PDEBUG_VALUE In,PULONG OutTypes,PDEBUG_VALUE Out) PURE;
871     STDMETHOD(Execute)(THIS_ ULONG OutputControl,PCSTR Command,ULONG Flags) PURE;
872     STDMETHOD(ExecuteCommandFile)(THIS_ ULONG OutputControl,PCSTR CommandFile,ULONG Flags) PURE;
873     STDMETHOD(GetNumberBreakpoints)(THIS_ PULONG Number) PURE;
874     STDMETHOD(GetBreakpointByIndex)(THIS_ ULONG Index,PDEBUG_BREAKPOINT *Bp) PURE;
875     STDMETHOD(GetBreakpointById)(THIS_ ULONG Id,PDEBUG_BREAKPOINT *Bp) PURE;
876     STDMETHOD(GetBreakpointParameters)(THIS_ ULONG Count,PULONG Ids,ULONG Start,PDEBUG_BREAKPOINT_PARAMETERS Params) PURE;
877     STDMETHOD(AddBreakpoint)(THIS_ ULONG Type,ULONG DesiredId,PDEBUG_BREAKPOINT *Bp) PURE;
878     STDMETHOD(RemoveBreakpoint)(THIS_ PDEBUG_BREAKPOINT Bp) PURE;
879     STDMETHOD(AddExtension)(THIS_ PCSTR Path,ULONG Flags,PULONG64 Handle) PURE;
880     STDMETHOD(RemoveExtension)(THIS_ ULONG64 Handle) PURE;
881     STDMETHOD(GetExtensionByPath)(THIS_ PCSTR Path,PULONG64 Handle) PURE;
882     STDMETHOD(CallExtension)(THIS_ ULONG64 Handle,PCSTR Function,PCSTR Arguments) PURE;
883     STDMETHOD(GetExtensionFunction)(THIS_ ULONG64 Handle,PCSTR FuncName,FARPROC *Function) PURE;
884     STDMETHOD(GetWindbgExtensionApis32)(THIS_ PWINDBG_EXTENSION_APIS32 Api) PURE;
885     STDMETHOD(GetWindbgExtensionApis64)(THIS_ PWINDBG_EXTENSION_APIS64 Api) PURE;
886     STDMETHOD(GetNumberEventFilters)(THIS_ PULONG SpecificEvents,PULONG SpecificExceptions,PULONG ArbitraryExceptions) PURE;
887     STDMETHOD(GetEventFilterText)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
888     STDMETHOD(GetEventFilterCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
889     STDMETHOD(SetEventFilterCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
890     STDMETHOD(GetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
891     STDMETHOD(SetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
892     STDMETHOD(GetSpecificFilterArgument)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG ArgumentSize) PURE;
893     STDMETHOD(SetSpecificFilterArgument)(THIS_ ULONG Index,PCSTR Argument) PURE;
894     STDMETHOD(GetExceptionFilterParameters)(THIS_ ULONG Count,PULONG Codes,ULONG Start,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
895     STDMETHOD(SetExceptionFilterParameters)(THIS_ ULONG Count,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
896     STDMETHOD(GetExceptionFilterSecondCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
897     STDMETHOD(SetExceptionFilterSecondCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
898     STDMETHOD(WaitForEvent)(THIS_ ULONG Flags,ULONG Timeout) PURE;
899     STDMETHOD(GetLastEventInformation)(THIS_ PULONG Type,PULONG ProcessId,PULONG ThreadId,PVOID ExtraInformation,ULONG ExtraInformationSize,PULONG ExtraInformationUsed,PSTR Description,ULONG DescriptionSize,PULONG DescriptionUsed) PURE;
900     STDMETHOD(GetCurrentTimeDate)(THIS_ PULONG TimeDate) PURE;
901     STDMETHOD(GetCurrentSystemUpTime)(THIS_ PULONG UpTime) PURE;
902     STDMETHOD(GetDumpFormatFlags)(THIS_ PULONG FormatFlags) PURE;
903     STDMETHOD(GetNumberTextReplacements)(THIS_ PULONG NumRepl) PURE;
904     STDMETHOD(GetTextReplacement)(THIS_ PCSTR SrcText,ULONG Index,PSTR SrcBuffer,ULONG SrcBufferSize,PULONG SrcSize,PSTR DstBuffer,ULONG DstBufferSize,PULONG DstSize) PURE;
905     STDMETHOD(SetTextReplacement)(THIS_ PCSTR SrcText,PCSTR DstText) PURE;
906     STDMETHOD(RemoveTextReplacements)(THIS) PURE;
907     STDMETHOD(OutputTextReplacements)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
908   };
909 
910 #define DEBUG_ASMOPT_DEFAULT 0x00000000
911 #define DEBUG_ASMOPT_VERBOSE 0x00000001
912 #define DEBUG_ASMOPT_NO_CODE_BYTES 0x00000002
913 #define DEBUG_ASMOPT_IGNORE_OUTPUT_WIDTH 0x00000004
914 
915 #define DEBUG_EXPR_MASM 0x00000000
916 #define DEBUG_EXPR_CPLUSPLUS 0x00000001
917 
918 #define DEBUG_EINDEX_NAME 0x00000000
919 #define DEBUG_EINDEX_FROM_START 0x00000000
920 #define DEBUG_EINDEX_FROM_END 0x00000001
921 #define DEBUG_EINDEX_FROM_CURRENT 0x00000002
922 
923 #undef INTERFACE
924 #define INTERFACE IDebugControl3
DECLARE_INTERFACE_(IDebugControl3,IUnknown)925   DECLARE_INTERFACE_(IDebugControl3,IUnknown) {
926     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
927     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
928     STDMETHOD_(ULONG,Release)(THIS) PURE;
929     STDMETHOD(GetInterrupt)(THIS) PURE;
930     STDMETHOD(SetInterrupt)(THIS_ ULONG Flags) PURE;
931     STDMETHOD(GetInterruptTimeout)(THIS_ PULONG Seconds) PURE;
932     STDMETHOD(SetInterruptTimeout)(THIS_ ULONG Seconds) PURE;
933     STDMETHOD(GetLogFile)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG FileSize,PBOOL Append) PURE;
934     STDMETHOD(OpenLogFile)(THIS_ PCSTR File,WINBOOL Append) PURE;
935     STDMETHOD(CloseLogFile)(THIS) PURE;
936     STDMETHOD(GetLogMask)(THIS_ PULONG Mask) PURE;
937     STDMETHOD(SetLogMask)(THIS_ ULONG Mask) PURE;
938     STDMETHOD(Input)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG InputSize) PURE;
939     STDMETHOD(ReturnInput)(THIS_ PCSTR Buffer) PURE;
940     STDMETHODV(Output)(THIS_ ULONG Mask,PCSTR Format,...) PURE;
941     STDMETHOD(OutputVaList)(THIS_ ULONG Mask,PCSTR Format,va_list Args) PURE;
942     STDMETHODV(ControlledOutput)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,...) PURE;
943     STDMETHOD(ControlledOutputVaList)(THIS_ ULONG OutputControl,ULONG Mask,PCSTR Format,va_list Args) PURE;
944     STDMETHODV(OutputPrompt)(THIS_ ULONG OutputControl,PCSTR Format,...) PURE;
945     STDMETHOD(OutputPromptVaList)(THIS_ ULONG OutputControl,PCSTR Format,va_list Args) PURE;
946     STDMETHOD(GetPromptText)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
947     STDMETHOD(OutputCurrentState)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
948     STDMETHOD(OutputVersionInformation)(THIS_ ULONG OutputControl) PURE;
949     STDMETHOD(GetNotifyEventHandle)(THIS_ PULONG64 Handle) PURE;
950     STDMETHOD(SetNotifyEventHandle)(THIS_ ULONG64 Handle) PURE;
951     STDMETHOD(Assemble)(THIS_ ULONG64 Offset,PCSTR Instr,PULONG64 EndOffset) PURE;
952     STDMETHOD(Disassemble)(THIS_ ULONG64 Offset,ULONG Flags,PSTR Buffer,ULONG BufferSize,PULONG DisassemblySize,PULONG64 EndOffset) PURE;
953     STDMETHOD(GetDisassembleEffectiveOffset)(THIS_ PULONG64 Offset) PURE;
954     STDMETHOD(OutputDisassembly)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG Flags,PULONG64 EndOffset) PURE;
955     STDMETHOD(OutputDisassemblyLines)(THIS_ ULONG OutputControl,ULONG PreviousLines,ULONG TotalLines,ULONG64 Offset,ULONG Flags,PULONG OffsetLine,PULONG64 StartOffset,PULONG64 EndOffset,PULONG64 LineOffsets) PURE;
956     STDMETHOD(GetNearInstruction)(THIS_ ULONG64 Offset,LONG Delta,PULONG64 NearOffset) PURE;
957     STDMETHOD(GetStackTrace)(THIS_ ULONG64 FrameOffset,ULONG64 StackOffset,ULONG64 InstructionOffset,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,PULONG FramesFilled) PURE;
958     STDMETHOD(GetReturnOffset)(THIS_ PULONG64 Offset) PURE;
959     STDMETHOD(OutputStackTrace)(THIS_ ULONG OutputControl,PDEBUG_STACK_FRAME Frames,ULONG FramesSize,ULONG Flags) PURE;
960     STDMETHOD(GetDebuggeeType)(THIS_ PULONG Class,PULONG Qualifier) PURE;
961     STDMETHOD(GetActualProcessorType)(THIS_ PULONG Type) PURE;
962     STDMETHOD(GetExecutingProcessorType)(THIS_ PULONG Type) PURE;
963     STDMETHOD(GetNumberPossibleExecutingProcessorTypes)(THIS_ PULONG Number) PURE;
964     STDMETHOD(GetPossibleExecutingProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
965     STDMETHOD(GetNumberProcessors)(THIS_ PULONG Number) PURE;
966     STDMETHOD(GetSystemVersion)(THIS_ PULONG PlatformId,PULONG Major,PULONG Minor,PSTR ServicePackString,ULONG ServicePackStringSize,PULONG ServicePackStringUsed,PULONG ServicePackNumber,PSTR BuildString,ULONG BuildStringSize,PULONG BuildStringUsed) PURE;
967     STDMETHOD(GetPageSize)(THIS_ PULONG Size) PURE;
968     STDMETHOD(IsPointer64Bit)(THIS) PURE;
969     STDMETHOD(ReadBugCheckData)(THIS_ PULONG Code,PULONG64 Arg1,PULONG64 Arg2,PULONG64 Arg3,PULONG64 Arg4) PURE;
970     STDMETHOD(GetNumberSupportedProcessorTypes)(THIS_ PULONG Number) PURE;
971     STDMETHOD(GetSupportedProcessorTypes)(THIS_ ULONG Start,ULONG Count,PULONG Types) PURE;
972     STDMETHOD(GetProcessorTypeNames)(THIS_ ULONG Type,PSTR FullNameBuffer,ULONG FullNameBufferSize,PULONG FullNameSize,PSTR AbbrevNameBuffer,ULONG AbbrevNameBufferSize,PULONG AbbrevNameSize) PURE;
973     STDMETHOD(GetEffectiveProcessorType)(THIS_ PULONG Type) PURE;
974     STDMETHOD(SetEffectiveProcessorType)(THIS_ ULONG Type) PURE;
975     STDMETHOD(GetExecutionStatus)(THIS_ PULONG Status) PURE;
976     STDMETHOD(SetExecutionStatus)(THIS_ ULONG Status) PURE;
977     STDMETHOD(GetCodeLevel)(THIS_ PULONG Level) PURE;
978     STDMETHOD(SetCodeLevel)(THIS_ ULONG Level) PURE;
979     STDMETHOD(GetEngineOptions)(THIS_ PULONG Options) PURE;
980     STDMETHOD(AddEngineOptions)(THIS_ ULONG Options) PURE;
981     STDMETHOD(RemoveEngineOptions)(THIS_ ULONG Options) PURE;
982     STDMETHOD(SetEngineOptions)(THIS_ ULONG Options) PURE;
983     STDMETHOD(GetSystemErrorControl)(THIS_ PULONG OutputLevel,PULONG BreakLevel) PURE;
984     STDMETHOD(SetSystemErrorControl)(THIS_ ULONG OutputLevel,ULONG BreakLevel) PURE;
985     STDMETHOD(GetTextMacro)(THIS_ ULONG Slot,PSTR Buffer,ULONG BufferSize,PULONG MacroSize) PURE;
986     STDMETHOD(SetTextMacro)(THIS_ ULONG Slot,PCSTR Macro) PURE;
987     STDMETHOD(GetRadix)(THIS_ PULONG Radix) PURE;
988     STDMETHOD(SetRadix)(THIS_ ULONG Radix) PURE;
989     STDMETHOD(Evaluate)(THIS_ PCSTR Expression,ULONG DesiredType,PDEBUG_VALUE Value,PULONG RemainderIndex) PURE;
990     STDMETHOD(CoerceValue)(THIS_ PDEBUG_VALUE In,ULONG OutType,PDEBUG_VALUE Out) PURE;
991     STDMETHOD(CoerceValues)(THIS_ ULONG Count,PDEBUG_VALUE In,PULONG OutTypes,PDEBUG_VALUE Out) PURE;
992     STDMETHOD(Execute)(THIS_ ULONG OutputControl,PCSTR Command,ULONG Flags) PURE;
993     STDMETHOD(ExecuteCommandFile)(THIS_ ULONG OutputControl,PCSTR CommandFile,ULONG Flags) PURE;
994     STDMETHOD(GetNumberBreakpoints)(THIS_ PULONG Number) PURE;
995     STDMETHOD(GetBreakpointByIndex)(THIS_ ULONG Index,PDEBUG_BREAKPOINT *Bp) PURE;
996     STDMETHOD(GetBreakpointById)(THIS_ ULONG Id,PDEBUG_BREAKPOINT *Bp) PURE;
997     STDMETHOD(GetBreakpointParameters)(THIS_ ULONG Count,PULONG Ids,ULONG Start,PDEBUG_BREAKPOINT_PARAMETERS Params) PURE;
998     STDMETHOD(AddBreakpoint)(THIS_ ULONG Type,ULONG DesiredId,PDEBUG_BREAKPOINT *Bp) PURE;
999     STDMETHOD(RemoveBreakpoint)(THIS_ PDEBUG_BREAKPOINT Bp) PURE;
1000     STDMETHOD(AddExtension)(THIS_ PCSTR Path,ULONG Flags,PULONG64 Handle) PURE;
1001     STDMETHOD(RemoveExtension)(THIS_ ULONG64 Handle) PURE;
1002     STDMETHOD(GetExtensionByPath)(THIS_ PCSTR Path,PULONG64 Handle) PURE;
1003     STDMETHOD(CallExtension)(THIS_ ULONG64 Handle,PCSTR Function,PCSTR Arguments) PURE;
1004     STDMETHOD(GetExtensionFunction)(THIS_ ULONG64 Handle,PCSTR FuncName,FARPROC *Function) PURE;
1005     STDMETHOD(GetWindbgExtensionApis32)(THIS_ PWINDBG_EXTENSION_APIS32 Api) PURE;
1006     STDMETHOD(GetWindbgExtensionApis64)(THIS_ PWINDBG_EXTENSION_APIS64 Api) PURE;
1007     STDMETHOD(GetNumberEventFilters)(THIS_ PULONG SpecificEvents,PULONG SpecificExceptions,PULONG ArbitraryExceptions) PURE;
1008     STDMETHOD(GetEventFilterText)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG TextSize) PURE;
1009     STDMETHOD(GetEventFilterCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
1010     STDMETHOD(SetEventFilterCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
1011     STDMETHOD(GetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
1012     STDMETHOD(SetSpecificFilterParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SPECIFIC_FILTER_PARAMETERS Params) PURE;
1013     STDMETHOD(GetSpecificFilterArgument)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG ArgumentSize) PURE;
1014     STDMETHOD(SetSpecificFilterArgument)(THIS_ ULONG Index,PCSTR Argument) PURE;
1015     STDMETHOD(GetExceptionFilterParameters)(THIS_ ULONG Count,PULONG Codes,ULONG Start,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
1016     STDMETHOD(SetExceptionFilterParameters)(THIS_ ULONG Count,PDEBUG_EXCEPTION_FILTER_PARAMETERS Params) PURE;
1017     STDMETHOD(GetExceptionFilterSecondCommand)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG CommandSize) PURE;
1018     STDMETHOD(SetExceptionFilterSecondCommand)(THIS_ ULONG Index,PCSTR Command) PURE;
1019     STDMETHOD(WaitForEvent)(THIS_ ULONG Flags,ULONG Timeout) PURE;
1020     STDMETHOD(GetLastEventInformation)(THIS_ PULONG Type,PULONG ProcessId,PULONG ThreadId,PVOID ExtraInformation,ULONG ExtraInformationSize,PULONG ExtraInformationUsed,PSTR Description,ULONG DescriptionSize,PULONG DescriptionUsed) PURE;
1021     STDMETHOD(GetCurrentTimeDate)(THIS_ PULONG TimeDate) PURE;
1022     STDMETHOD(GetCurrentSystemUpTime)(THIS_ PULONG UpTime) PURE;
1023     STDMETHOD(GetDumpFormatFlags)(THIS_ PULONG FormatFlags) PURE;
1024     STDMETHOD(GetNumberTextReplacements)(THIS_ PULONG NumRepl) PURE;
1025     STDMETHOD(GetTextReplacement)(THIS_ PCSTR SrcText,ULONG Index,PSTR SrcBuffer,ULONG SrcBufferSize,PULONG SrcSize,PSTR DstBuffer,ULONG DstBufferSize,PULONG DstSize) PURE;
1026     STDMETHOD(SetTextReplacement)(THIS_ PCSTR SrcText,PCSTR DstText) PURE;
1027     STDMETHOD(RemoveTextReplacements)(THIS) PURE;
1028     STDMETHOD(OutputTextReplacements)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
1029     STDMETHOD(GetAssemblyOptions)(THIS_ PULONG Options) PURE;
1030     STDMETHOD(AddAssemblyOptions)(THIS_ ULONG Options) PURE;
1031     STDMETHOD(RemoveAssemblyOptions)(THIS_ ULONG Options) PURE;
1032     STDMETHOD(SetAssemblyOptions)(THIS_ ULONG Options) PURE;
1033     STDMETHOD(GetExpressionSyntax)(THIS_ PULONG Flags) PURE;
1034     STDMETHOD(SetExpressionSyntax)(THIS_ ULONG Flags) PURE;
1035     STDMETHOD(SetExpressionSyntaxByName)(THIS_ PCSTR AbbrevName) PURE;
1036     STDMETHOD(GetNumberExpressionSyntaxes)(THIS_ PULONG Number) PURE;
1037     STDMETHOD(GetExpressionSyntaxNames)(THIS_ ULONG Index,PSTR FullNameBuffer,ULONG FullNameBufferSize,PULONG FullNameSize,PSTR AbbrevNameBuffer,ULONG AbbrevNameBufferSize,PULONG AbbrevNameSize) PURE;
1038     STDMETHOD(GetNumberEvents)(THIS_ PULONG Events) PURE;
1039     STDMETHOD(GetEventIndexDescription)(THIS_ ULONG Index,ULONG Which,PSTR Buffer,ULONG BufferSize,PULONG DescSize) PURE;
1040     STDMETHOD(GetCurrentEventIndex)(THIS_ PULONG Index) PURE;
1041     STDMETHOD(SetNextEventIndex)(THIS_ ULONG Relation,ULONG Value,PULONG NextIndex) PURE;
1042   };
1043 
1044 #define DEBUG_DATA_SPACE_VIRTUAL 0
1045 #define DEBUG_DATA_SPACE_PHYSICAL 1
1046 #define DEBUG_DATA_SPACE_CONTROL 2
1047 #define DEBUG_DATA_SPACE_IO 3
1048 #define DEBUG_DATA_SPACE_MSR 4
1049 #define DEBUG_DATA_SPACE_BUS_DATA 5
1050 #define DEBUG_DATA_SPACE_DEBUGGER_DATA 6
1051 #define DEBUG_DATA_SPACE_COUNT 7
1052 
1053 #define DEBUG_DATA_KernBase 24
1054 #define DEBUG_DATA_BreakpointWithStatusAddr 32
1055 #define DEBUG_DATA_SavedContextAddr 40
1056 #define DEBUG_DATA_KiCallUserModeAddr 56
1057 #define DEBUG_DATA_KeUserCallbackDispatcherAddr 64
1058 #define DEBUG_DATA_PsLoadedModuleListAddr 72
1059 #define DEBUG_DATA_PsActiveProcessHeadAddr 80
1060 #define DEBUG_DATA_PspCidTableAddr 88
1061 #define DEBUG_DATA_ExpSystemResourcesListAddr 96
1062 #define DEBUG_DATA_ExpPagedPoolDescriptorAddr 104
1063 #define DEBUG_DATA_ExpNumberOfPagedPoolsAddr 112
1064 #define DEBUG_DATA_KeTimeIncrementAddr 120
1065 #define DEBUG_DATA_KeBugCheckCallbackListHeadAddr 128
1066 #define DEBUG_DATA_KiBugcheckDataAddr 136
1067 #define DEBUG_DATA_IopErrorLogListHeadAddr 144
1068 #define DEBUG_DATA_ObpRootDirectoryObjectAddr 152
1069 #define DEBUG_DATA_ObpTypeObjectTypeAddr 160
1070 #define DEBUG_DATA_MmSystemCacheStartAddr 168
1071 #define DEBUG_DATA_MmSystemCacheEndAddr 176
1072 #define DEBUG_DATA_MmSystemCacheWsAddr 184
1073 #define DEBUG_DATA_MmPfnDatabaseAddr 192
1074 #define DEBUG_DATA_MmSystemPtesStartAddr 200
1075 #define DEBUG_DATA_MmSystemPtesEndAddr 208
1076 #define DEBUG_DATA_MmSubsectionBaseAddr 216
1077 #define DEBUG_DATA_MmNumberOfPagingFilesAddr 224
1078 #define DEBUG_DATA_MmLowestPhysicalPageAddr 232
1079 #define DEBUG_DATA_MmHighestPhysicalPageAddr 240
1080 #define DEBUG_DATA_MmNumberOfPhysicalPagesAddr 248
1081 #define DEBUG_DATA_MmMaximumNonPagedPoolInBytesAddr 256
1082 #define DEBUG_DATA_MmNonPagedSystemStartAddr 264
1083 #define DEBUG_DATA_MmNonPagedPoolStartAddr 272
1084 #define DEBUG_DATA_MmNonPagedPoolEndAddr 280
1085 #define DEBUG_DATA_MmPagedPoolStartAddr 288
1086 #define DEBUG_DATA_MmPagedPoolEndAddr 296
1087 #define DEBUG_DATA_MmPagedPoolInformationAddr 304
1088 #define DEBUG_DATA_MmPageSize 312
1089 #define DEBUG_DATA_MmSizeOfPagedPoolInBytesAddr 320
1090 #define DEBUG_DATA_MmTotalCommitLimitAddr 328
1091 #define DEBUG_DATA_MmTotalCommittedPagesAddr 336
1092 #define DEBUG_DATA_MmSharedCommitAddr 344
1093 #define DEBUG_DATA_MmDriverCommitAddr 352
1094 #define DEBUG_DATA_MmProcessCommitAddr 360
1095 #define DEBUG_DATA_MmPagedPoolCommitAddr 368
1096 #define DEBUG_DATA_MmExtendedCommitAddr 376
1097 #define DEBUG_DATA_MmZeroedPageListHeadAddr 384
1098 #define DEBUG_DATA_MmFreePageListHeadAddr 392
1099 #define DEBUG_DATA_MmStandbyPageListHeadAddr 400
1100 #define DEBUG_DATA_MmModifiedPageListHeadAddr 408
1101 #define DEBUG_DATA_MmModifiedNoWritePageListHeadAddr 416
1102 #define DEBUG_DATA_MmAvailablePagesAddr 424
1103 #define DEBUG_DATA_MmResidentAvailablePagesAddr 432
1104 #define DEBUG_DATA_PoolTrackTableAddr 440
1105 #define DEBUG_DATA_NonPagedPoolDescriptorAddr 448
1106 #define DEBUG_DATA_MmHighestUserAddressAddr 456
1107 #define DEBUG_DATA_MmSystemRangeStartAddr 464
1108 #define DEBUG_DATA_MmUserProbeAddressAddr 472
1109 #define DEBUG_DATA_KdPrintCircularBufferAddr 480
1110 #define DEBUG_DATA_KdPrintCircularBufferEndAddr 488
1111 #define DEBUG_DATA_KdPrintWritePointerAddr 496
1112 #define DEBUG_DATA_KdPrintRolloverCountAddr 504
1113 #define DEBUG_DATA_MmLoadedUserImageListAddr 512
1114 #define DEBUG_DATA_NtBuildLabAddr 520
1115 #define DEBUG_DATA_KiNormalSystemCall 528
1116 #define DEBUG_DATA_KiProcessorBlockAddr 536
1117 #define DEBUG_DATA_MmUnloadedDriversAddr 544
1118 #define DEBUG_DATA_MmLastUnloadedDriverAddr 552
1119 #define DEBUG_DATA_MmTriageActionTakenAddr 560
1120 #define DEBUG_DATA_MmSpecialPoolTagAddr 568
1121 #define DEBUG_DATA_KernelVerifierAddr 576
1122 #define DEBUG_DATA_MmVerifierDataAddr 584
1123 #define DEBUG_DATA_MmAllocatedNonPagedPoolAddr 592
1124 #define DEBUG_DATA_MmPeakCommitmentAddr 600
1125 #define DEBUG_DATA_MmTotalCommitLimitMaximumAddr 608
1126 #define DEBUG_DATA_CmNtCSDVersionAddr 616
1127 #define DEBUG_DATA_MmPhysicalMemoryBlockAddr 624
1128 #define DEBUG_DATA_MmSessionBase 632
1129 #define DEBUG_DATA_MmSessionSize 640
1130 #define DEBUG_DATA_MmSystemParentTablePage 648
1131 #define DEBUG_DATA_MmVirtualTranslationBase 656
1132 #define DEBUG_DATA_OffsetKThreadNextProcessor 664
1133 #define DEBUG_DATA_OffsetKThreadTeb 666
1134 #define DEBUG_DATA_OffsetKThreadKernelStack 668
1135 #define DEBUG_DATA_OffsetKThreadInitialStack 670
1136 #define DEBUG_DATA_OffsetKThreadApcProcess 672
1137 #define DEBUG_DATA_OffsetKThreadState 674
1138 #define DEBUG_DATA_OffsetKThreadBStore 676
1139 #define DEBUG_DATA_OffsetKThreadBStoreLimit 678
1140 #define DEBUG_DATA_SizeEProcess 680
1141 #define DEBUG_DATA_OffsetEprocessPeb 682
1142 #define DEBUG_DATA_OffsetEprocessParentCID 684
1143 #define DEBUG_DATA_OffsetEprocessDirectoryTableBase 686
1144 #define DEBUG_DATA_SizePrcb 688
1145 #define DEBUG_DATA_OffsetPrcbDpcRoutine 690
1146 #define DEBUG_DATA_OffsetPrcbCurrentThread 692
1147 #define DEBUG_DATA_OffsetPrcbMhz 694
1148 #define DEBUG_DATA_OffsetPrcbCpuType 696
1149 #define DEBUG_DATA_OffsetPrcbVendorString 698
1150 #define DEBUG_DATA_OffsetPrcbProcessorState 700
1151 #define DEBUG_DATA_OffsetPrcbNumber 702
1152 #define DEBUG_DATA_SizeEThread 704
1153 #define DEBUG_DATA_KdPrintCircularBufferPtrAddr 712
1154 #define DEBUG_DATA_KdPrintBufferSizeAddr 720
1155 
1156 #define DEBUG_DATA_PaeEnabled 100000
1157 #define DEBUG_DATA_SharedUserData 100008
1158 #define DEBUG_DATA_ProductType 100016
1159 #define DEBUG_DATA_SuiteMask 100024
1160 
1161   typedef struct _DEBUG_PROCESSOR_IDENTIFICATION_ALPHA {
1162     ULONG Type;
1163     ULONG Revision;
1164   } DEBUG_PROCESSOR_IDENTIFICATION_ALPHA,*PDEBUG_PROCESSOR_IDENTIFICATION_ALPHA;
1165 
1166   typedef struct _DEBUG_PROCESSOR_IDENTIFICATION_AMD64 {
1167     ULONG Family;
1168     ULONG Model;
1169     ULONG Stepping;
1170     CHAR VendorString[16];
1171   } DEBUG_PROCESSOR_IDENTIFICATION_AMD64,*PDEBUG_PROCESSOR_IDENTIFICATION_AMD64;
1172 
1173   typedef struct _DEBUG_PROCESSOR_IDENTIFICATION_IA64 {
1174     ULONG Model;
1175     ULONG Revision;
1176     ULONG Family;
1177     ULONG ArchRev;
1178     CHAR VendorString[16];
1179   } DEBUG_PROCESSOR_IDENTIFICATION_IA64,*PDEBUG_PROCESSOR_IDENTIFICATION_IA64;
1180 
1181   typedef struct _DEBUG_PROCESSOR_IDENTIFICATION_X86 {
1182     ULONG Family;
1183     ULONG Model;
1184     ULONG Stepping;
1185     CHAR VendorString[16];
1186   } DEBUG_PROCESSOR_IDENTIFICATION_X86,*PDEBUG_PROCESSOR_IDENTIFICATION_X86;
1187 
1188   typedef struct _DEBUG_PROCESSOR_IDENTIFICATION_ARM {
1189     ULONG Type;
1190     ULONG Revision;
1191   } DEBUG_PROCESSOR_IDENTIFICATION_ARM,*PDEBUG_PROCESSOR_IDENTIFICATION_ARM;
1192 
1193   typedef union _DEBUG_PROCESSOR_IDENTIFICATION_ALL {
1194     DEBUG_PROCESSOR_IDENTIFICATION_ALPHA Alpha;
1195     DEBUG_PROCESSOR_IDENTIFICATION_AMD64 Amd64;
1196     DEBUG_PROCESSOR_IDENTIFICATION_IA64 Ia64;
1197     DEBUG_PROCESSOR_IDENTIFICATION_X86 X86;
1198     DEBUG_PROCESSOR_IDENTIFICATION_ARM Arm;
1199   } DEBUG_PROCESSOR_IDENTIFICATION_ALL,*PDEBUG_PROCESSOR_IDENTIFICATION_ALL;
1200 
1201 #define DEBUG_DATA_KPCR_OFFSET 0
1202 #define DEBUG_DATA_KPRCB_OFFSET 1
1203 #define DEBUG_DATA_KTHREAD_OFFSET 2
1204 #define DEBUG_DATA_BASE_TRANSLATION_VIRTUAL_OFFSET 3
1205 #define DEBUG_DATA_PROCESSOR_IDENTIFICATION 4
1206 #define DEBUG_DATA_PROCESSOR_SPEED 5
1207 
1208 #undef INTERFACE
1209 #define INTERFACE IDebugDataSpaces
DECLARE_INTERFACE_(IDebugDataSpaces,IUnknown)1210   DECLARE_INTERFACE_(IDebugDataSpaces,IUnknown) {
1211     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1212     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1213     STDMETHOD_(ULONG,Release)(THIS) PURE;
1214     STDMETHOD(ReadVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1215     STDMETHOD(WriteVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1216     STDMETHOD(SearchVirtual)(THIS_ ULONG64 Offset,ULONG64 Length,PVOID Pattern,ULONG PatternSize,ULONG PatternGranularity,PULONG64 MatchOffset) PURE;
1217     STDMETHOD(ReadVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1218     STDMETHOD(WriteVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1219     STDMETHOD(ReadPointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1220     STDMETHOD(WritePointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1221     STDMETHOD(ReadPhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1222     STDMETHOD(WritePhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1223     STDMETHOD(ReadControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1224     STDMETHOD(WriteControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1225     STDMETHOD(ReadIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1226     STDMETHOD(WriteIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1227     STDMETHOD(ReadMsr)(THIS_ ULONG Msr,PULONG64 Value) PURE;
1228     STDMETHOD(WriteMsr)(THIS_ ULONG Msr,ULONG64 Value) PURE;
1229     STDMETHOD(ReadBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1230     STDMETHOD(WriteBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1231     STDMETHOD(CheckLowMemory)(THIS) PURE;
1232     STDMETHOD(ReadDebuggerData)(THIS_ ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1233     STDMETHOD(ReadProcessorSystemData)(THIS_ ULONG Processor,ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1234   };
1235 
1236 #define DEBUG_HANDLE_DATA_TYPE_BASIC 0
1237 #define DEBUG_HANDLE_DATA_TYPE_TYPE_NAME 1
1238 #define DEBUG_HANDLE_DATA_TYPE_OBJECT_NAME 2
1239 #define DEBUG_HANDLE_DATA_TYPE_HANDLE_COUNT 3
1240 #define DEBUG_HANDLE_DATA_TYPE_TYPE_NAME_WIDE 4
1241 #define DEBUG_HANDLE_DATA_TYPE_OBJECT_NAME_WIDE 5
1242 
1243   typedef struct _DEBUG_HANDLE_DATA_BASIC {
1244     ULONG TypeNameSize;
1245     ULONG ObjectNameSize;
1246     ULONG Attributes;
1247     ULONG GrantedAccess;
1248     ULONG HandleCount;
1249     ULONG PointerCount;
1250   } DEBUG_HANDLE_DATA_BASIC,*PDEBUG_HANDLE_DATA_BASIC;
1251 
1252 #undef INTERFACE
1253 #define INTERFACE IDebugDataSpaces2
DECLARE_INTERFACE_(IDebugDataSpaces2,IUnknown)1254   DECLARE_INTERFACE_(IDebugDataSpaces2,IUnknown) {
1255     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1256     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1257     STDMETHOD_(ULONG,Release)(THIS) PURE;
1258     STDMETHOD(ReadVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1259     STDMETHOD(WriteVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1260     STDMETHOD(SearchVirtual)(THIS_ ULONG64 Offset,ULONG64 Length,PVOID Pattern,ULONG PatternSize,ULONG PatternGranularity,PULONG64 MatchOffset) PURE;
1261     STDMETHOD(ReadVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1262     STDMETHOD(WriteVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1263     STDMETHOD(ReadPointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1264     STDMETHOD(WritePointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1265     STDMETHOD(ReadPhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1266     STDMETHOD(WritePhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1267     STDMETHOD(ReadControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1268     STDMETHOD(WriteControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1269     STDMETHOD(ReadIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1270     STDMETHOD(WriteIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1271     STDMETHOD(ReadMsr)(THIS_ ULONG Msr,PULONG64 Value) PURE;
1272     STDMETHOD(WriteMsr)(THIS_ ULONG Msr,ULONG64 Value) PURE;
1273     STDMETHOD(ReadBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1274     STDMETHOD(WriteBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1275     STDMETHOD(CheckLowMemory)(THIS) PURE;
1276     STDMETHOD(ReadDebuggerData)(THIS_ ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1277     STDMETHOD(ReadProcessorSystemData)(THIS_ ULONG Processor,ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1278     STDMETHOD(VirtualToPhysical)(THIS_ ULONG64 Virtual,PULONG64 Physical) PURE;
1279     STDMETHOD(GetVirtualTranslationPhysicalOffsets)(THIS_ ULONG64 Virtual,PULONG64 Offsets,ULONG OffsetsSize,PULONG Levels) PURE;
1280     STDMETHOD(ReadHandleData)(THIS_ ULONG64 Handle,ULONG DataType,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1281     STDMETHOD(FillVirtual)(THIS_ ULONG64 Start,ULONG Size,PVOID Pattern,ULONG PatternSize,PULONG Filled) PURE;
1282     STDMETHOD(FillPhysical)(THIS_ ULONG64 Start,ULONG Size,PVOID Pattern,ULONG PatternSize,PULONG Filled) PURE;
1283     STDMETHOD(QueryVirtual)(THIS_ ULONG64 Offset,PMEMORY_BASIC_INFORMATION64 Info) PURE;
1284   };
1285 
1286 #undef INTERFACE
1287 #define INTERFACE IDebugDataSpaces3
DECLARE_INTERFACE_(IDebugDataSpaces3,IUnknown)1288   DECLARE_INTERFACE_(IDebugDataSpaces3,IUnknown) {
1289     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1290     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1291     STDMETHOD_(ULONG,Release)(THIS) PURE;
1292     STDMETHOD(ReadVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1293     STDMETHOD(WriteVirtual)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1294     STDMETHOD(SearchVirtual)(THIS_ ULONG64 Offset,ULONG64 Length,PVOID Pattern,ULONG PatternSize,ULONG PatternGranularity,PULONG64 MatchOffset) PURE;
1295     STDMETHOD(ReadVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1296     STDMETHOD(WriteVirtualUncached)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1297     STDMETHOD(ReadPointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1298     STDMETHOD(WritePointersVirtual)(THIS_ ULONG Count,ULONG64 Offset,PULONG64 Ptrs) PURE;
1299     STDMETHOD(ReadPhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1300     STDMETHOD(WritePhysical)(THIS_ ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1301     STDMETHOD(ReadControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1302     STDMETHOD(WriteControl)(THIS_ ULONG Processor,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1303     STDMETHOD(ReadIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1304     STDMETHOD(WriteIo)(THIS_ ULONG InterfaceType,ULONG BusNumber,ULONG AddressSpace,ULONG64 Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1305     STDMETHOD(ReadMsr)(THIS_ ULONG Msr,PULONG64 Value) PURE;
1306     STDMETHOD(WriteMsr)(THIS_ ULONG Msr,ULONG64 Value) PURE;
1307     STDMETHOD(ReadBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1308     STDMETHOD(WriteBusData)(THIS_ ULONG BusDataType,ULONG BusNumber,ULONG SlotNumber,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1309     STDMETHOD(CheckLowMemory)(THIS) PURE;
1310     STDMETHOD(ReadDebuggerData)(THIS_
1311       ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1312     STDMETHOD(ReadProcessorSystemData)(THIS_ ULONG Processor,ULONG Index,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1313     STDMETHOD(VirtualToPhysical)(THIS_ ULONG64 Virtual,PULONG64 Physical) PURE;
1314     STDMETHOD(GetVirtualTranslationPhysicalOffsets)(THIS_ ULONG64 Virtual,PULONG64 Offsets,ULONG OffsetsSize,PULONG Levels) PURE;
1315     STDMETHOD(ReadHandleData)(THIS_ ULONG64 Handle,ULONG DataType,PVOID Buffer,ULONG BufferSize,PULONG DataSize) PURE;
1316     STDMETHOD(FillVirtual)(THIS_ ULONG64 Start,ULONG Size,PVOID Pattern,ULONG PatternSize,PULONG Filled) PURE;
1317     STDMETHOD(FillPhysical)(THIS_ ULONG64 Start,ULONG Size,PVOID Pattern,ULONG PatternSize,PULONG Filled) PURE;
1318     STDMETHOD(QueryVirtual)(THIS_ ULONG64 Offset,PMEMORY_BASIC_INFORMATION64 Info) PURE;
1319     STDMETHOD(ReadImageNtHeaders)(THIS_ ULONG64 ImageBase,PIMAGE_NT_HEADERS64 Headers) PURE;
1320     STDMETHOD(ReadTagged)(THIS_ LPGUID Tag,ULONG Offset,PVOID Buffer,ULONG BufferSize,PULONG TotalSize) PURE;
1321     STDMETHOD(StartEnumTagged)(THIS_ PULONG64 Handle) PURE;
1322     STDMETHOD(GetNextTagged)(THIS_ ULONG64 Handle,LPGUID Tag,PULONG Size) PURE;
1323     STDMETHOD(EndEnumTagged)(THIS_ ULONG64 Handle) PURE;
1324   };
1325 
1326 #define DEBUG_EVENT_BREAKPOINT 0x00000001
1327 #define DEBUG_EVENT_EXCEPTION 0x00000002
1328 #define DEBUG_EVENT_CREATE_THREAD 0x00000004
1329 #define DEBUG_EVENT_EXIT_THREAD 0x00000008
1330 #define DEBUG_EVENT_CREATE_PROCESS 0x00000010
1331 #define DEBUG_EVENT_EXIT_PROCESS 0x00000020
1332 #define DEBUG_EVENT_LOAD_MODULE 0x00000040
1333 #define DEBUG_EVENT_UNLOAD_MODULE 0x00000080
1334 #define DEBUG_EVENT_SYSTEM_ERROR 0x00000100
1335 #define DEBUG_EVENT_SESSION_STATUS 0x00000200
1336 #define DEBUG_EVENT_CHANGE_DEBUGGEE_STATE 0x00000400
1337 #define DEBUG_EVENT_CHANGE_ENGINE_STATE 0x00000800
1338 #define DEBUG_EVENT_CHANGE_SYMBOL_STATE 0x00001000
1339 
1340 #define DEBUG_SESSION_ACTIVE 0x00000000
1341 
1342 #define DEBUG_SESSION_END_SESSION_ACTIVE_TERMINATE 0x00000001
1343 #define DEBUG_SESSION_END_SESSION_ACTIVE_DETACH 0x00000002
1344 #define DEBUG_SESSION_END_SESSION_PASSIVE 0x00000003
1345 #define DEBUG_SESSION_END 0x00000004
1346 #define DEBUG_SESSION_REBOOT 0x00000005
1347 #define DEBUG_SESSION_HIBERNATE 0x00000006
1348 #define DEBUG_SESSION_FAILURE 0x00000007
1349 
1350 #define DEBUG_CDS_ALL 0xffffffff
1351 
1352 #define DEBUG_CDS_REGISTERS 0x00000001
1353 #define DEBUG_CDS_DATA 0x00000002
1354 
1355 #define DEBUG_CES_ALL 0xffffffff
1356 
1357 #define DEBUG_CES_CURRENT_THREAD 0x00000001
1358 #define DEBUG_CES_EFFECTIVE_PROCESSOR 0x00000002
1359 #define DEBUG_CES_BREAKPOINTS 0x00000004
1360 #define DEBUG_CES_CODE_LEVEL 0x00000008
1361 #define DEBUG_CES_EXECUTION_STATUS 0x00000010
1362 #define DEBUG_CES_ENGINE_OPTIONS 0x00000020
1363 #define DEBUG_CES_LOG_FILE 0x00000040
1364 #define DEBUG_CES_RADIX 0x00000080
1365 #define DEBUG_CES_EVENT_FILTERS 0x00000100
1366 #define DEBUG_CES_PROCESS_OPTIONS 0x00000200
1367 #define DEBUG_CES_EXTENSIONS 0x00000400
1368 #define DEBUG_CES_SYSTEMS 0x00000800
1369 #define DEBUG_CES_ASSEMBLY_OPTIONS 0x00001000
1370 #define DEBUG_CES_EXPRESSION_SYNTAX 0x00002000
1371 #define DEBUG_CES_TEXT_REPLACEMENTS 0x00004000
1372 
1373 #define DEBUG_CSS_ALL 0xffffffff
1374 
1375 #define DEBUG_CSS_LOADS 0x00000001
1376 #define DEBUG_CSS_UNLOADS 0x00000002
1377 #define DEBUG_CSS_SCOPE 0x00000004
1378 #define DEBUG_CSS_PATHS 0x00000008
1379 #define DEBUG_CSS_SYMBOL_OPTIONS 0x00000010
1380 #define DEBUG_CSS_TYPE_OPTIONS 0x00000020
1381 
1382 #undef INTERFACE
1383 #define INTERFACE IDebugEventCallbacks
DECLARE_INTERFACE_(IDebugEventCallbacks,IUnknown)1384   DECLARE_INTERFACE_(IDebugEventCallbacks,IUnknown) {
1385     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1386     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1387     STDMETHOD_(ULONG,Release)(THIS) PURE;
1388     STDMETHOD(GetInterestMask)(THIS_ PULONG Mask) PURE;
1389     STDMETHOD(Breakpoint)(THIS_ PDEBUG_BREAKPOINT Bp) PURE;
1390     STDMETHOD(Exception)(THIS_ PEXCEPTION_RECORD64 Exception,ULONG FirstChance) PURE;
1391     STDMETHOD(CreateThread)(THIS_ ULONG64 Handle,ULONG64 DataOffset,ULONG64 StartOffset) PURE;
1392     STDMETHOD(ExitThread)(THIS_ ULONG ExitCode) PURE;
1393     STDMETHOD(CreateProcess)(THIS_ ULONG64 ImageFileHandle,ULONG64 Handle,ULONG64 BaseOffset,ULONG ModuleSize,PCSTR ModuleName,PCSTR ImageName,ULONG CheckSum,ULONG TimeDateStamp,ULONG64 InitialThreadHandle,ULONG64 ThreadDataOffset,ULONG64 StartOffset) PURE;
1394     STDMETHOD(ExitProcess)(THIS_ ULONG ExitCode) PURE;
1395     STDMETHOD(LoadModule)(THIS_ ULONG64 ImageFileHandle,ULONG64 BaseOffset,ULONG ModuleSize,PCSTR ModuleName,PCSTR ImageName,ULONG CheckSum,ULONG TimeDateStamp) PURE;
1396     STDMETHOD(UnloadModule)(THIS_ PCSTR ImageBaseName,ULONG64 BaseOffset) PURE;
1397     STDMETHOD(SystemError)(THIS_ ULONG Error,ULONG Level) PURE;
1398     STDMETHOD(SessionStatus)(THIS_ ULONG Status) PURE;
1399     STDMETHOD(ChangeDebuggeeState)(THIS_ ULONG Flags,ULONG64 Argument) PURE;
1400     STDMETHOD(ChangeEngineState)(THIS_ ULONG Flags,ULONG64 Argument) PURE;
1401     STDMETHOD(ChangeSymbolState)(THIS_ ULONG Flags,ULONG64 Argument) PURE;
1402   };
1403 
1404 #undef INTERFACE
1405 #define INTERFACE IDebugInputCallbacks
DECLARE_INTERFACE_(IDebugInputCallbacks,IUnknown)1406   DECLARE_INTERFACE_(IDebugInputCallbacks,IUnknown) {
1407     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1408     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1409     STDMETHOD_(ULONG,Release)(THIS) PURE;
1410     STDMETHOD(StartInput)(THIS_ ULONG BufferSize) PURE;
1411     STDMETHOD(EndInput)(THIS) PURE;
1412   };
1413 
1414 #undef INTERFACE
1415 #define INTERFACE IDebugOutputCallbacks
DECLARE_INTERFACE_(IDebugOutputCallbacks,IUnknown)1416   DECLARE_INTERFACE_(IDebugOutputCallbacks,IUnknown) {
1417     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1418     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1419     STDMETHOD_(ULONG,Release)(THIS) PURE;
1420     STDMETHOD(Output)(THIS_ ULONG Mask,PCSTR Text) PURE;
1421   };
1422 
1423 #define DEBUG_REGISTER_SUB_REGISTER 0x00000001
1424 
1425 #define DEBUG_REGISTERS_DEFAULT 0x00000000
1426 #define DEBUG_REGISTERS_INT32 0x00000001
1427 #define DEBUG_REGISTERS_INT64 0x00000002
1428 #define DEBUG_REGISTERS_FLOAT 0x00000004
1429 #define DEBUG_REGISTERS_ALL 0x00000007
1430 
1431   typedef struct _DEBUG_REGISTER_DESCRIPTION {
1432     ULONG Type;
1433     ULONG Flags;
1434     ULONG SubregMaster;
1435     ULONG SubregLength;
1436     ULONG64 SubregMask;
1437     ULONG SubregShift;
1438     ULONG Reserved0;
1439   } DEBUG_REGISTER_DESCRIPTION,*PDEBUG_REGISTER_DESCRIPTION;
1440 
1441 #undef INTERFACE
1442 #define INTERFACE IDebugRegisters
DECLARE_INTERFACE_(IDebugRegisters,IUnknown)1443   DECLARE_INTERFACE_(IDebugRegisters,IUnknown) {
1444     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1445     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1446     STDMETHOD_(ULONG,Release)(THIS) PURE;
1447     STDMETHOD(GetNumberRegisters)(THIS_ PULONG Number) PURE;
1448     STDMETHOD(GetDescription)(THIS_ ULONG Register,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize,PDEBUG_REGISTER_DESCRIPTION Desc) PURE;
1449     STDMETHOD(GetIndexByName)(THIS_ PCSTR Name,PULONG Index) PURE;
1450     STDMETHOD(GetValue)(THIS_ ULONG Register,PDEBUG_VALUE Value) PURE;
1451     STDMETHOD(SetValue)(THIS_ ULONG Register,PDEBUG_VALUE Value) PURE;
1452     STDMETHOD(GetValues)(THIS_ ULONG Count,PULONG Indices,ULONG Start,PDEBUG_VALUE Values) PURE;
1453     STDMETHOD(SetValues)(THIS_ ULONG Count,PULONG Indices,ULONG Start,PDEBUG_VALUE Values) PURE;
1454     STDMETHOD(OutputRegisters)(THIS_ ULONG OutputControl,ULONG Flags) PURE;
1455     STDMETHOD(GetInstructionOffset)(THIS_ PULONG64 Offset) PURE;
1456     STDMETHOD(GetStackOffset)(THIS_ PULONG64 Offset) PURE;
1457     STDMETHOD(GetFrameOffset)(THIS_ PULONG64 Offset) PURE;
1458   };
1459 
1460 #define DEBUG_OUTPUT_SYMBOLS_DEFAULT 0x00000000
1461 #define DEBUG_OUTPUT_SYMBOLS_NO_NAMES 0x00000001
1462 #define DEBUG_OUTPUT_SYMBOLS_NO_OFFSETS 0x00000002
1463 #define DEBUG_OUTPUT_SYMBOLS_NO_VALUES 0x00000004
1464 #define DEBUG_OUTPUT_SYMBOLS_NO_TYPES 0x00000010
1465 
1466 #define DEBUG_OUTPUT_NAME_END "**NAME**"
1467 #define DEBUG_OUTPUT_OFFSET_END "**OFF**"
1468 #define DEBUG_OUTPUT_VALUE_END "**VALUE**"
1469 #define DEBUG_OUTPUT_TYPE_END "**TYPE**"
1470 
1471 #define DEBUG_SYMBOL_EXPANSION_LEVEL_MASK 0x0000000f
1472 #define DEBUG_SYMBOL_EXPANDED 0x00000010
1473 #define DEBUG_SYMBOL_READ_ONLY 0x00000020
1474 #define DEBUG_SYMBOL_IS_ARRAY 0x00000040
1475 #define DEBUG_SYMBOL_IS_FLOAT 0x00000080
1476 #define DEBUG_SYMBOL_IS_ARGUMENT 0x00000100
1477 #define DEBUG_SYMBOL_IS_LOCAL 0x00000200
1478 
1479   typedef struct _DEBUG_SYMBOL_PARAMETERS {
1480     ULONG64 Module;
1481     ULONG TypeId;
1482     ULONG ParentSymbol;
1483     ULONG SubElements;
1484     ULONG Flags;
1485     ULONG64 Reserved;
1486   } DEBUG_SYMBOL_PARAMETERS,*PDEBUG_SYMBOL_PARAMETERS;
1487 
1488 #undef INTERFACE
1489 #define INTERFACE IDebugSymbolGroup
DECLARE_INTERFACE_(IDebugSymbolGroup,IUnknown)1490   DECLARE_INTERFACE_(IDebugSymbolGroup,IUnknown) {
1491     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1492     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1493     STDMETHOD_(ULONG,Release)(THIS) PURE;
1494     STDMETHOD(GetNumberSymbols)(THIS_ PULONG Number) PURE;
1495     STDMETHOD(AddSymbol)(THIS_ PCSTR Name,PULONG Index) PURE;
1496     STDMETHOD(RemoveSymbolByName)(THIS_ PCSTR Name) PURE;
1497     STDMETHOD(RemoveSymbolByIndex)(THIS_ ULONG Index) PURE;
1498     STDMETHOD(GetSymbolName)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG NameSize) PURE;
1499     STDMETHOD(GetSymbolParameters)(THIS_ ULONG Start,ULONG Count,PDEBUG_SYMBOL_PARAMETERS Params) PURE;
1500     STDMETHOD(ExpandSymbol)(THIS_ ULONG Index,WINBOOL Expand) PURE;
1501     STDMETHOD(OutputSymbols)(THIS_ ULONG OutputControl,ULONG Flags,ULONG Start,ULONG Count) PURE;
1502     STDMETHOD(WriteSymbol)(THIS_ ULONG Index,PCSTR Value) PURE;
1503     STDMETHOD(OutputAsType)(THIS_ ULONG Index,PCSTR Type) PURE;
1504   };
1505 
1506 #define DEBUG_MODULE_LOADED 0x00000000
1507 #define DEBUG_MODULE_UNLOADED 0x00000001
1508 #define DEBUG_MODULE_USER_MODE 0x00000002
1509 #define DEBUG_MODULE_SYM_BAD_CHECKSUM 0x00010000
1510 
1511 #define DEBUG_SYMTYPE_NONE 0
1512 #define DEBUG_SYMTYPE_COFF 1
1513 #define DEBUG_SYMTYPE_CODEVIEW 2
1514 #define DEBUG_SYMTYPE_PDB 3
1515 #define DEBUG_SYMTYPE_EXPORT 4
1516 #define DEBUG_SYMTYPE_DEFERRED 5
1517 #define DEBUG_SYMTYPE_SYM 6
1518 #define DEBUG_SYMTYPE_DIA 7
1519 
1520   typedef struct _DEBUG_MODULE_PARAMETERS {
1521     ULONG64 Base;
1522     ULONG Size;
1523     ULONG TimeDateStamp;
1524     ULONG Checksum;
1525     ULONG Flags;
1526     ULONG SymbolType;
1527     ULONG ImageNameSize;
1528     ULONG ModuleNameSize;
1529     ULONG LoadedImageNameSize;
1530     ULONG SymbolFileNameSize;
1531     ULONG MappedImageNameSize;
1532     ULONG64 Reserved[2];
1533   } DEBUG_MODULE_PARAMETERS,*PDEBUG_MODULE_PARAMETERS;
1534 
1535 #define DEBUG_SCOPE_GROUP_ARGUMENTS 0x00000001
1536 #define DEBUG_SCOPE_GROUP_LOCALS 0x00000002
1537 #define DEBUG_SCOPE_GROUP_ALL 0x00000003
1538 
1539 #define DEBUG_OUTTYPE_DEFAULT 0x00000000
1540 #define DEBUG_OUTTYPE_NO_INDENT 0x00000001
1541 #define DEBUG_OUTTYPE_NO_OFFSET 0x00000002
1542 #define DEBUG_OUTTYPE_VERBOSE 0x00000004
1543 #define DEBUG_OUTTYPE_COMPACT_OUTPUT 0x00000008
1544 #define DEBUG_OUTTYPE_RECURSION_LEVEL(Max) (((Max) & 0xf) << 4)
1545 #define DEBUG_OUTTYPE_ADDRESS_OF_FIELD 0x00010000
1546 #define DEBUG_OUTTYPE_ADDRESS_AT_END 0x00020000
1547 #define DEBUG_OUTTYPE_BLOCK_RECURSE 0x00200000
1548 
1549 #define DEBUG_FIND_SOURCE_DEFAULT 0x00000000
1550 #define DEBUG_FIND_SOURCE_FULL_PATH 0x00000001
1551 #define DEBUG_FIND_SOURCE_BEST_MATCH 0x00000002
1552 
1553 #define DEBUG_INVALID_OFFSET ((ULONG64)-1)
1554 
1555 #undef INTERFACE
1556 #define INTERFACE IDebugSymbols
DECLARE_INTERFACE_(IDebugSymbols,IUnknown)1557   DECLARE_INTERFACE_(IDebugSymbols,IUnknown) {
1558     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1559     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1560     STDMETHOD_(ULONG,Release)(THIS) PURE;
1561     STDMETHOD(GetSymbolOptions)(THIS_ PULONG Options) PURE;
1562     STDMETHOD(AddSymbolOptions)(THIS_ ULONG Options) PURE;
1563     STDMETHOD(RemoveSymbolOptions)(THIS_ ULONG Options) PURE;
1564     STDMETHOD(SetSymbolOptions)(THIS_ ULONG Options) PURE;
1565     STDMETHOD(GetNameByOffset)(THIS_ ULONG64 Offset,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize,PULONG64 Displacement) PURE;
1566     STDMETHOD(GetOffsetByName)(THIS_ PCSTR Symbol,PULONG64 Offset) PURE;
1567     STDMETHOD(GetNearNameByOffset)(THIS_ ULONG64 Offset,LONG Delta,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize,PULONG64 Displacement) PURE;
1568     STDMETHOD(GetLineByOffset)(THIS_ ULONG64 Offset,PULONG Line,PSTR FileBuffer,ULONG FileBufferSize,PULONG FileSize,PULONG64 Displacement) PURE;
1569     STDMETHOD(GetOffsetByLine)(THIS_ ULONG Line,PCSTR File,PULONG64 Offset) PURE;
1570     STDMETHOD(GetNumberModules)(THIS_ PULONG Loaded,PULONG Unloaded) PURE;
1571     STDMETHOD(GetModuleByIndex)(THIS_ ULONG Index,PULONG64 Base) PURE;
1572     STDMETHOD(GetModuleByModuleName)(THIS_ PCSTR Name,ULONG StartIndex,PULONG Index,PULONG64 Base) PURE;
1573     STDMETHOD(GetModuleByOffset)(THIS_ ULONG64 Offset,ULONG StartIndex,PULONG Index,PULONG64 Base) PURE;
1574     STDMETHOD(GetModuleNames)(THIS_ ULONG Index,ULONG64 Base,PSTR ImageNameBuffer,ULONG ImageNameBufferSize,PULONG ImageNameSize,PSTR ModuleNameBuffer,ULONG ModuleNameBufferSize,PULONG ModuleNameSize,PSTR LoadedImageNameBuffer,ULONG LoadedImageNameBufferSize,PULONG LoadedImageNameSize) PURE;
1575     STDMETHOD(GetModuleParameters)(THIS_ ULONG Count,PULONG64 Bases,ULONG Start,PDEBUG_MODULE_PARAMETERS Params) PURE;
1576     STDMETHOD(GetSymbolModule)(THIS_ PCSTR Symbol,PULONG64 Base) PURE;
1577     STDMETHOD(GetTypeName)(THIS_ ULONG64 Module,ULONG TypeId,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize) PURE;
1578     STDMETHOD(GetTypeId)(THIS_ ULONG64 Module,PCSTR Name,PULONG TypeId) PURE;
1579     STDMETHOD(GetTypeSize)(THIS_ ULONG64 Module,ULONG TypeId,PULONG Size) PURE;
1580     STDMETHOD(GetFieldOffset)(THIS_ ULONG64 Module,ULONG TypeId,PCSTR Field,PULONG Offset) PURE;
1581     STDMETHOD(GetSymbolTypeId)(THIS_ PCSTR Symbol,PULONG TypeId,PULONG64 Module) PURE;
1582     STDMETHOD(GetOffsetTypeId)(THIS_ ULONG64 Offset,PULONG TypeId,PULONG64 Module) PURE;
1583     STDMETHOD(ReadTypedDataVirtual)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1584     STDMETHOD(WriteTypedDataVirtual)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1585     STDMETHOD(OutputTypedDataVirtual)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG64 Module,ULONG TypeId,ULONG Flags) PURE;
1586     STDMETHOD(ReadTypedDataPhysical)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1587     STDMETHOD(WriteTypedDataPhysical)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1588     STDMETHOD(OutputTypedDataPhysical)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG64 Module,ULONG TypeId,ULONG Flags) PURE;
1589     STDMETHOD(GetScope)(THIS_ PULONG64 InstructionOffset,PDEBUG_STACK_FRAME ScopeFrame,PVOID ScopeContext,ULONG ScopeContextSize) PURE;
1590     STDMETHOD(SetScope)(THIS_ ULONG64 InstructionOffset,PDEBUG_STACK_FRAME ScopeFrame,PVOID ScopeContext,ULONG ScopeContextSize) PURE;
1591     STDMETHOD(ResetScope)(THIS) PURE;
1592     STDMETHOD(GetScopeSymbolGroup)(THIS_ ULONG Flags,PDEBUG_SYMBOL_GROUP Update,PDEBUG_SYMBOL_GROUP *Symbols) PURE;
1593     STDMETHOD(CreateSymbolGroup)(THIS_ PDEBUG_SYMBOL_GROUP *Group) PURE;
1594     STDMETHOD(StartSymbolMatch)(THIS_ PCSTR Pattern,PULONG64 Handle) PURE;
1595     STDMETHOD(GetNextSymbolMatch)(THIS_ ULONG64 Handle,PSTR Buffer,ULONG BufferSize,PULONG MatchSize,PULONG64 Offset) PURE;
1596     STDMETHOD(EndSymbolMatch)(THIS_ ULONG64 Handle) PURE;
1597     STDMETHOD(Reload)(THIS_ PCSTR Module) PURE;
1598     STDMETHOD(GetSymbolPath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1599     STDMETHOD(SetSymbolPath)(THIS_ PCSTR Path) PURE;
1600     STDMETHOD(AppendSymbolPath)(THIS_ PCSTR Addition) PURE;
1601     STDMETHOD(GetImagePath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1602     STDMETHOD(SetImagePath)(THIS_ PCSTR Path) PURE;
1603     STDMETHOD(AppendImagePath)(THIS_ PCSTR Addition) PURE;
1604     STDMETHOD(GetSourcePath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1605     STDMETHOD(GetSourcePathElement)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG ElementSize) PURE;
1606     STDMETHOD(SetSourcePath)(THIS_ PCSTR Path) PURE;
1607     STDMETHOD(AppendSourcePath)(THIS_ PCSTR Addition) PURE;
1608     STDMETHOD(FindSourceFile)(THIS_ ULONG StartElement,PCSTR File,ULONG Flags,PULONG FoundElement,PSTR Buffer,ULONG BufferSize,PULONG FoundSize) PURE;
1609     STDMETHOD(GetSourceFileLineOffsets)(THIS_ PCSTR File,PULONG64 Buffer,ULONG BufferLines,PULONG FileLines) PURE;
1610   };
1611 
1612 #define DEBUG_MODNAME_IMAGE 0x00000000
1613 #define DEBUG_MODNAME_MODULE 0x00000001
1614 #define DEBUG_MODNAME_LOADED_IMAGE 0x00000002
1615 #define DEBUG_MODNAME_SYMBOL_FILE 0x00000003
1616 #define DEBUG_MODNAME_MAPPED_IMAGE 0x00000004
1617 
1618 #define DEBUG_TYPEOPTS_UNICODE_DISPLAY 0x00000001
1619 #define DEBUG_TYPEOPTS_LONGSTATUS_DISPLAY 0x00000002
1620 #define DEBUG_TYPEOPTS_FORCERADIX_OUTPUT 0x00000004
1621 
1622 #undef INTERFACE
1623 #define INTERFACE IDebugSymbols2
DECLARE_INTERFACE_(IDebugSymbols2,IUnknown)1624   DECLARE_INTERFACE_(IDebugSymbols2,IUnknown) {
1625     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1626     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1627     STDMETHOD_(ULONG,Release)(THIS) PURE;
1628     STDMETHOD(GetSymbolOptions)(THIS_ PULONG Options) PURE;
1629     STDMETHOD(AddSymbolOptions)(THIS_ ULONG Options) PURE;
1630     STDMETHOD(RemoveSymbolOptions)(THIS_ ULONG Options) PURE;
1631     STDMETHOD(SetSymbolOptions)(THIS_ ULONG Options) PURE;
1632     STDMETHOD(GetNameByOffset)(THIS_ ULONG64 Offset,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize,PULONG64 Displacement) PURE;
1633     STDMETHOD(GetOffsetByName)(THIS_ PCSTR Symbol,PULONG64 Offset) PURE;
1634     STDMETHOD(GetNearNameByOffset)(THIS_ ULONG64 Offset,LONG Delta,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize,PULONG64 Displacement) PURE;
1635     STDMETHOD(GetLineByOffset)(THIS_ ULONG64 Offset,PULONG Line,PSTR FileBuffer,ULONG FileBufferSize,PULONG FileSize,PULONG64 Displacement) PURE;
1636     STDMETHOD(GetOffsetByLine)(THIS_ ULONG Line,PCSTR File,PULONG64 Offset) PURE;
1637     STDMETHOD(GetNumberModules)(THIS_ PULONG Loaded,PULONG Unloaded) PURE;
1638     STDMETHOD(GetModuleByIndex)(THIS_ ULONG Index,PULONG64 Base) PURE;
1639     STDMETHOD(GetModuleByModuleName)(THIS_ PCSTR Name,ULONG StartIndex,PULONG Index,PULONG64 Base) PURE;
1640     STDMETHOD(GetModuleByOffset)(THIS_ ULONG64 Offset,ULONG StartIndex,PULONG Index,PULONG64 Base) PURE;
1641     STDMETHOD(GetModuleNames)(THIS_ ULONG Index,ULONG64 Base,PSTR ImageNameBuffer,ULONG ImageNameBufferSize,PULONG ImageNameSize,PSTR ModuleNameBuffer,ULONG ModuleNameBufferSize,PULONG ModuleNameSize,PSTR LoadedImageNameBuffer,ULONG LoadedImageNameBufferSize,PULONG LoadedImageNameSize) PURE;
1642     STDMETHOD(GetModuleParameters)(THIS_ ULONG Count,PULONG64 Bases,ULONG Start,PDEBUG_MODULE_PARAMETERS Params) PURE;
1643     STDMETHOD(GetSymbolModule)(THIS_ PCSTR Symbol,PULONG64 Base) PURE;
1644     STDMETHOD(GetTypeName)(THIS_ ULONG64 Module,ULONG TypeId,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize) PURE;
1645     STDMETHOD(GetTypeId)(THIS_ ULONG64 Module,PCSTR Name,PULONG TypeId) PURE;
1646     STDMETHOD(GetTypeSize)(THIS_ ULONG64 Module,ULONG TypeId,PULONG Size) PURE;
1647     STDMETHOD(GetFieldOffset)(THIS_ ULONG64 Module,ULONG TypeId,PCSTR Field,PULONG Offset) PURE;
1648     STDMETHOD(GetSymbolTypeId)(THIS_ PCSTR Symbol,PULONG TypeId,PULONG64 Module) PURE;
1649     STDMETHOD(GetOffsetTypeId)(THIS_ ULONG64 Offset,PULONG TypeId,PULONG64 Module) PURE;
1650     STDMETHOD(ReadTypedDataVirtual)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1651     STDMETHOD(WriteTypedDataVirtual)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1652     STDMETHOD(OutputTypedDataVirtual)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG64 Module,ULONG TypeId,ULONG Flags) PURE;
1653     STDMETHOD(ReadTypedDataPhysical)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesRead) PURE;
1654     STDMETHOD(WriteTypedDataPhysical)(THIS_ ULONG64 Offset,ULONG64 Module,ULONG TypeId,PVOID Buffer,ULONG BufferSize,PULONG BytesWritten) PURE;
1655     STDMETHOD(OutputTypedDataPhysical)(THIS_ ULONG OutputControl,ULONG64 Offset,ULONG64 Module,ULONG TypeId,ULONG Flags) PURE;
1656     STDMETHOD(GetScope)(THIS_ PULONG64 InstructionOffset,PDEBUG_STACK_FRAME ScopeFrame,PVOID ScopeContext,ULONG ScopeContextSize) PURE;
1657     STDMETHOD(SetScope)(THIS_ ULONG64 InstructionOffset,PDEBUG_STACK_FRAME ScopeFrame,PVOID ScopeContext,ULONG ScopeContextSize) PURE;
1658     STDMETHOD(ResetScope)(THIS) PURE;
1659     STDMETHOD(GetScopeSymbolGroup)(THIS_ ULONG Flags,PDEBUG_SYMBOL_GROUP Update,PDEBUG_SYMBOL_GROUP *Symbols) PURE;
1660     STDMETHOD(CreateSymbolGroup)(THIS_ PDEBUG_SYMBOL_GROUP *Group) PURE;
1661     STDMETHOD(StartSymbolMatch)(THIS_ PCSTR Pattern,PULONG64 Handle) PURE;
1662     STDMETHOD(GetNextSymbolMatch)(THIS_ ULONG64 Handle,PSTR Buffer,ULONG BufferSize,PULONG MatchSize,PULONG64 Offset) PURE;
1663     STDMETHOD(EndSymbolMatch)(THIS_ ULONG64 Handle) PURE;
1664     STDMETHOD(Reload)(THIS_ PCSTR Module) PURE;
1665     STDMETHOD(GetSymbolPath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1666     STDMETHOD(SetSymbolPath)(THIS_ PCSTR Path) PURE;
1667     STDMETHOD(AppendSymbolPath)(THIS_ PCSTR Addition) PURE;
1668     STDMETHOD(GetImagePath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1669     STDMETHOD(SetImagePath)(THIS_ PCSTR Path) PURE;
1670     STDMETHOD(AppendImagePath)(THIS_ PCSTR Addition) PURE;
1671     STDMETHOD(GetSourcePath)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG PathSize) PURE;
1672     STDMETHOD(GetSourcePathElement)(THIS_ ULONG Index,PSTR Buffer,ULONG BufferSize,PULONG ElementSize) PURE;
1673     STDMETHOD(SetSourcePath)(THIS_ PCSTR Path) PURE;
1674     STDMETHOD(AppendSourcePath)(THIS_ PCSTR Addition) PURE;
1675     STDMETHOD(FindSourceFile)(THIS_ ULONG StartElement,PCSTR File,ULONG Flags,PULONG FoundElement,PSTR Buffer,ULONG BufferSize,PULONG FoundSize) PURE;
1676     STDMETHOD(GetSourceFileLineOffsets)(THIS_ PCSTR File,PULONG64 Buffer,ULONG BufferLines,PULONG FileLines) PURE;
1677     STDMETHOD(GetModuleVersionInformation)(THIS_ ULONG Index,ULONG64 Base,PCSTR Item,PVOID Buffer,ULONG BufferSize,PULONG VerInfoSize) PURE;
1678     STDMETHOD(GetModuleNameString)(THIS_ ULONG Which,ULONG Index,ULONG64 Base,PSTR Buffer,ULONG BufferSize,PULONG NameSize) PURE;
1679     STDMETHOD(GetConstantName)(THIS_ ULONG64 Module,ULONG TypeId,ULONG64 Value,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize) PURE;
1680     STDMETHOD(GetFieldName)(THIS_ ULONG64 Module,ULONG TypeId,ULONG FieldIndex,PSTR NameBuffer,ULONG NameBufferSize,PULONG NameSize) PURE;
1681     STDMETHOD(GetTypeOptions)(THIS_ PULONG Options) PURE;
1682     STDMETHOD(AddTypeOptions)(THIS_ ULONG Options) PURE;
1683     STDMETHOD(RemoveTypeOptions)(THIS_ ULONG Options) PURE;
1684     STDMETHOD(SetTypeOptions)(THIS_ ULONG Options) PURE;
1685   };
1686 
1687 #undef INTERFACE
1688 #define INTERFACE IDebugSystemObjects
DECLARE_INTERFACE_(IDebugSystemObjects,IUnknown)1689   DECLARE_INTERFACE_(IDebugSystemObjects,IUnknown) {
1690     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1691     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1692     STDMETHOD_(ULONG,Release)(THIS) PURE;
1693     STDMETHOD(GetEventThread)(THIS_ PULONG Id) PURE;
1694     STDMETHOD(GetEventProcess)(THIS_ PULONG Id) PURE;
1695     STDMETHOD(GetCurrentThreadId)(THIS_ PULONG Id) PURE;
1696     STDMETHOD(SetCurrentThreadId)(THIS_ ULONG Id) PURE;
1697     STDMETHOD(GetCurrentProcessId)(THIS_ PULONG Id) PURE;
1698     STDMETHOD(SetCurrentProcessId)(THIS_ ULONG Id) PURE;
1699     STDMETHOD(GetNumberThreads)(THIS_ PULONG Number) PURE;
1700     STDMETHOD(GetTotalNumberThreads)(THIS_ PULONG Total,PULONG LargestProcess) PURE;
1701     STDMETHOD(GetThreadIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1702     STDMETHOD(GetThreadIdByProcessor)(THIS_ ULONG Processor,PULONG Id) PURE;
1703     STDMETHOD(GetCurrentThreadDataOffset)(THIS_ PULONG64 Offset) PURE;
1704     STDMETHOD(GetThreadIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1705     STDMETHOD(GetCurrentThreadTeb)(THIS_ PULONG64 Offset) PURE;
1706     STDMETHOD(GetThreadIdByTeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1707     STDMETHOD(GetCurrentThreadSystemId)(THIS_ PULONG SysId) PURE;
1708     STDMETHOD(GetThreadIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1709     STDMETHOD(GetCurrentThreadHandle)(THIS_ PULONG64 Handle) PURE;
1710     STDMETHOD(GetThreadIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1711     STDMETHOD(GetNumberProcesses)(THIS_ PULONG Number) PURE;
1712     STDMETHOD(GetProcessIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1713     STDMETHOD(GetCurrentProcessDataOffset)(THIS_ PULONG64 Offset) PURE;
1714     STDMETHOD(GetProcessIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1715     STDMETHOD(GetCurrentProcessPeb)(THIS_ PULONG64 Offset) PURE;
1716     STDMETHOD(GetProcessIdByPeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1717     STDMETHOD(GetCurrentProcessSystemId)(THIS_ PULONG SysId) PURE;
1718     STDMETHOD(GetProcessIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1719     STDMETHOD(GetCurrentProcessHandle)(THIS_ PULONG64 Handle) PURE;
1720     STDMETHOD(GetProcessIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1721     STDMETHOD(GetCurrentProcessExecutableName)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG ExeSize) PURE;
1722   };
1723 
1724 #undef INTERFACE
1725 #define INTERFACE IDebugSystemObjects2
DECLARE_INTERFACE_(IDebugSystemObjects2,IUnknown)1726   DECLARE_INTERFACE_(IDebugSystemObjects2,IUnknown) {
1727     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1728     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1729     STDMETHOD_(ULONG,Release)(THIS) PURE;
1730     STDMETHOD(GetEventThread)(THIS_ PULONG Id) PURE;
1731     STDMETHOD(GetEventProcess)(THIS_ PULONG Id) PURE;
1732     STDMETHOD(GetCurrentThreadId)(THIS_ PULONG Id) PURE;
1733     STDMETHOD(SetCurrentThreadId)(THIS_ ULONG Id) PURE;
1734     STDMETHOD(GetCurrentProcessId)(THIS_ PULONG Id) PURE;
1735     STDMETHOD(SetCurrentProcessId)(THIS_ ULONG Id) PURE;
1736     STDMETHOD(GetNumberThreads)(THIS_ PULONG Number) PURE;
1737     STDMETHOD(GetTotalNumberThreads)(THIS_ PULONG Total,PULONG LargestProcess) PURE;
1738     STDMETHOD(GetThreadIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1739     STDMETHOD(GetThreadIdByProcessor)(THIS_ ULONG Processor,PULONG Id) PURE;
1740     STDMETHOD(GetCurrentThreadDataOffset)(THIS_ PULONG64 Offset) PURE;
1741     STDMETHOD(GetThreadIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1742     STDMETHOD(GetCurrentThreadTeb)(THIS_ PULONG64 Offset) PURE;
1743     STDMETHOD(GetThreadIdByTeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1744     STDMETHOD(GetCurrentThreadSystemId)(THIS_ PULONG SysId) PURE;
1745     STDMETHOD(GetThreadIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1746     STDMETHOD(GetCurrentThreadHandle)(THIS_ PULONG64 Handle) PURE;
1747     STDMETHOD(GetThreadIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1748     STDMETHOD(GetNumberProcesses)(THIS_ PULONG Number) PURE;
1749     STDMETHOD(GetProcessIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1750     STDMETHOD(GetCurrentProcessDataOffset)(THIS_ PULONG64 Offset) PURE;
1751     STDMETHOD(GetProcessIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1752     STDMETHOD(GetCurrentProcessPeb)(THIS_ PULONG64 Offset) PURE;
1753     STDMETHOD(GetProcessIdByPeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1754     STDMETHOD(GetCurrentProcessSystemId)(THIS_ PULONG SysId) PURE;
1755     STDMETHOD(GetProcessIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1756     STDMETHOD(GetCurrentProcessHandle)(THIS_ PULONG64 Handle) PURE;
1757     STDMETHOD(GetProcessIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1758     STDMETHOD(GetCurrentProcessExecutableName)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG ExeSize) PURE;
1759     STDMETHOD(GetCurrentProcessUpTime)(THIS_ PULONG UpTime) PURE;
1760     STDMETHOD(GetImplicitThreadDataOffset)(THIS_ PULONG64 Offset) PURE;
1761     STDMETHOD(SetImplicitThreadDataOffset)(THIS_ ULONG64 Offset) PURE;
1762     STDMETHOD(GetImplicitProcessDataOffset)(THIS_ PULONG64 Offset) PURE;
1763     STDMETHOD(SetImplicitProcessDataOffset)(THIS_ ULONG64 Offset) PURE;
1764   };
1765 
1766 #undef INTERFACE
1767 #define INTERFACE IDebugSystemObjects3
DECLARE_INTERFACE_(IDebugSystemObjects3,IUnknown)1768   DECLARE_INTERFACE_(IDebugSystemObjects3,IUnknown) {
1769     STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) PURE;
1770     STDMETHOD_(ULONG,AddRef)(THIS) PURE;
1771     STDMETHOD_(ULONG,Release)(THIS) PURE;
1772     STDMETHOD(GetEventThread)(THIS_ PULONG Id) PURE;
1773     STDMETHOD(GetEventProcess)(THIS_ PULONG Id) PURE;
1774     STDMETHOD(GetCurrentThreadId)(THIS_ PULONG Id) PURE;
1775     STDMETHOD(SetCurrentThreadId)(THIS_ ULONG Id) PURE;
1776     STDMETHOD(GetCurrentProcessId)(THIS_ PULONG Id) PURE;
1777     STDMETHOD(SetCurrentProcessId)(THIS_ ULONG Id) PURE;
1778     STDMETHOD(GetNumberThreads)(THIS_ PULONG Number) PURE;
1779     STDMETHOD(GetTotalNumberThreads)(THIS_ PULONG Total,PULONG LargestProcess) PURE;
1780     STDMETHOD(GetThreadIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1781     STDMETHOD(GetThreadIdByProcessor)(THIS_ ULONG Processor,PULONG Id) PURE;
1782     STDMETHOD(GetCurrentThreadDataOffset)(THIS_ PULONG64 Offset) PURE;
1783     STDMETHOD(GetThreadIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1784     STDMETHOD(GetCurrentThreadTeb)(THIS_ PULONG64 Offset) PURE;
1785     STDMETHOD(GetThreadIdByTeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1786     STDMETHOD(GetCurrentThreadSystemId)(THIS_ PULONG SysId) PURE;
1787     STDMETHOD(GetThreadIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1788     STDMETHOD(GetCurrentThreadHandle)(THIS_ PULONG64 Handle) PURE;
1789     STDMETHOD(GetThreadIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1790     STDMETHOD(GetNumberProcesses)(THIS_ PULONG Number) PURE;
1791     STDMETHOD(GetProcessIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids,PULONG SysIds) PURE;
1792     STDMETHOD(GetCurrentProcessDataOffset)(THIS_ PULONG64 Offset) PURE;
1793     STDMETHOD(GetProcessIdByDataOffset)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1794     STDMETHOD(GetCurrentProcessPeb)(THIS_ PULONG64 Offset) PURE;
1795     STDMETHOD(GetProcessIdByPeb)(THIS_ ULONG64 Offset,PULONG Id) PURE;
1796     STDMETHOD(GetCurrentProcessSystemId)(THIS_ PULONG SysId) PURE;
1797     STDMETHOD(GetProcessIdBySystemId)(THIS_ ULONG SysId,PULONG Id) PURE;
1798     STDMETHOD(GetCurrentProcessHandle)(THIS_ PULONG64 Handle) PURE;
1799     STDMETHOD(GetProcessIdByHandle)(THIS_ ULONG64 Handle,PULONG Id) PURE;
1800     STDMETHOD(GetCurrentProcessExecutableName)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG ExeSize) PURE;
1801     STDMETHOD(GetCurrentProcessUpTime)(THIS_ PULONG UpTime) PURE;
1802     STDMETHOD(GetImplicitThreadDataOffset)(THIS_ PULONG64 Offset) PURE;
1803     STDMETHOD(SetImplicitThreadDataOffset)(THIS_ ULONG64 Offset) PURE;
1804     STDMETHOD(GetImplicitProcessDataOffset)(THIS_ PULONG64 Offset) PURE;
1805     STDMETHOD(SetImplicitProcessDataOffset)(THIS_ ULONG64 Offset) PURE;
1806     STDMETHOD(GetEventSystem)(THIS_ PULONG Id) PURE;
1807     STDMETHOD(GetCurrentSystemId)(THIS_ PULONG Id) PURE;
1808     STDMETHOD(SetCurrentSystemId)(THIS_ ULONG Id) PURE;
1809     STDMETHOD(GetNumberSystems)(THIS_ PULONG Number) PURE;
1810     STDMETHOD(GetSystemIdsByIndex)(THIS_ ULONG Start,ULONG Count,PULONG Ids) PURE;
1811     STDMETHOD(GetTotalNumberThreadsAndProcesses)(THIS_ PULONG TotalThreads,PULONG TotalProcesses,PULONG LargestProcessThreads,PULONG LargestSystemThreads,PULONG LargestSystemProcesses) PURE;
1812     STDMETHOD(GetCurrentSystemServer)(THIS_ PULONG64 Server) PURE;
1813     STDMETHOD(GetSystemByServer)(THIS_ ULONG64 Server,PULONG Id) PURE;
1814     STDMETHOD(GetCurrentSystemServerName)(THIS_ PSTR Buffer,ULONG BufferSize,PULONG NameSize) PURE;
1815   };
1816 
1817 #define DEBUG_COMMAND_EXCEPTION_ID 0xdbe00dbe
1818 
1819 #define DEBUG_CMDEX_INVALID 0x00000000
1820 #define DEBUG_CMDEX_ADD_EVENT_STRING 0x00000001
1821 #define DEBUG_CMDEX_RESET_EVENT_STRINGS 0x00000002
1822 
1823 #if !defined(DEBUG_NO_IMPLEMENTATION) && !defined(__CRT__NO_INLINE)
DebugCommandException(ULONG Command,ULONG ArgSize,PVOID Arg)1824   __CRT_INLINE void DebugCommandException(ULONG Command,ULONG ArgSize,PVOID Arg) {
1825     ULONG_PTR ExArgs[4];
1826     ExArgs[0] = DEBUG_COMMAND_EXCEPTION_ID;
1827     ExArgs[1] = Command;
1828     ExArgs[2] = ArgSize;
1829     ExArgs[3] = (ULONG_PTR)Arg;
1830     RaiseException(DBG_COMMAND_EXCEPTION,0,4,ExArgs);
1831   }
1832 #endif
1833 
1834   typedef HRESULT (CALLBACK *PDEBUG_EXTENSION_INITIALIZE)(PULONG Version,PULONG Flags);
1835   typedef void (CALLBACK *PDEBUG_EXTENSION_UNINITIALIZE)(void);
1836 
1837 #define DEBUG_NOTIFY_SESSION_ACTIVE 0x00000000
1838 #define DEBUG_NOTIFY_SESSION_INACTIVE 0x00000001
1839 #define DEBUG_NOTIFY_SESSION_ACCESSIBLE 0x00000002
1840 #define DEBUG_NOTIFY_SESSION_INACCESSIBLE 0x00000003
1841 
1842   typedef void (CALLBACK *PDEBUG_EXTENSION_NOTIFY)(ULONG Notify,ULONG64 Argument);
1843   typedef HRESULT (CALLBACK *PDEBUG_EXTENSION_CALL)(PDEBUG_CLIENT Client,PCSTR Args);
1844 
1845 #define DEBUG_EXTENSION_CONTINUE_SEARCH HRESULT_FROM_NT(0xC0000271)
1846 #define DEBUG_EXTENSION_VERSION(Major,Minor) ((((Major) & 0xffff) << 16) | ((Minor) & 0xffff))
1847 
1848 #ifdef __cplusplus
1849 };
1850 
1851 #ifndef DEBUG_NO_IMPLEMENTATION
1852 class DebugBaseEventCallbacks : public IDebugEventCallbacks {
1853 public:
STDMETHOD(QueryInterface)1854   STDMETHOD(QueryInterface)(THIS_ REFIID InterfaceId,PVOID *Interface) {
1855     *Interface = NULL;
1856     if(IsEqualIID(InterfaceId,IID_IUnknown) || IsEqualIID(InterfaceId,IID_IDebugEventCallbacks)) {
1857       *Interface = (IDebugEventCallbacks *)this;
1858       AddRef();
1859       return S_OK;
1860     } else return E_NOINTERFACE;
1861   }
STDMETHOD(Breakpoint)1862   STDMETHOD(Breakpoint)(THIS_ PDEBUG_BREAKPOINT Bp) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(Exception)1863   STDMETHOD(Exception)(THIS_ PEXCEPTION_RECORD64 Exception,ULONG FirstChance) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(CreateThread)1864   STDMETHOD(CreateThread)(THIS_ ULONG64 Handle,ULONG64 DataOffset,ULONG64 StartOffset) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(ExitThread)1865   STDMETHOD(ExitThread)(THIS_ ULONG ExitCode) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(CreateProcess)1866   STDMETHOD(CreateProcess)(THIS_ ULONG64 ImageFileHandle,ULONG64 Handle,ULONG64 BaseOffset,ULONG ModuleSize,PCSTR ModuleName,PCSTR ImageName,ULONG CheckSum,ULONG TimeDateStamp,ULONG64 InitialThreadHandle,ULONG64 ThreadDataOffset,ULONG64 StartOffset) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(ExitProcess)1867   STDMETHOD(ExitProcess)(THIS_ ULONG ExitCode) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(LoadModule)1868   STDMETHOD(LoadModule)(THIS_ ULONG64 ImageFileHandle,ULONG64 BaseOffset,ULONG ModuleSize,PCSTR ModuleName,PCSTR ImageName,ULONG CheckSum,ULONG TimeDateStamp) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(UnloadModule)1869   STDMETHOD(UnloadModule)(THIS_ PCSTR ImageBaseName,ULONG64 BaseOffset) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(SystemError)1870   STDMETHOD(SystemError)(THIS_ ULONG Error,ULONG Level) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(SessionStatus)1871   STDMETHOD(SessionStatus)(THIS_ ULONG Status) { return DEBUG_STATUS_NO_CHANGE; }
STDMETHOD(ChangeDebuggeeState)1872   STDMETHOD(ChangeDebuggeeState)(THIS_ ULONG Flags,ULONG64 Argument) { return S_OK; }
STDMETHOD(ChangeEngineState)1873   STDMETHOD(ChangeEngineState)(THIS_ ULONG Flags,ULONG64 Argument) { return S_OK; }
STDMETHOD(ChangeSymbolState)1874   STDMETHOD(ChangeSymbolState)(THIS_ ULONG Flags,ULONG64 Argument) { return S_OK; }
1875 };
1876 #endif
1877 #endif
1878 #endif
1879