22 #ifndef SRC_NODE_WIN32_ETW_PROVIDER_INL_H_ 23 #define SRC_NODE_WIN32_ETW_PROVIDER_INL_H_ 25 #if defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS 28 #include "node_etw_provider.h" 31 # define ETW_WRITE_INTPTR_DATA ETW_WRITE_INT64_DATA 33 # define ETW_WRITE_INTPTR_DATA ETW_WRITE_INT32_DATA 43 #define ETW_WRITE_STRING_DATA(data_descriptor, data) \ 44 EventDataDescCreate(data_descriptor, \ 46 (strlen(data) + 1) * sizeof(*data)); 48 #define ETW_WRITE_INT32_DATA(data_descriptor, data) \ 49 EventDataDescCreate(data_descriptor, data, sizeof(int32_t)); 51 #define ETW_WRITE_INT64_DATA(data_descriptor, data) \ 52 EventDataDescCreate(data_descriptor, data, sizeof(int64_t)); 54 #define ETW_WRITE_ADDRESS_DATA(data_descriptor, data) \ 55 EventDataDescCreate(data_descriptor, data, sizeof(intptr_t)); 57 #define ETW_WRITE_INT16_DATA(data_descriptor, data) \ 58 EventDataDescCreate(data_descriptor, data, sizeof(int16_t)); 60 #define ETW_WRITE_WSTRING_DATA_LENGTH(data_descriptor, data, data_len_bytes) \ 61 EventDataDescCreate(data_descriptor, \ 65 #define ETW_WRITE_NET_CONNECTION(descriptors, conn) \ 66 ETW_WRITE_INT32_DATA(descriptors, &conn->fd); \ 67 ETW_WRITE_INT32_DATA(descriptors + 1, &conn->port); \ 68 ETW_WRITE_STRING_DATA(descriptors + 2, conn->remote); \ 69 ETW_WRITE_INT32_DATA(descriptors + 3, &conn->buffered); 71 #define ETW_WRITE_HTTP_SERVER_REQUEST(descriptors, req) \ 72 ETW_WRITE_STRING_DATA(descriptors, req->url); \ 73 ETW_WRITE_STRING_DATA(descriptors + 1, req->method); \ 74 ETW_WRITE_STRING_DATA(descriptors + 2, req->forwardedFor); 76 #define ETW_WRITE_HTTP_CLIENT_REQUEST(descriptors, req) \ 77 ETW_WRITE_STRING_DATA(descriptors, req->url); \ 78 ETW_WRITE_STRING_DATA(descriptors + 1, req->method); 80 #define ETW_WRITE_GC(descriptors, type, flags) \ 81 ETW_WRITE_INT32_DATA(descriptors, &type); \ 82 ETW_WRITE_INT32_DATA(descriptors + 1, &flags); 84 #define ETW_WRITE_V8ADDRESSCHANGE(descriptors, addr1, addr2) \ 85 ETW_WRITE_ADDRESS_DATA(descriptors, &addr1); \ 86 ETW_WRITE_ADDRESS_DATA(descriptors + 1, &addr2); 88 #define ETW_WRITE_JSMETHOD_LOADUNLOAD(descriptors, \ 100 ETW_WRITE_ADDRESS_DATA(descriptors, &context); \ 101 ETW_WRITE_ADDRESS_DATA(descriptors + 1, &startAddr); \ 102 ETW_WRITE_INT64_DATA(descriptors + 2, &size); \ 103 ETW_WRITE_INTPTR_DATA(descriptors + 3, &id); \ 104 ETW_WRITE_INT16_DATA(descriptors + 4, &flags); \ 105 ETW_WRITE_INT16_DATA(descriptors + 5, &rangeId); \ 106 ETW_WRITE_INT64_DATA(descriptors + 6, &sourceId); \ 107 ETW_WRITE_INT32_DATA(descriptors + 7, &line); \ 108 ETW_WRITE_INT32_DATA(descriptors + 8, &col); \ 109 ETW_WRITE_WSTRING_DATA_LENGTH(descriptors + 9, name, name_len_bytes); 112 #define ETW_WRITE_EVENT(eventDescriptor, dataDescriptors) \ 113 DWORD status = event_write(node_provider, \ 115 sizeof(dataDescriptors) / \ 116 sizeof(*dataDescriptors), \ 118 CHECK_EQ(status, ERROR_SUCCESS); 120 #define ETW_WRITE_EMPTY_EVENT(eventDescriptor) \ 121 DWORD status = event_write(node_provider, \ 125 CHECK_EQ(status, ERROR_SUCCESS); 130 const char *
method,
const char *url,
int fd) {
131 EVENT_DATA_DESCRIPTOR descriptors[7];
132 ETW_WRITE_HTTP_SERVER_REQUEST(descriptors, req);
133 ETW_WRITE_NET_CONNECTION(descriptors + 3, conn);
134 ETW_WRITE_EVENT(NODE_HTTP_SERVER_REQUEST_EVENT, descriptors);
139 const char *remote,
int port,
int fd) {
140 EVENT_DATA_DESCRIPTOR descriptors[4];
141 ETW_WRITE_NET_CONNECTION(descriptors, conn);
142 ETW_WRITE_EVENT(NODE_HTTP_SERVER_RESPONSE_EVENT, descriptors);
148 const char *
method,
const char *url,
int fd) {
149 EVENT_DATA_DESCRIPTOR descriptors[6];
150 ETW_WRITE_HTTP_CLIENT_REQUEST(descriptors, req);
151 ETW_WRITE_NET_CONNECTION(descriptors + 2, conn);
152 ETW_WRITE_EVENT(NODE_HTTP_CLIENT_REQUEST_EVENT, descriptors);
157 const char *remote,
int port,
int fd) {
158 EVENT_DATA_DESCRIPTOR descriptors[4];
159 ETW_WRITE_NET_CONNECTION(descriptors, conn);
160 ETW_WRITE_EVENT(NODE_HTTP_CLIENT_RESPONSE_EVENT, descriptors);
165 const char *remote,
int port,
int fd) {
166 EVENT_DATA_DESCRIPTOR descriptors[4];
167 ETW_WRITE_NET_CONNECTION(descriptors, conn);
168 ETW_WRITE_EVENT(NODE_NET_SERVER_CONNECTION_EVENT, descriptors);
173 const char *remote,
int port,
int fd) {
174 EVENT_DATA_DESCRIPTOR descriptors[4];
175 ETW_WRITE_NET_CONNECTION(descriptors, conn);
176 ETW_WRITE_EVENT(NODE_NET_STREAM_END_EVENT, descriptors);
181 v8::GCCallbackFlags flags,
182 v8::Isolate* isolate) {
183 if (events_enabled > 0) {
184 EVENT_DATA_DESCRIPTOR descriptors[2];
185 ETW_WRITE_GC(descriptors, type, flags);
186 ETW_WRITE_EVENT(NODE_GC_START_EVENT, descriptors);
192 v8::GCCallbackFlags flags,
193 v8::Isolate* isolate) {
194 if (events_enabled > 0) {
195 EVENT_DATA_DESCRIPTOR descriptors[2];
196 ETW_WRITE_GC(descriptors, type, flags);
197 ETW_WRITE_EVENT(NODE_GC_DONE_EVENT, descriptors);
202 void NODE_V8SYMBOL_REMOVE(
const void* addr1,
const void* addr2) {
203 if (events_enabled > 0) {
204 EVENT_DATA_DESCRIPTOR descriptors[2];
205 ETW_WRITE_V8ADDRESSCHANGE(descriptors, addr1, addr2);
206 ETW_WRITE_EVENT(NODE_V8SYMBOL_REMOVE_EVENT, descriptors);
211 void NODE_V8SYMBOL_MOVE(
const void* addr1,
const void* addr2) {
212 if (events_enabled > 0) {
213 EVENT_DATA_DESCRIPTOR descriptors[2];
214 ETW_WRITE_V8ADDRESSCHANGE(descriptors, addr1, addr2);
215 ETW_WRITE_EVENT(NODE_V8SYMBOL_MOVE_EVENT, descriptors);
220 void NODE_V8SYMBOL_RESET() {
221 if (events_enabled > 0) {
222 ETW_WRITE_EMPTY_EVENT(NODE_V8SYMBOL_RESET_EVENT);
226 #define SETSYMBUF(s) \ 228 symbol_len = arraysize(s) - 1; 230 void NODE_V8SYMBOL_ADD(LPCSTR symbol,
234 if (events_enabled > 0) {
236 if (symbol ==
nullptr) {
237 SETSYMBUF(L
"nullptr");
239 symbol_len = MultiByteToWideChar(CP_ACP,
245 if (symbol_len == 0) {
246 SETSYMBUF(L
"Invalid");
248 if (symbol_len > 127) {
251 symbuf[symbol_len] = L
'\0';
254 void* context =
nullptr;
255 INT64 size = (INT64)len;
256 INT_PTR
id = (INT_PTR)addr1;
262 EVENT_DATA_DESCRIPTOR descriptors[10];
263 ETW_WRITE_JSMETHOD_LOADUNLOAD(descriptors,
274 (symbol_len + 1) *
sizeof(symbuf[0]));
275 ETW_WRITE_EVENT(MethodLoad, descriptors);
287 bool NODE_V8SYMBOL_ENABLED() {
return events_enabled > 0; }
291 #endif // defined(NODE_WANT_INTERNALS) && NODE_WANT_INTERNALS 293 #endif // SRC_NODE_WIN32_ETW_PROVIDER_INL_H_ #define NODE_HTTP_CLIENT_RESPONSE(arg0)
EventWriteFunc event_write
#define NODE_NET_STREAM_END_ENABLED()
#define NODE_NET_STREAM_END(arg0)
#define NODE_GC_DONE(arg0, arg1, arg2)
#define NODE_HTTP_CLIENT_REQUEST(arg0, arg1)
#define NODE_HTTP_SERVER_REQUEST_ENABLED()
#define NODE_NET_SERVER_CONNECTION_ENABLED()
#define NODE_HTTP_CLIENT_REQUEST_ENABLED()
#define NODE_HTTP_SERVER_RESPONSE_ENABLED()
#define NODE_HTTP_CLIENT_RESPONSE_ENABLED()
#define NODE_NET_SERVER_CONNECTION(arg0)
#define NODE_GC_START(arg0, arg1, arg2)
#define NODE_HTTP_SERVER_RESPONSE(arg0)
#define NODE_HTTP_SERVER_REQUEST(arg0, arg1)