123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975 |
- /**
- * This file is part of the mingw-w64 runtime package.
- * No warranty is given; refer to the file DISCLAIMER within this package.
- */
- #include <winapifamily.h>
- #ifndef _EVNTRACE_
- #define _EVNTRACE_
- #if defined (_WINNT_) || defined (WINNT)
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- #if !defined (WMIAPI) && !defined (__WIDL__) && !defined (MIDL_PASS)
- #ifdef _WMI_SOURCE_
- #ifdef _ARM_
- #define WMIAPI
- #else
- #define WMIAPI __stdcall
- #endif
- #else
- #ifdef _ARM_
- #define WMIAPI DECLSPEC_IMPORT
- #else
- #define WMIAPI DECLSPEC_IMPORT __stdcall
- #endif
- #endif
- #endif
- #include <guiddef.h>
- #if defined (_NTDDK_) || defined (_NTIFS_) || defined (_WMIKM_)
- #define _EVNTRACE_KERNEL_MODE
- #endif
- #ifndef _EVNTRACE_KERNEL_MODE
- #include <wmistr.h>
- #endif
- DEFINE_GUID (EventTraceGuid, 0x68fdd900, 0x4a3e, 0x11d1, 0x84, 0xf4, 0x00, 0x00, 0xf8, 0x04, 0x64, 0xe3);
- DEFINE_GUID (SystemTraceControlGuid, 0x9e814aad, 0x3204, 0x11d2, 0x9a, 0x82, 0x00, 0x60, 0x08, 0xa8, 0x69, 0x39);
- DEFINE_GUID (EventTraceConfigGuid, 0x01853a65, 0x418f, 0x4f36, 0xae, 0xfc, 0xdc, 0x0f, 0x1d, 0x2f, 0xd2, 0x35);
- DEFINE_GUID (DefaultTraceSecurityGuid, 0x0811c1af, 0x7a07, 0x4a06, 0x82, 0xed, 0x86, 0x94, 0x55, 0xcd, 0xf7, 0x13);
- #define KERNEL_LOGGER_NAMEW L"NT Kernel Logger"
- #define GLOBAL_LOGGER_NAMEW L"GlobalLogger"
- #define EVENT_LOGGER_NAMEW L"EventLog"
- #define DIAG_LOGGER_NAMEW L"DiagLog"
- #define KERNEL_LOGGER_NAMEA "NT Kernel Logger"
- #define GLOBAL_LOGGER_NAMEA "GlobalLogger"
- #define EVENT_LOGGER_NAMEA "EventLog"
- #define DIAG_LOGGER_NAMEA "DiagLog"
- #define MAX_MOF_FIELDS 16
- #ifndef _TRACEHANDLE_DEFINED
- #define _TRACEHANDLE_DEFINED
- typedef ULONG64 TRACEHANDLE,*PTRACEHANDLE;
- #endif
- #define SYSTEM_EVENT_TYPE 1
- #define EVENT_TRACE_TYPE_INFO 0x00
- #define EVENT_TRACE_TYPE_START 0x01
- #define EVENT_TRACE_TYPE_END 0x02
- #define EVENT_TRACE_TYPE_STOP 0x02
- #define EVENT_TRACE_TYPE_DC_START 0x03
- #define EVENT_TRACE_TYPE_DC_END 0x04
- #define EVENT_TRACE_TYPE_EXTENSION 0x05
- #define EVENT_TRACE_TYPE_REPLY 0x06
- #define EVENT_TRACE_TYPE_DEQUEUE 0x07
- #define EVENT_TRACE_TYPE_RESUME 0x07
- #define EVENT_TRACE_TYPE_CHECKPOINT 0x08
- #define EVENT_TRACE_TYPE_SUSPEND 0x08
- #define EVENT_TRACE_TYPE_WINEVT_SEND 0x09
- #define EVENT_TRACE_TYPE_WINEVT_RECEIVE 0xf0
- #define TRACE_LEVEL_NONE 0
- #define TRACE_LEVEL_CRITICAL 1
- #define TRACE_LEVEL_FATAL 1
- #define TRACE_LEVEL_ERROR 2
- #define TRACE_LEVEL_WARNING 3
- #define TRACE_LEVEL_INFORMATION 4
- #define TRACE_LEVEL_VERBOSE 5
- #define TRACE_LEVEL_RESERVED6 6
- #define TRACE_LEVEL_RESERVED7 7
- #define TRACE_LEVEL_RESERVED8 8
- #define TRACE_LEVEL_RESERVED9 9
- #define EVENT_TRACE_TYPE_LOAD 0x0a
- #define EVENT_TRACE_TYPE_TERMINATE 0x0b
- #define EVENT_TRACE_TYPE_IO_READ 0x0a
- #define EVENT_TRACE_TYPE_IO_WRITE 0x0b
- #define EVENT_TRACE_TYPE_IO_READ_INIT 0x0c
- #define EVENT_TRACE_TYPE_IO_WRITE_INIT 0x0d
- #define EVENT_TRACE_TYPE_IO_FLUSH 0x0e
- #define EVENT_TRACE_TYPE_IO_FLUSH_INIT 0x0f
- #define EVENT_TRACE_TYPE_MM_TF 0x0a
- #define EVENT_TRACE_TYPE_MM_DZF 0x0b
- #define EVENT_TRACE_TYPE_MM_COW 0x0c
- #define EVENT_TRACE_TYPE_MM_GPF 0x0d
- #define EVENT_TRACE_TYPE_MM_HPF 0x0e
- #define EVENT_TRACE_TYPE_MM_AV 0x0f
- #define EVENT_TRACE_TYPE_SEND 0x0a
- #define EVENT_TRACE_TYPE_RECEIVE 0x0b
- #define EVENT_TRACE_TYPE_CONNECT 0x0c
- #define EVENT_TRACE_TYPE_DISCONNECT 0x0d
- #define EVENT_TRACE_TYPE_RETRANSMIT 0x0e
- #define EVENT_TRACE_TYPE_ACCEPT 0x0f
- #define EVENT_TRACE_TYPE_RECONNECT 0x10
- #define EVENT_TRACE_TYPE_CONNFAIL 0x11
- #define EVENT_TRACE_TYPE_COPY_TCP 0x12
- #define EVENT_TRACE_TYPE_COPY_ARP 0x13
- #define EVENT_TRACE_TYPE_ACKFULL 0x14
- #define EVENT_TRACE_TYPE_ACKPART 0x15
- #define EVENT_TRACE_TYPE_ACKDUP 0x16
- #define EVENT_TRACE_TYPE_GUIDMAP 0x0a
- #define EVENT_TRACE_TYPE_CONFIG 0x0b
- #define EVENT_TRACE_TYPE_SIDINFO 0x0c
- #define EVENT_TRACE_TYPE_SECURITY 0x0d
- #define EVENT_TRACE_TYPE_DBGID_RSDS 0x40
- #define EVENT_TRACE_TYPE_REGCREATE 0x0a
- #define EVENT_TRACE_TYPE_REGOPEN 0x0b
- #define EVENT_TRACE_TYPE_REGDELETE 0x0c
- #define EVENT_TRACE_TYPE_REGQUERY 0x0d
- #define EVENT_TRACE_TYPE_REGSETVALUE 0x0e
- #define EVENT_TRACE_TYPE_REGDELETEVALUE 0x0f
- #define EVENT_TRACE_TYPE_REGQUERYVALUE 0x10
- #define EVENT_TRACE_TYPE_REGENUMERATEKEY 0x11
- #define EVENT_TRACE_TYPE_REGENUMERATEVALUEKEY 0x12
- #define EVENT_TRACE_TYPE_REGQUERYMULTIPLEVALUE 0x13
- #define EVENT_TRACE_TYPE_REGSETINFORMATION 0x14
- #define EVENT_TRACE_TYPE_REGFLUSH 0x15
- #define EVENT_TRACE_TYPE_REGKCBCREATE 0x16
- #define EVENT_TRACE_TYPE_REGKCBDELETE 0x17
- #define EVENT_TRACE_TYPE_REGKCBRUNDOWNBEGIN 0x18
- #define EVENT_TRACE_TYPE_REGKCBRUNDOWNEND 0x19
- #define EVENT_TRACE_TYPE_REGVIRTUALIZE 0x1a
- #define EVENT_TRACE_TYPE_REGCLOSE 0x1b
- #define EVENT_TRACE_TYPE_REGSETSECURITY 0x1c
- #define EVENT_TRACE_TYPE_REGQUERYSECURITY 0x1d
- #define EVENT_TRACE_TYPE_REGCOMMIT 0x1e
- #define EVENT_TRACE_TYPE_REGPREPARE 0x1f
- #define EVENT_TRACE_TYPE_REGROLLBACK 0x20
- #define EVENT_TRACE_TYPE_REGMOUNTHIVE 0x21
- #define EVENT_TRACE_TYPE_CONFIG_CPU 0x0a
- #define EVENT_TRACE_TYPE_CONFIG_PHYSICALDISK 0x0b
- #define EVENT_TRACE_TYPE_CONFIG_LOGICALDISK 0x0c
- #define EVENT_TRACE_TYPE_CONFIG_NIC 0x0d
- #define EVENT_TRACE_TYPE_CONFIG_VIDEO 0x0e
- #define EVENT_TRACE_TYPE_CONFIG_SERVICES 0x0f
- #define EVENT_TRACE_TYPE_CONFIG_POWER 0x10
- #define EVENT_TRACE_TYPE_CONFIG_NETINFO 0x11
- #define EVENT_TRACE_TYPE_CONFIG_OPTICALMEDIA 0x12
- #define EVENT_TRACE_TYPE_CONFIG_IRQ 0x15
- #define EVENT_TRACE_TYPE_CONFIG_PNP 0x16
- #define EVENT_TRACE_TYPE_CONFIG_IDECHANNEL 0x17
- #define EVENT_TRACE_TYPE_CONFIG_NUMANODE 0x18
- #define EVENT_TRACE_TYPE_CONFIG_PLATFORM 0x19
- #define EVENT_TRACE_TYPE_CONFIG_PROCESSORGROUP 0x1a
- #define EVENT_TRACE_TYPE_CONFIG_PROCESSORNUMBER 0x1b
- #define EVENT_TRACE_TYPE_CONFIG_DPI 0x1c
- #define EVENT_TRACE_TYPE_CONFIG_CI_INFO 0x1d
- #define EVENT_TRACE_TYPE_CONFIG_MACHINEID 0x1e
- #define EVENT_TRACE_TYPE_CONFIG_DEFRAG 0x1f
- #define EVENT_TRACE_TYPE_CONFIG_MOBILEPLATFORM 0x20
- #define EVENT_TRACE_TYPE_CONFIG_DEVICEFAMILY 0x21
- #define EVENT_TRACE_TYPE_CONFIG_FLIGHTID 0x22
- #define EVENT_TRACE_TYPE_CONFIG_PROCESSOR 0x23
- #define EVENT_TRACE_TYPE_OPTICAL_IO_READ 0x37
- #define EVENT_TRACE_TYPE_OPTICAL_IO_WRITE 0x38
- #define EVENT_TRACE_TYPE_OPTICAL_IO_FLUSH 0x39
- #define EVENT_TRACE_TYPE_OPTICAL_IO_READ_INIT 0x3a
- #define EVENT_TRACE_TYPE_OPTICAL_IO_WRITE_INIT 0x3b
- #define EVENT_TRACE_TYPE_OPTICAL_IO_FLUSH_INIT 0x3c
- #define EVENT_TRACE_TYPE_FLT_PREOP_INIT 0x60
- #define EVENT_TRACE_TYPE_FLT_POSTOP_INIT 0x61
- #define EVENT_TRACE_TYPE_FLT_PREOP_COMPLETION 0x62
- #define EVENT_TRACE_TYPE_FLT_POSTOP_COMPLETION 0x63
- #define EVENT_TRACE_TYPE_FLT_PREOP_FAILURE 0x64
- #define EVENT_TRACE_TYPE_FLT_POSTOP_FAILURE 0x65
- #define EVENT_TRACE_FLAG_PROCESS 0x00000001
- #define EVENT_TRACE_FLAG_THREAD 0x00000002
- #define EVENT_TRACE_FLAG_IMAGE_LOAD 0x00000004
- #define EVENT_TRACE_FLAG_DISK_IO 0x00000100
- #define EVENT_TRACE_FLAG_DISK_FILE_IO 0x00000200
- #define EVENT_TRACE_FLAG_MEMORY_PAGE_FAULTS 0x00001000
- #define EVENT_TRACE_FLAG_MEMORY_HARD_FAULTS 0x00002000
- #define EVENT_TRACE_FLAG_NETWORK_TCPIP 0x00010000
- #define EVENT_TRACE_FLAG_REGISTRY 0x00020000
- #define EVENT_TRACE_FLAG_DBGPRINT 0x00040000
- #define EVENT_TRACE_FLAG_PROCESS_COUNTERS 0x00000008
- #define EVENT_TRACE_FLAG_CSWITCH 0x00000010
- #define EVENT_TRACE_FLAG_DPC 0x00000020
- #define EVENT_TRACE_FLAG_INTERRUPT 0x00000040
- #define EVENT_TRACE_FLAG_SYSTEMCALL 0x00000080
- #define EVENT_TRACE_FLAG_DISK_IO_INIT 0x00000400
- #define EVENT_TRACE_FLAG_ALPC 0x00100000
- #define EVENT_TRACE_FLAG_SPLIT_IO 0x00200000
- #define EVENT_TRACE_FLAG_DRIVER 0x00800000
- #define EVENT_TRACE_FLAG_PROFILE 0x01000000
- #define EVENT_TRACE_FLAG_FILE_IO 0x02000000
- #define EVENT_TRACE_FLAG_FILE_IO_INIT 0x04000000
- #define EVENT_TRACE_FLAG_DISPATCHER 0x00000800
- #define EVENT_TRACE_FLAG_VIRTUAL_ALLOC 0x00004000
- #define EVENT_TRACE_FLAG_VAMAP 0x00008000
- #define EVENT_TRACE_FLAG_NO_SYSCONFIG 0x10000000
- #define EVENT_TRACE_FLAG_JOB 0x00080000
- #define EVENT_TRACE_FLAG_DEBUG_EVENTS 0x00400000
- #define EVENT_TRACE_FLAG_EXTENSION 0x80000000
- #define EVENT_TRACE_FLAG_FORWARD_WMI 0x40000000
- #define EVENT_TRACE_FLAG_ENABLE_RESERVE 0x20000000
- #define EVENT_TRACE_FILE_MODE_NONE 0x00000000
- #define EVENT_TRACE_FILE_MODE_SEQUENTIAL 0x00000001
- #define EVENT_TRACE_FILE_MODE_CIRCULAR 0x00000002
- #define EVENT_TRACE_FILE_MODE_APPEND 0x00000004
- #define EVENT_TRACE_REAL_TIME_MODE 0x00000100
- #define EVENT_TRACE_DELAY_OPEN_FILE_MODE 0x00000200
- #define EVENT_TRACE_BUFFERING_MODE 0x00000400
- #define EVENT_TRACE_PRIVATE_LOGGER_MODE 0x00000800
- #define EVENT_TRACE_ADD_HEADER_MODE 0x00001000
- #define EVENT_TRACE_USE_GLOBAL_SEQUENCE 0x00004000
- #define EVENT_TRACE_USE_LOCAL_SEQUENCE 0x00008000
- #define EVENT_TRACE_RELOG_MODE 0x00010000
- #define EVENT_TRACE_USE_PAGED_MEMORY 0x01000000
- #define EVENT_TRACE_FILE_MODE_NEWFILE 0x00000008
- #define EVENT_TRACE_FILE_MODE_PREALLOCATE 0x00000020
- #define EVENT_TRACE_NONSTOPPABLE_MODE 0x00000040
- #define EVENT_TRACE_SECURE_MODE 0x00000080
- #define EVENT_TRACE_USE_KBYTES_FOR_SIZE 0x00002000
- #define EVENT_TRACE_PRIVATE_IN_PROC 0x00020000
- #define EVENT_TRACE_MODE_RESERVED 0x00100000
- #define EVENT_TRACE_NO_PER_PROCESSOR_BUFFERING 0x10000000
- #define EVENT_TRACE_SYSTEM_LOGGER_MODE 0x02000000
- #define EVENT_TRACE_ADDTO_TRIAGE_DUMP 0x80000000
- #define EVENT_TRACE_STOP_ON_HYBRID_SHUTDOWN 0x00400000
- #define EVENT_TRACE_PERSIST_ON_HYBRID_SHUTDOWN 0x00800000
- #define EVENT_TRACE_INDEPENDENT_SESSION_MODE 0x08000000
- #define EVENT_TRACE_COMPRESSED_MODE 0x04000000
- #define EVENT_TRACE_CONTROL_QUERY 0
- #define EVENT_TRACE_CONTROL_STOP 1
- #define EVENT_TRACE_CONTROL_UPDATE 2
- #define EVENT_TRACE_CONTROL_FLUSH 3
- #define EVENT_TRACE_CONTROL_INCREMENT_FILE 4
- #define TRACE_MESSAGE_SEQUENCE 1
- #define TRACE_MESSAGE_GUID 2
- #define TRACE_MESSAGE_COMPONENTID 4
- #define TRACE_MESSAGE_TIMESTAMP 8
- #define TRACE_MESSAGE_PERFORMANCE_TIMESTAMP 16
- #define TRACE_MESSAGE_SYSTEMINFO 32
- #define TRACE_MESSAGE_POINTER32 0x0040
- #define TRACE_MESSAGE_POINTER64 0x0080
- #define TRACE_MESSAGE_FLAG_MASK 0xffff
- #define TRACE_MESSAGE_MAXIMUM_SIZE (64 * 1024)
- #define EVENT_TRACE_USE_PROCTIME 0x0001
- #define EVENT_TRACE_USE_NOCPUTIME 0x0002
- #define TRACE_HEADER_FLAG_USE_TIMESTAMP 0x00000200
- #define TRACE_HEADER_FLAG_TRACED_GUID 0x00020000
- #define TRACE_HEADER_FLAG_LOG_WNODE 0x00040000
- #define TRACE_HEADER_FLAG_USE_GUID_PTR 0x00080000
- #define TRACE_HEADER_FLAG_USE_MOF_PTR 0x00100000
- typedef enum {
- EtwCompressionModeRestart = 0,
- EtwCompressionModeNoDisable = 1,
- EtwCompressionModeNoRestart = 2
- } ETW_COMPRESSION_RESUMPTION_MODE;
- typedef struct _EVENT_TRACE_HEADER {
- USHORT Size;
- __C89_NAMELESS union {
- USHORT FieldTypeFlags;
- __C89_NAMELESS struct {
- UCHAR HeaderType;
- UCHAR MarkerFlags;
- } DUMMYSTRUCTNAME;
- } DUMMYUNIONNAME;
- __C89_NAMELESS union {
- ULONG Version;
- struct {
- UCHAR Type;
- UCHAR Level;
- USHORT Version;
- } Class;
- } DUMMYUNIONNAME2;
- ULONG ThreadId;
- ULONG ProcessId;
- LARGE_INTEGER TimeStamp;
- __C89_NAMELESS union {
- GUID Guid;
- ULONGLONG GuidPtr;
- } DUMMYUNIONNAME3;
- __C89_NAMELESS union {
- __C89_NAMELESS struct {
- ULONG KernelTime;
- ULONG UserTime;
- } DUMMYSTRUCTNAME;
- ULONG64 ProcessorTime;
- __C89_NAMELESS struct {
- ULONG ClientContext;
- ULONG Flags;
- } DUMMYSTRUCTNAME2;
- } DUMMYUNIONNAME4;
- } EVENT_TRACE_HEADER,*PEVENT_TRACE_HEADER;
- typedef struct _EVENT_INSTANCE_HEADER {
- USHORT Size;
- __C89_NAMELESS union {
- USHORT FieldTypeFlags;
- __C89_NAMELESS struct {
- UCHAR HeaderType;
- UCHAR MarkerFlags;
- } DUMMYSTRUCTNAME;
- } DUMMYUNIONNAME;
- __C89_NAMELESS union {
- ULONG Version;
- struct {
- UCHAR Type;
- UCHAR Level;
- USHORT Version;
- } Class;
- } DUMMYUNIONNAME2;
- ULONG ThreadId;
- ULONG ProcessId;
- LARGE_INTEGER TimeStamp;
- ULONGLONG RegHandle;
- ULONG InstanceId;
- ULONG ParentInstanceId;
- __C89_NAMELESS union {
- __C89_NAMELESS struct {
- ULONG KernelTime;
- ULONG UserTime;
- } DUMMYSTRUCTNAME;
- ULONG64 ProcessorTime;
- __C89_NAMELESS struct {
- ULONG EventId;
- ULONG Flags;
- } DUMMYSTRUCTNAME2;
- } DUMMYUNIONNAME3;
- ULONGLONG ParentRegHandle;
- } EVENT_INSTANCE_HEADER,*PEVENT_INSTANCE_HEADER;
- #define ETW_NULL_TYPE_VALUE 0
- #define ETW_OBJECT_TYPE_VALUE 1
- #define ETW_STRING_TYPE_VALUE 2
- #define ETW_SBYTE_TYPE_VALUE 3
- #define ETW_BYTE_TYPE_VALUE 4
- #define ETW_INT16_TYPE_VALUE 5
- #define ETW_UINT16_TYPE_VALUE 6
- #define ETW_INT32_TYPE_VALUE 7
- #define ETW_UINT32_TYPE_VALUE 8
- #define ETW_INT64_TYPE_VALUE 9
- #define ETW_UINT64_TYPE_VALUE 10
- #define ETW_CHAR_TYPE_VALUE 11
- #define ETW_SINGLE_TYPE_VALUE 12
- #define ETW_DOUBLE_TYPE_VALUE 13
- #define ETW_BOOLEAN_TYPE_VALUE 14
- #define ETW_DECIMAL_TYPE_VALUE 15
- #define ETW_GUID_TYPE_VALUE 101
- #define ETW_ASCIICHAR_TYPE_VALUE 102
- #define ETW_ASCIISTRING_TYPE_VALUE 103
- #define ETW_COUNTED_STRING_TYPE_VALUE 104
- #define ETW_POINTER_TYPE_VALUE 105
- #define ETW_SIZET_TYPE_VALUE 106
- #define ETW_HIDDEN_TYPE_VALUE 107
- #define ETW_BOOL_TYPE_VALUE 108
- #define ETW_COUNTED_ANSISTRING_TYPE_VALUE 109
- #define ETW_REVERSED_COUNTED_STRING_TYPE_VALUE 110
- #define ETW_REVERSED_COUNTED_ANSISTRING_TYPE_VALUE 111
- #define ETW_NON_NULL_TERMINATED_STRING_TYPE_VALUE 112
- #define ETW_REDUCED_ANSISTRING_TYPE_VALUE 113
- #define ETW_REDUCED_STRING_TYPE_VALUE 114
- #define ETW_SID_TYPE_VALUE 115
- #define ETW_VARIANT_TYPE_VALUE 116
- #define ETW_PTVECTOR_TYPE_VALUE 117
- #define ETW_WMITIME_TYPE_VALUE 118
- #define ETW_DATETIME_TYPE_VALUE 119
- #define ETW_REFRENCE_TYPE_VALUE 120
- #define DEFINE_TRACE_MOF_FIELD(M, P, LEN, TYP) (M)->DataPtr = (ULONG64) (ULONG_PTR) P; (M)->Length = (ULONG) LEN; (M)->DataType = (ULONG) TYP;
- typedef struct _MOF_FIELD {
- ULONG64 DataPtr;
- ULONG Length;
- ULONG DataType;
- } MOF_FIELD,*PMOF_FIELD;
- #if !defined (_EVNTRACE_KERNEL_MODE) || defined (_WMIKM_)
- typedef struct _TRACE_LOGFILE_HEADER {
- ULONG BufferSize;
- __C89_NAMELESS union {
- ULONG Version;
- struct {
- UCHAR MajorVersion;
- UCHAR MinorVersion;
- UCHAR SubVersion;
- UCHAR SubMinorVersion;
- } VersionDetail;
- } DUMMYUNIONNAME;
- ULONG ProviderVersion;
- ULONG NumberOfProcessors;
- LARGE_INTEGER EndTime;
- ULONG TimerResolution;
- ULONG MaximumFileSize;
- ULONG LogFileMode;
- ULONG BuffersWritten;
- __C89_NAMELESS union {
- GUID LogInstanceGuid;
- __C89_NAMELESS struct {
- ULONG StartBuffers;
- ULONG PointerSize;
- ULONG EventsLost;
- ULONG CpuSpeedInMHz;
- } DUMMYSTRUCTNAME;
- } DUMMYUNIONNAME2;
- #if defined (_WMIKM_)
- PWCHAR LoggerName;
- PWCHAR LogFileName;
- RTL_TIME_ZONE_INFORMATION TimeZone;
- #else
- LPWSTR LoggerName;
- LPWSTR LogFileName;
- TIME_ZONE_INFORMATION TimeZone;
- #endif
- LARGE_INTEGER BootTime;
- LARGE_INTEGER PerfFreq;
- LARGE_INTEGER StartTime;
- ULONG ReservedFlags;
- ULONG BuffersLost;
- } TRACE_LOGFILE_HEADER,*PTRACE_LOGFILE_HEADER;
- typedef struct _TRACE_LOGFILE_HEADER32 {
- ULONG BufferSize;
- __C89_NAMELESS union {
- ULONG Version;
- struct {
- UCHAR MajorVersion;
- UCHAR MinorVersion;
- UCHAR SubVersion;
- UCHAR SubMinorVersion;
- } VersionDetail;
- };
- ULONG ProviderVersion;
- ULONG NumberOfProcessors;
- LARGE_INTEGER EndTime;
- ULONG TimerResolution;
- ULONG MaximumFileSize;
- ULONG LogFileMode;
- ULONG BuffersWritten;
- __C89_NAMELESS union {
- GUID LogInstanceGuid;
- __C89_NAMELESS struct {
- ULONG StartBuffers;
- ULONG PointerSize;
- ULONG EventsLost;
- ULONG CpuSpeedInMHz;
- };
- };
- ULONG32 LoggerName;
- ULONG32 LogFileName;
- #if defined (_WMIKM_)
- RTL_TIME_ZONE_INFORMATION TimeZone;
- #else
- TIME_ZONE_INFORMATION TimeZone;
- #endif
- LARGE_INTEGER BootTime;
- LARGE_INTEGER PerfFreq;
- LARGE_INTEGER StartTime;
- ULONG ReservedFlags;
- ULONG BuffersLost;
- } TRACE_LOGFILE_HEADER32,*PTRACE_LOGFILE_HEADER32;
- typedef struct _TRACE_LOGFILE_HEADER64 {
- ULONG BufferSize;
- __C89_NAMELESS union {
- ULONG Version;
- __C89_NAMELESS struct {
- UCHAR MajorVersion;
- UCHAR MinorVersion;
- UCHAR SubVersion;
- UCHAR SubMinorVersion;
- } VersionDetail;
- };
- ULONG ProviderVersion;
- ULONG NumberOfProcessors;
- LARGE_INTEGER EndTime;
- ULONG TimerResolution;
- ULONG MaximumFileSize;
- ULONG LogFileMode;
- ULONG BuffersWritten;
- __C89_NAMELESS union {
- GUID LogInstanceGuid;
- __C89_NAMELESS struct {
- ULONG StartBuffers;
- ULONG PointerSize;
- ULONG EventsLost;
- ULONG CpuSpeedInMHz;
- };
- };
- ULONG64 LoggerName;
- ULONG64 LogFileName;
- #if defined (_WMIKM_)
- RTL_TIME_ZONE_INFORMATION TimeZone;
- #else
- TIME_ZONE_INFORMATION TimeZone;
- #endif
- LARGE_INTEGER BootTime;
- LARGE_INTEGER PerfFreq;
- LARGE_INTEGER StartTime;
- ULONG ReservedFlags;
- ULONG BuffersLost;
- } TRACE_LOGFILE_HEADER64,*PTRACE_LOGFILE_HEADER64;
- #endif
- typedef struct EVENT_INSTANCE_INFO {
- HANDLE RegHandle;
- ULONG InstanceId;
- } EVENT_INSTANCE_INFO,*PEVENT_INSTANCE_INFO;
- #ifndef _EVNTRACE_KERNEL_MODE
- typedef struct _EVENT_FILTER_DESCRIPTOR EVENT_FILTER_DESCRIPTOR, *PEVENT_FILTER_DESCRIPTOR;
- typedef struct _EVENT_TRACE_PROPERTIES {
- WNODE_HEADER Wnode;
- ULONG BufferSize;
- ULONG MinimumBuffers;
- ULONG MaximumBuffers;
- ULONG MaximumFileSize;
- ULONG LogFileMode;
- ULONG FlushTimer;
- ULONG EnableFlags;
- LONG AgeLimit;
- ULONG NumberOfBuffers;
- ULONG FreeBuffers;
- ULONG EventsLost;
- ULONG BuffersWritten;
- ULONG LogBuffersLost;
- ULONG RealTimeBuffersLost;
- HANDLE LoggerThreadId;
- ULONG LogFileNameOffset;
- ULONG LoggerNameOffset;
- } EVENT_TRACE_PROPERTIES,*PEVENT_TRACE_PROPERTIES;
- typedef struct _EVENT_TRACE_PROPERTIES_V2 {
- WNODE_HEADER Wnode;
- ULONG BufferSize;
- ULONG MinimumBuffers;
- ULONG MaximumBuffers;
- ULONG MaximumFileSize;
- ULONG LogFileMode;
- ULONG FlushTimer;
- ULONG EnableFlags;
- __C89_NAMELESS union {
- LONG AgeLimit;
- LONG FlushThreshold;
- };
- ULONG NumberOfBuffers;
- ULONG FreeBuffers;
- ULONG EventsLost;
- ULONG BuffersWritten;
- ULONG LogBuffersLost;
- ULONG RealTimeBuffersLost;
- HANDLE LoggerThreadId;
- ULONG LogFileNameOffset;
- ULONG LoggerNameOffset;
- __C89_NAMELESS union {
- __C89_NAMELESS struct {
- ULONG VersionNumber : 8;
- };
- ULONG V2Control;
- };
- ULONG FilterDescCount;
- PEVENT_FILTER_DESCRIPTOR FilterDesc;
- __C89_NAMELESS union {
- __C89_NAMELESS struct {
- ULONG Wow : 1;
- ULONG QpcDeltaTracking : 1;
- };
- ULONG64 V2Options;
- };
- } EVENT_TRACE_PROPERTIES_V2, *PEVENT_TRACE_PROPERTIES_V2;
- typedef struct _TRACE_GUID_REGISTRATION {
- LPCGUID Guid;
- HANDLE RegHandle;
- } TRACE_GUID_REGISTRATION,*PTRACE_GUID_REGISTRATION;
- #endif
- typedef struct _TRACE_GUID_PROPERTIES {
- GUID Guid;
- ULONG GuidType;
- ULONG LoggerId;
- ULONG EnableLevel;
- ULONG EnableFlags;
- BOOLEAN IsEnable;
- } TRACE_GUID_PROPERTIES,*PTRACE_GUID_PROPERTIES;
- #ifndef ETW_BUFFER_CONTEXT_DEF
- #define ETW_BUFFER_CONTEXT_DEF
- typedef struct _ETW_BUFFER_CONTEXT {
- __C89_NAMELESS union {
- __C89_NAMELESS struct {
- UCHAR ProcessorNumber;
- UCHAR Alignment;
- } DUMMYSTRUCTNAME;
- USHORT ProcessorIndex;
- } DUMMYUNIONNAME;
- USHORT LoggerId;
- } ETW_BUFFER_CONTEXT,*PETW_BUFFER_CONTEXT;
- #endif
- #define TRACE_PROVIDER_FLAG_LEGACY (0x00000001)
- #define TRACE_PROVIDER_FLAG_PRE_ENABLE (0x00000002)
- typedef struct _TRACE_ENABLE_INFO {
- ULONG IsEnabled;
- UCHAR Level;
- UCHAR Reserved1;
- USHORT LoggerId;
- ULONG EnableProperty;
- ULONG Reserved2;
- ULONGLONG MatchAnyKeyword;
- ULONGLONG MatchAllKeyword;
- } TRACE_ENABLE_INFO,*PTRACE_ENABLE_INFO;
- typedef struct _TRACE_PROVIDER_INSTANCE_INFO {
- ULONG NextOffset;
- ULONG EnableCount;
- ULONG Pid;
- ULONG Flags;
- } TRACE_PROVIDER_INSTANCE_INFO,*PTRACE_PROVIDER_INSTANCE_INFO;
- typedef struct _TRACE_GUID_INFO {
- ULONG InstanceCount;
- ULONG Reserved;
- } TRACE_GUID_INFO,*PTRACE_GUID_INFO;
- typedef struct _PROFILE_SOURCE_INFO {
- ULONG NextEntryOffset;
- ULONG Source;
- ULONG MinInterval;
- ULONG MaxInterval;
- ULONG64 Reserved;
- WCHAR Description[ANYSIZE_ARRAY];
- } PROFILE_SOURCE_INFO,*PPROFILE_SOURCE_INFO;
- typedef struct _EVENT_TRACE {
- EVENT_TRACE_HEADER Header;
- ULONG InstanceId;
- ULONG ParentInstanceId;
- GUID ParentGuid;
- PVOID MofData;
- ULONG MofLength;
- __C89_NAMELESS union {
- ULONG ClientContext;
- ETW_BUFFER_CONTEXT BufferContext;
- } DUMMYUNIONNAME;
- } EVENT_TRACE,*PEVENT_TRACE;
- #define EVENT_CONTROL_CODE_DISABLE_PROVIDER 0
- #define EVENT_CONTROL_CODE_ENABLE_PROVIDER 1
- #define EVENT_CONTROL_CODE_CAPTURE_STATE 2
- #endif
- #ifndef _EVNTRACE_KERNEL_MODE
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- typedef struct _EVENT_RECORD EVENT_RECORD,*PEVENT_RECORD;
- typedef struct _EVENT_TRACE_LOGFILEW EVENT_TRACE_LOGFILEW,*PEVENT_TRACE_LOGFILEW;
- typedef struct _EVENT_TRACE_LOGFILEA EVENT_TRACE_LOGFILEA,*PEVENT_TRACE_LOGFILEA;
- typedef ULONG (WINAPI *PEVENT_TRACE_BUFFER_CALLBACKW) (PEVENT_TRACE_LOGFILEW Logfile);
- typedef ULONG (WINAPI *PEVENT_TRACE_BUFFER_CALLBACKA) (PEVENT_TRACE_LOGFILEA Logfile);
- typedef VOID (WINAPI *PEVENT_CALLBACK) (PEVENT_TRACE pEvent);
- typedef VOID (WINAPI *PEVENT_RECORD_CALLBACK) (PEVENT_RECORD EventRecord);
- typedef ULONG (WINAPI *WMIDPREQUEST) (WMIDPREQUESTCODE RequestCode, PVOID RequestContext, ULONG *BufferSize, PVOID Buffer);
- struct _EVENT_TRACE_LOGFILEW {
- LPWSTR LogFileName;
- LPWSTR LoggerName;
- LONGLONG CurrentTime;
- ULONG BuffersRead;
- __C89_NAMELESS union {
- ULONG LogFileMode;
- ULONG ProcessTraceMode;
- } DUMMYUNIONNAME;
- EVENT_TRACE CurrentEvent;
- TRACE_LOGFILE_HEADER LogfileHeader;
- PEVENT_TRACE_BUFFER_CALLBACKW BufferCallback;
- ULONG BufferSize;
- ULONG Filled;
- ULONG EventsLost;
- __C89_NAMELESS union {
- PEVENT_CALLBACK EventCallback;
- PEVENT_RECORD_CALLBACK EventRecordCallback;
- } DUMMYUNIONNAME2;
- ULONG IsKernelTrace;
- PVOID Context;
- };
- struct _EVENT_TRACE_LOGFILEA {
- LPSTR LogFileName;
- LPSTR LoggerName;
- LONGLONG CurrentTime;
- ULONG BuffersRead;
- __C89_NAMELESS union {
- ULONG LogFileMode;
- ULONG ProcessTraceMode;
- } DUMMYUNIONNAME;
- EVENT_TRACE CurrentEvent;
- TRACE_LOGFILE_HEADER LogfileHeader;
- PEVENT_TRACE_BUFFER_CALLBACKA BufferCallback;
- ULONG BufferSize;
- ULONG Filled;
- ULONG EventsLost;
- __C89_NAMELESS union {
- PEVENT_CALLBACK EventCallback;
- PEVENT_RECORD_CALLBACK EventRecordCallback;
- } DUMMYUNIONNAME2;
- ULONG IsKernelTrace;
- PVOID Context;
- };
- #if defined (_UNICODE) || defined (UNICODE)
- #define PEVENT_TRACE_BUFFER_CALLBACK PEVENT_TRACE_BUFFER_CALLBACKW
- #define EVENT_TRACE_LOGFILE EVENT_TRACE_LOGFILEW
- #define PEVENT_TRACE_LOGFILE PEVENT_TRACE_LOGFILEW
- #define KERNEL_LOGGER_NAME KERNEL_LOGGER_NAMEW
- #define GLOBAL_LOGGER_NAME GLOBAL_LOGGER_NAMEW
- #define EVENT_LOGGER_NAME EVENT_LOGGER_NAMEW
- #else
- #define PEVENT_TRACE_BUFFER_CALLBACK PEVENT_TRACE_BUFFER_CALLBACKA
- #define EVENT_TRACE_LOGFILE EVENT_TRACE_LOGFILEA
- #define PEVENT_TRACE_LOGFILE PEVENT_TRACE_LOGFILEA
- #define KERNEL_LOGGER_NAME KERNEL_LOGGER_NAMEA
- #define GLOBAL_LOGGER_NAME GLOBAL_LOGGER_NAMEA
- #define EVENT_LOGGER_NAME EVENT_LOGGER_NAMEA
- #endif
- #endif
- #ifdef __cplusplus
- extern "C" {
- #endif
- #define ENABLE_TRACE_PARAMETERS_VERSION 1
- #define ENABLE_TRACE_PARAMETERS_VERSION_2 2
- typedef enum _TRACE_QUERY_INFO_CLASS {
- TraceGuidQueryList,
- TraceGuidQueryInfo,
- TraceGuidQueryProcess,
- TraceStackTracingInfo,
- TraceSystemTraceEnableFlagsInfo,
- TraceSampledProfileIntervalInfo,
- TraceProfileSourceConfigInfo,
- TraceProfileSourceListInfo,
- TracePmcEventListInfo,
- TracePmcCounterListInfo,
- TraceSetDisallowList,
- TraceVersionInfo,
- TraceGroupQueryList,
- TraceGroupQueryInfo,
- TraceDisallowListQuery,
- TraceCompressionInfo,
- TracePeriodicCaptureStateListInfo,
- TracePeriodicCaptureStateInfo,
- TraceProviderBinaryTracking,
- TraceMaxLoggersQuery,
- MaxTraceSetInfoClass
- } TRACE_QUERY_INFO_CLASS, TRACE_INFO_CLASS;
- typedef struct _EVENT_FILTER_DESCRIPTOR EVENT_FILTER_DESCRIPTOR,*PEVENT_FILTER_DESCRIPTOR;
- typedef struct _ENABLE_TRACE_PARAMETERS_V1 {
- ULONG Version;
- ULONG EnableProperty;
- ULONG ControlFlags;
- GUID SourceId;
- PEVENT_FILTER_DESCRIPTOR EnableFilterDesc;
- } ENABLE_TRACE_PARAMETERS_V1, *PENABLE_TRACE_PARAMETERS_V1;
- typedef struct _ENABLE_TRACE_PARAMETERS {
- ULONG Version;
- ULONG EnableProperty;
- ULONG ControlFlags;
- GUID SourceId;
- PEVENT_FILTER_DESCRIPTOR EnableFilterDesc;
- ULONG FilterDescCount;
- } ENABLE_TRACE_PARAMETERS, *PENABLE_TRACE_PARAMETERS;
- /*To enable the read event type for disk IO events, set GUID to 3d6fa8d4-fe05-11d0-9dda-00c04fd7ba7c and Type to 10.*/
- typedef struct _CLASSIC_EVENT_ID {
- GUID EventGuid;
- UCHAR Type;
- UCHAR Reserved[7];
- } CLASSIC_EVENT_ID, *PCLASSIC_EVENT_ID;
- typedef struct _TRACE_PROFILE_INTERVAL {
- ULONG Source;
- ULONG Interval;
- } TRACE_PROFILE_INTERVAL, *PTRACE_PROFILE_INTERVAL;
- typedef struct _TRACE_VERSION_INFO {
- UINT EtwTraceProcessingVersion;
- UINT Reserved;
- } TRACE_VERSION_INFO, *PTRACE_VERSION_INFO;
- typedef struct _TRACE_PERIODIC_CAPTURE_STATE_INFO {
- ULONG CaptureStateFrequencyInSeconds;
- USHORT ProviderCount;
- USHORT Reserved;
- } TRACE_PERIODIC_CAPTURE_STATE_INFO, *PTRACE_PERIODIC_CAPTURE_STATE_INFO;
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- EXTERN_C ULONG WMIAPI ControlTraceA (TRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties, ULONG ControlCode);
- EXTERN_C ULONG WMIAPI FlushTraceA (TRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties); EXTERN_C ULONG WMIAPI QueryTraceA (TRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties); EXTERN_C ULONG WMIAPI StartTraceA (PTRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI StopTraceA (TRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI RegisterTraceGuidsA (WMIDPREQUEST RequestAddress, PVOID RequestContext, LPCGUID ControlGuid, ULONG GuidCount, PTRACE_GUID_REGISTRATION TraceGuidReg, LPCSTR MofImagePath, LPCSTR MofResourceName, PTRACEHANDLE RegistrationHandle);
- EXTERN_C TRACEHANDLE WMIAPI OpenTraceA (PEVENT_TRACE_LOGFILEA Logfile);
- EXTERN_C ULONG WMIAPI CloseTrace (TRACEHANDLE TraceHandle);
- EXTERN_C ULONG WMIAPI ProcessTrace (PTRACEHANDLE HandleArray, ULONG HandleCount, LPFILETIME StartTime, LPFILETIME EndTime);
- #endif
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_DESKTOP)
- EXTERN_C ULONG WMIAPI UpdateTraceW (TRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI UpdateTraceA (TRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI QueryAllTracesW (PEVENT_TRACE_PROPERTIES *PropertyArray, ULONG PropertyArrayCount, PULONG LoggerCount);
- EXTERN_C ULONG WMIAPI QueryAllTracesA (PEVENT_TRACE_PROPERTIES *PropertyArray, ULONG PropertyArrayCount, PULONG LoggerCount);
- EXTERN_C ULONG WMIAPI CreateTraceInstanceId (HANDLE RegHandle, PEVENT_INSTANCE_INFO InstInfo);
- EXTERN_C ULONG WMIAPI TraceEvent (TRACEHANDLE TraceHandle, PEVENT_TRACE_HEADER EventTrace);
- EXTERN_C ULONG WMIAPI TraceEventInstance (TRACEHANDLE TraceHandle, PEVENT_INSTANCE_HEADER EventTrace, PEVENT_INSTANCE_INFO InstInfo, PEVENT_INSTANCE_INFO ParentInstInfo);
- EXTERN_C ULONG WMIAPI EnumerateTraceGuids (PTRACE_GUID_PROPERTIES *GuidPropertiesArray, ULONG PropertyArrayCount, PULONG GuidCount);
- EXTERN_C ULONG WMIAPI SetTraceCallback (LPCGUID pGuid, PEVENT_CALLBACK EventCallback);
- EXTERN_C ULONG WMIAPI RemoveTraceCallback (LPCGUID pGuid);
- EXTERN_C ULONG TraceMessageVa (TRACEHANDLE LoggerHandle, ULONG MessageFlags, LPCGUID MessageGuid, USHORT MessageNumber, va_list MessageArgList);
- #if WINVER >= 0x0601
- EXTERN_C ULONG WMIAPI TraceSetInformation (TRACEHANDLE SessionHandle, TRACE_INFO_CLASS InformationClass, PVOID TraceInformation, ULONG InformationLength);
- #endif
- #if WINVER >= 0x0602
- EXTERN_C ULONG WMIAPI TraceQueryInformation (TRACEHANDLE SessionHandle, TRACE_INFO_CLASS InformationClass, PVOID TraceInformation, ULONG InformationLength, PULONG ReturnLength);
- #endif
- #endif /* WINAPI_PARTITION_DESKTOP */
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- typedef enum _ETW_PROCESS_HANDLE_INFO_TYPE {
- EtwQueryPartitionInformation = 1,
- EtwQueryProcessHandleInfoMax
- } ETW_PROCESS_HANDLE_INFO_TYPE;
- typedef struct _ETW_TRACE_PARTITION_INFORMATION {
- GUID PartitionId;
- GUID ParentId;
- LONG64 QpcOffsetFromRoot;
- ULONG PartitionType;
- } ETW_TRACE_PARTITION_INFORMATION, *PETW_TRACE_PARTITION_INFORMATION;
- EXTERN_C TRACEHANDLE WMIAPI OpenTraceW (PEVENT_TRACE_LOGFILEW Logfile);
- #if WINVER >= 0x0600
- EXTERN_C ULONG WMIAPI EnableTraceEx (LPCGUID ProviderId, LPCGUID SourceId, TRACEHANDLE TraceHandle, ULONG IsEnabled, UCHAR Level, ULONGLONG MatchAnyKeyword, ULONGLONG MatchAllKeyword, ULONG EnableProperty, PEVENT_FILTER_DESCRIPTOR EnableFilterDesc);
- EXTERN_C ULONG WMIAPI EnumerateTraceGuidsEx (TRACE_QUERY_INFO_CLASS TraceQueryInfoClass, PVOID InBuffer, ULONG InBufferSize, PVOID OutBuffer, ULONG OutBufferSize, PULONG ReturnLength);
- #endif
- #if WINVER >= 0x0601
- EXTERN_C ULONG WMIAPI EnableTraceEx2 (TRACEHANDLE TraceHandle, LPCGUID ProviderId, ULONG ControlCode, UCHAR Level, ULONGLONG MatchAnyKeyword, ULONGLONG MatchAllKeyword, ULONG Timeout, PENABLE_TRACE_PARAMETERS EnableParameters);
- #endif
- EXTERN_C ULONG WMIAPI StartTraceA (PTRACEHANDLE TraceHandle, LPCSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI StartTraceW (PTRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI StopTraceW (TRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI QueryTraceW (TRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI FlushTraceW (TRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties);
- EXTERN_C ULONG WMIAPI ControlTraceW (TRACEHANDLE TraceHandle, LPCWSTR InstanceName, PEVENT_TRACE_PROPERTIES Properties, ULONG ControlCode);
- EXTERN_C ULONG WMIAPI EnableTrace (ULONG Enable, ULONG EnableFlag, ULONG EnableLevel, LPCGUID ControlGuid, TRACEHANDLE TraceHandle);
- EXTERN_C ULONG WMIAPI RegisterTraceGuidsW (WMIDPREQUEST RequestAddress, PVOID RequestContext, LPCGUID ControlGuid, ULONG GuidCount, PTRACE_GUID_REGISTRATION TraceGuidReg, LPCWSTR MofImagePath, LPCWSTR MofResourceName, PTRACEHANDLE RegistrationHandle);
- EXTERN_C ULONG WMIAPI UnregisterTraceGuids (TRACEHANDLE RegistrationHandle);
- EXTERN_C TRACEHANDLE WMIAPI GetTraceLoggerHandle (PVOID Buffer);
- EXTERN_C UCHAR WMIAPI GetTraceEnableLevel (TRACEHANDLE TraceHandle);
- EXTERN_C ULONG WMIAPI GetTraceEnableFlags (TRACEHANDLE TraceHandle);
- EXTERN_C ULONG __cdecl TraceMessage (TRACEHANDLE LoggerHandle, ULONG MessageFlags, LPCGUID MessageGuid, USHORT MessageNumber,...);
- EXTERN_C ULONG WMIAPI QueryTraceProcessingHandle (TRACEHANDLE ProcessingHandle, ETW_PROCESS_HANDLE_INFO_TYPE InformationClass, PVOID InBuffer, ULONG InBufferSize, PVOID OutBuffer, ULONG OutBufferSize, PULONG ReturnLength);
- #endif /* WINAPI_PARTITION_APP */
- #ifdef __cplusplus
- }
- #endif
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- #define INVALID_PROCESSTRACE_HANDLE ((TRACEHANDLE)INVALID_HANDLE_VALUE)
- #endif
- #if defined (UNICODE) || defined (_UNICODE)
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- #define RegisterTraceGuids RegisterTraceGuidsW
- #define StartTrace StartTraceW
- #define ControlTrace ControlTraceW
- #ifdef __TRACE_W2K_COMPATIBLE
- #define StopTrace(a, b, c) ControlTraceW ((a),(b),(c), EVENT_TRACE_CONTROL_STOP)
- #define QueryTrace(a, b, c) ControlTraceW ((a),(b),(c), EVENT_TRACE_CONTROL_QUERY)
- #define UpdateTrace(a, b, c) ControlTraceW ((a),(b),(c), EVENT_TRACE_CONTROL_UPDATE)
- #else
- #define StopTrace StopTraceW
- #define QueryTrace QueryTraceW
- #define UpdateTrace UpdateTraceW
- #endif
- #define FlushTrace FlushTraceW
- #define QueryAllTraces QueryAllTracesW
- #define OpenTrace OpenTraceW
- #endif
- #else
- #if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_APP)
- #define RegisterTraceGuids RegisterTraceGuidsA
- #define StartTrace StartTraceA
- #define ControlTrace ControlTraceA
- #ifdef __TRACE_W2K_COMPATIBLE
- #define StopTrace(a, b, c) ControlTraceA ((a),(b),(c), EVENT_TRACE_CONTROL_STOP)
- #define QueryTrace(a, b, c) ControlTraceA ((a),(b),(c), EVENT_TRACE_CONTROL_QUERY)
- #define UpdateTrace(a, b, c) ControlTraceA ((a),(b),(c), EVENT_TRACE_CONTROL_UPDATE)
- #else
- #define StopTrace StopTraceA
- #define QueryTrace QueryTraceA
- #define UpdateTrace UpdateTraceA
- #endif
- #define FlushTrace FlushTraceA
- #define QueryAllTraces QueryAllTracesA
- #define OpenTrace OpenTraceA
- #endif
- #endif
- #endif
- #endif
- #endif
|