2020-09-30 16:53:55 +02:00

481 lines
13 KiB
C

//----------------------------------------------------------------------------
//
// Low-level debugging service interfaces.
//
// Copyright (C) Microsoft Corporation, 1999-2002.
//
//----------------------------------------------------------------------------
#ifndef __DBGSVC_H__
#define __DBGSVC_H__
#include <stdarg.h>
#include <objbase.h>
#ifdef __cplusplus
extern "C" {
#endif
//----------------------------------------------------------------------------
//
// GUIDs and interface forward declarations.
//
//----------------------------------------------------------------------------
/* a7ba24c4-e4fb-4625-a8fc-b1cb1fd51f53 */
DEFINE_GUID(IID_IUserDebugServices, 0xa7ba24c4, 0xe4fb, 0x4625,
0xa8, 0xfc, 0xb1, 0xcb, 0x1f, 0xd5, 0x1f, 0x53);
typedef interface DECLSPEC_UUID("a7ba24c4-e4fb-4625-a8fc-b1cb1fd51f53")
IUserDebugServices* PUSER_DEBUG_SERVICES;
//----------------------------------------------------------------------------
//
// IUserDebugServices.
//
//----------------------------------------------------------------------------
// The service implementation does not implement Insert/RemoveCodeBreakpoints
// directly, instead it is the caller's responsibility to handle them
// via break instruction insertion and removal.
#define DBGSVC_GENERIC_CODE_BREAKPOINTS 0x00000001
// Handles returned in create process and create thread events
// are not automatically closed. Instead it is the responsibility
// of the caller to close them when they are no longer needed.
#define DBGSVC_CLOSE_PROC_THREAD_HANDLES 0x00000002
// The service implementation does not implement Insert/RemoveDataBreakpoints
// directly, instead it is the caller's responsibility to handle them
// via process register manipulation.
#define DBGSVC_GENERIC_DATA_BREAKPOINTS 0x00000004
// GetProcessInfo flags.
#define DBGSVC_PROC_INFO_NO_SUSPEND 0x00000001
// Handle to ULONG64 and back.
#define SERVICE_HANDLE(OsHandle) ((ULONG64)(OsHandle))
#define OS_HANDLE(SvcHandle) ((HANDLE)(ULONG_PTR)(SvcHandle))
typedef struct _USER_THREAD_INFO
{
ULONG64 Handle;
ULONG Id;
ULONG Reserved;
} USER_THREAD_INFO, *PUSER_THREAD_INFO;
#undef INTERFACE
#define INTERFACE IUserDebugServices
DECLARE_INTERFACE_(IUserDebugServices, IUnknown)
{
// IUnknown.
STDMETHOD(QueryInterface)(
THIS_
IN REFIID InterfaceId,
OUT PVOID* Interface
) PURE;
STDMETHOD_(ULONG, AddRef)(
THIS
) PURE;
STDMETHOD_(ULONG, Release)(
THIS
) PURE;
// IUserDebugServices.
STDMETHOD(Initialize)(
THIS_
OUT PULONG Flags
) PURE;
STDMETHOD(Uninitialize)(
THIS_
IN BOOL Global
) PURE;
STDMETHOD(GetTargetInfo)(
THIS_
OUT PULONG MachineType,
OUT PULONG NumberProcessors,
OUT PULONG PlatformId,
OUT PULONG BuildNumber,
OUT PULONG CheckedBuild,
OUT PSTR CsdString,
IN ULONG CsdStringSize,
OUT PSTR BuildString,
IN ULONG BuildStringSize,
OUT PULONG ProductType,
OUT PULONG SuiteMask
) PURE;
STDMETHOD(GetConnectionInfo)(
THIS_
OUT OPTIONAL PSTR MachineName,
IN ULONG MachineNameSize,
OUT OPTIONAL PSTR ClientIdentity,
IN ULONG ClientIdentitySize,
OUT OPTIONAL PSTR TransportIdentity,
IN ULONG TransportIdentitySize
) PURE;
STDMETHOD(GetProcessorId)(
THIS_
OUT PVOID Buffer,
IN ULONG BufferSize,
OUT PULONG BufferUsed
) PURE;
STDMETHOD(GetGenericProcessorFeatures)(
THIS_
OUT OPTIONAL /* size_is(FeaturesSize) */ PULONG64 Features,
IN ULONG FeaturesSize,
OUT OPTIONAL PULONG Used
) PURE;
STDMETHOD(GetSpecificProcessorFeatures)(
THIS_
OUT OPTIONAL /* size_is(FeaturesSize) */ PULONG64 Features,
IN ULONG FeaturesSize,
OUT OPTIONAL PULONG Used
) PURE;
STDMETHOD(GetFileVersionInformationA)(
THIS_
IN PCWSTR File,
IN PCSTR Item,
OUT OPTIONAL PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG VerInfoSize
) PURE;
STDMETHOD(GetProcessIds)(
THIS_
OUT OPTIONAL /* size_is(Count) */ PULONG Ids,
IN ULONG Count,
OUT OPTIONAL PULONG ActualCount
) PURE;
STDMETHOD(GetProcessIdByExecutableNameW)(
THIS_
IN PCWSTR ExeName,
IN ULONG Flags,
OUT PULONG Id
) PURE;
STDMETHOD(GetProcessDescriptionW)(
THIS_
IN ULONG ProcessId,
IN ULONG Flags,
OUT OPTIONAL PWSTR ExeName,
IN ULONG ExeNameSize,
OUT OPTIONAL PULONG ActualExeNameSize,
OUT OPTIONAL PWSTR Description,
IN ULONG DescriptionSize,
OUT OPTIONAL PULONG ActualDescriptionSize
) PURE;
STDMETHOD(GetProcessInfo)(
THIS_
IN ULONG ProcessId,
IN ULONG Flags,
OUT OPTIONAL PULONG64 Handle,
OUT OPTIONAL /* size_is(InfoCount) */ PUSER_THREAD_INFO Threads,
IN ULONG InfoCount,
OUT OPTIONAL PULONG ThreadCount
) PURE;
STDMETHOD(AttachProcess)(
THIS_
IN ULONG ProcessId,
IN ULONG AttachFlags,
OUT PULONG64 ProcessHandle,
OUT PULONG ProcessOptions
) PURE;
STDMETHOD(DetachProcess)(
THIS_
IN ULONG ProcessId
) PURE;
STDMETHOD(CreateProcessW)(
THIS_
IN PWSTR CommandLine,
IN ULONG CreateFlags,
IN BOOL InheritHandles,
IN OPTIONAL PWSTR CurrentDir,
OUT PULONG ProcessId,
OUT PULONG ThreadId,
OUT PULONG64 ProcessHandle,
OUT PULONG64 ThreadHandle
) PURE;
STDMETHOD(TerminateProcess)(
THIS_
IN ULONG64 Process,
IN ULONG ExitCode
) PURE;
STDMETHOD(AbandonProcess)(
THIS_
IN ULONG64 Process
) PURE;
STDMETHOD(GetProcessExitCode)(
THIS_
IN ULONG64 Process,
OUT PULONG ExitCode
) PURE;
STDMETHOD(CloseHandle)(
THIS_
IN ULONG64 Handle
) PURE;
STDMETHOD(SetProcessOptions)(
THIS_
IN ULONG64 Process,
IN ULONG Options
) PURE;
STDMETHOD(SetDebugObjectOptions)(
THIS_
IN ULONG64 DebugObject,
IN ULONG Options
) PURE;
STDMETHOD(GetProcessDebugObject)(
THIS_
IN ULONG64 Process,
OUT PULONG64 DebugObject
) PURE;
STDMETHOD(DuplicateHandle)(
THIS_
IN ULONG64 InProcess,
IN ULONG64 InHandle,
IN ULONG64 OutProcess,
IN ULONG DesiredAccess,
IN ULONG Inherit,
IN ULONG Options,
OUT PULONG64 OutHandle
) PURE;
STDMETHOD(ReadVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
OUT PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG BytesRead
) PURE;
STDMETHOD(WriteVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG BytesWritten
) PURE;
STDMETHOD(QueryVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
OUT PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG BufferUsed
) PURE;
STDMETHOD(ProtectVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN ULONG64 Size,
IN ULONG NewProtect,
OUT PULONG OldProtect
) PURE;
STDMETHOD(AllocVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN ULONG64 Size,
IN ULONG Type,
IN ULONG Protect,
OUT PULONG64 AllocOffset
) PURE;
STDMETHOD(FreeVirtual)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN ULONG64 Size,
IN ULONG Type
) PURE;
STDMETHOD(ReadHandleData)(
THIS_
IN ULONG64 Process,
IN ULONG64 Handle,
IN ULONG DataType,
OUT OPTIONAL PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG DataSize
) PURE;
STDMETHOD(SuspendThreads)(
THIS_
IN ULONG Count,
IN /* size_is(Count) */ PULONG64 Threads,
OUT OPTIONAL /* size_is(Count) */ PULONG SuspendCounts
) PURE;
STDMETHOD(ResumeThreads)(
THIS_
IN ULONG Count,
IN /* size_is(Count) */ PULONG64 Threads,
OUT OPTIONAL /* size_is(Count) */ PULONG SuspendCounts
) PURE;
STDMETHOD(GetThreadStartAddress)(
THIS_
IN ULONG64 Thread,
OUT PULONG64 Offset
) PURE;
STDMETHOD(GetContext)(
THIS_
IN ULONG64 Thread,
IN ULONG Flags,
IN ULONG FlagsOffset,
OUT PVOID Context,
IN ULONG ContextSize,
OUT OPTIONAL PULONG ContextUsed
) PURE;
STDMETHOD(SetContext)(
THIS_
IN ULONG64 Thread,
IN PVOID Context,
IN ULONG ContextSize,
OUT OPTIONAL PULONG ContextUsed
) PURE;
STDMETHOD(GetProcessDataOffset)(
THIS_
IN ULONG64 Process,
OUT PULONG64 Offset
) PURE;
STDMETHOD(GetThreadDataOffset)(
THIS_
IN ULONG64 Thread,
OUT PULONG64 Offset
) PURE;
STDMETHOD(DescribeSelector)(
THIS_
IN ULONG64 Thread,
IN ULONG Selector,
OUT PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG BufferUsed
) PURE;
STDMETHOD(GetCurrentTimeDateN)(
THIS_
OUT PULONG64 TimeDate
) PURE;
STDMETHOD(GetCurrentSystemUpTimeN)(
THIS_
OUT PULONG64 UpTime
) PURE;
STDMETHOD(GetProcessUpTimeN)(
THIS_
IN ULONG64 Process,
OUT PULONG64 UpTime
) PURE;
STDMETHOD(GetProcessTimes)(
THIS_
IN ULONG64 Process,
OUT PULONG64 Create,
OUT PULONG64 Exit,
OUT PULONG64 Kernel,
OUT PULONG64 User
) PURE;
STDMETHOD(GetThreadTimes)(
THIS_
IN ULONG64 Thread,
OUT PULONG64 Create,
OUT PULONG64 Exit,
OUT PULONG64 Kernel,
OUT PULONG64 User
) PURE;
STDMETHOD(RequestBreakIn)(
THIS_
IN ULONG64 Process
) PURE;
STDMETHOD(WaitForEvent)(
THIS_
IN ULONG Timeout,
OUT PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG BufferUsed
) PURE;
STDMETHOD(ContinueEvent)(
THIS_
IN ULONG ContinueStatus
) PURE;
STDMETHOD(InsertCodeBreakpoint)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN ULONG MachineType,
OUT PVOID Storage,
IN ULONG StorageSize
) PURE;
STDMETHOD(RemoveCodeBreakpoint)(
THIS_
IN ULONG64 Process,
IN ULONG64 Offset,
IN ULONG MachineType,
IN PVOID Storage,
IN ULONG StorageSize
) PURE;
STDMETHOD(InsertDataBreakpoint)(
THIS_
IN ULONG64 Process,
IN ULONG64 Thread,
IN ULONG64 Offset,
IN ULONG AccessLength,
IN ULONG AccessType,
IN ULONG MachineType
) PURE;
STDMETHOD(RemoveDataBreakpoint)(
THIS_
IN ULONG64 Process,
IN ULONG64 Thread,
IN ULONG64 Offset,
IN ULONG AccessLength,
IN ULONG AccessType,
IN ULONG MachineType
) PURE;
STDMETHOD(GetLastDataBreakpointHit)(
THIS_
IN ULONG64 Process,
IN ULONG64 Thread,
OUT PULONG64 Address,
OUT PULONG AccessType
) PURE;
STDMETHOD(GetFunctionTableListHead)(
THIS_
IN ULONG64 Process,
OUT PULONG64 Offset
) PURE;
STDMETHOD(GetOutOfProcessFunctionTableW)(
THIS_
IN ULONG64 Process,
IN PWSTR Dll,
IN ULONG64 LoadedDllHandle,
IN ULONG64 Table,
IN OPTIONAL PVOID Buffer,
IN ULONG BufferSize,
OUT OPTIONAL PULONG TableSize,
OUT OPTIONAL PULONG64 UsedDllHandle
) PURE;
STDMETHOD(GetUnloadedModuleListHead)(
THIS_
IN ULONG64 Process,
OUT PULONG64 Offset
) PURE;
STDMETHOD(LoadLibrary)(
THIS_
IN PWSTR Path,
OUT PULONG64 Handle
) PURE;
STDMETHOD(FreeLibrary)(
THIS_
IN ULONG64 Handle
) PURE;
};
#ifdef __cplusplus
};
#endif
#endif // #ifndef __DBGSVC_H__