From 06b083c3751d1e4a7fe82c99929549ca4b1d0ce4 Mon Sep 17 00:00:00 2001 From: Ali Ijaz Sheikh Date: Fri, 3 Aug 2018 16:22:31 -0700 Subject: [PATCH 1/2] deps: cherry-pick bf5ea81 from upstream V8 Original commit message: [tracing] allow dynamic control of tracing If the trace_buffer_ was null, we were returning a pointer to a static flag back that permanently disabled that particular trace point. This implied an assumption that tracing will be statically enabled at process startup, and once it is disabled, it will never be enabled again. On Node.js side we want to dynamically enable/disable tracing as per programmer intent. Change-Id: Ic7a7839b8450ab5c356d85e8e0826f42824907f4 Reviewed-on: https://chromium-review.googlesource.com/1161518 Reviewed-by: Yang Guo Commit-Queue: Ali Ijaz Sheikh Cr-Commit-Position: refs/heads/master@{#54903} Refs: https://github.com/v8/v8/commit/bf5ea8138c0726613c9d722a3ccb552a8f477992 --- common.gypi | 2 +- .../src/libplatform/tracing/tracing-controller.cc | 13 ++++--------- 2 files changed, 5 insertions(+), 10 deletions(-) diff --git a/common.gypi b/common.gypi index a085594786e46f..c2f4b1778a12d0 100644 --- a/common.gypi +++ b/common.gypi @@ -29,7 +29,7 @@ # Reset this number to 0 on major V8 upgrades. # Increment by one for each non-official patch applied to deps/v8. - 'v8_embedder_string': '-node.23', + 'v8_embedder_string': '-node.24', # Enable disassembler for `--print-code` v8 options 'v8_enable_disassembler': 1, diff --git a/deps/v8/src/libplatform/tracing/tracing-controller.cc b/deps/v8/src/libplatform/tracing/tracing-controller.cc index 647306d62790af..b4aa7baf724d4f 100644 --- a/deps/v8/src/libplatform/tracing/tracing-controller.cc +++ b/deps/v8/src/libplatform/tracing/tracing-controller.cc @@ -24,18 +24,17 @@ namespace tracing { // convert internally to determine the category name from the char enabled // pointer. const char* g_category_groups[MAX_CATEGORY_GROUPS] = { - "toplevel", "tracing already shutdown", + "toplevel", "tracing categories exhausted; must increase MAX_CATEGORY_GROUPS", "__metadata"}; // The enabled flag is char instead of bool so that the API can be used from C. unsigned char g_category_group_enabled[MAX_CATEGORY_GROUPS] = {0}; // Indexes here have to match the g_category_groups array indexes above. -const int g_category_already_shutdown = 1; -const int g_category_categories_exhausted = 2; +const int g_category_categories_exhausted = 1; // Metadata category not used in V8. -// const int g_category_metadata = 3; -const int g_num_builtin_categories = 4; +// const int g_category_metadata = 2; +const int g_num_builtin_categories = 3; // Skip default categories. v8::base::AtomicWord g_category_index = g_num_builtin_categories; @@ -103,10 +102,6 @@ void TracingController::UpdateTraceEventDuration( const uint8_t* TracingController::GetCategoryGroupEnabled( const char* category_group) { - if (!trace_buffer_) { - DCHECK(!g_category_group_enabled[g_category_already_shutdown]); - return &g_category_group_enabled[g_category_already_shutdown]; - } return GetCategoryGroupEnabledInternal(category_group); } From 4dff389b28a89f0a6d831fcd164fda6ca71fb5ed Mon Sep 17 00:00:00 2001 From: Ali Ijaz Sheikh Date: Thu, 2 Aug 2018 17:13:21 -0700 Subject: [PATCH 2/2] [squash] add test to dynamic enablement of trace-events --- .../test-trace-events-dynamic-enable.js | 58 +++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 test/parallel/test-trace-events-dynamic-enable.js diff --git a/test/parallel/test-trace-events-dynamic-enable.js b/test/parallel/test-trace-events-dynamic-enable.js new file mode 100644 index 00000000000000..a32949f8ec5994 --- /dev/null +++ b/test/parallel/test-trace-events-dynamic-enable.js @@ -0,0 +1,58 @@ +'use strict'; + +const common = require('../common'); + +common.skipIfInspectorDisabled(); + +const assert = require('assert'); +const { performance } = require('perf_hooks'); +const { Session } = require('inspector'); + +const session = new Session(); + +function post(message, data) { + return new Promise((resolve, reject) => { + session.post(message, data, (err, result) => { + if (err) + reject(new Error(JSON.stringify(err))); + else + resolve(result); + }); + }); +} + +async function test() { + session.connect(); + + let traceNotification = null; + let tracingComplete = false; + session.on('NodeTracing.dataCollected', (n) => traceNotification = n); + session.on('NodeTracing.tracingComplete', () => tracingComplete = true); + + // Generate a node.perf event before tracing is enabled. + performance.mark('mark1'); + + const traceConfig = { includedCategories: ['node.perf'] }; + await post('NodeTracing.start', { traceConfig }); + + // Generate a node.perf event after tracing is enabled. This should be the + // mark event captured. + performance.mark('mark2'); + + await post('NodeTracing.stop', { traceConfig }); + + performance.mark('mark3'); + + session.disconnect(); + + assert.ok(tracingComplete); + assert.ok(traceNotification); + assert.ok(traceNotification.data && traceNotification.data.value); + + const events = traceNotification.data.value; + const marks = events.filter((t) => null !== /node\.perf\.usertim/.exec(t.cat)); + assert.strictEqual(marks.length, 1); + assert.strictEqual(marks[0].name, 'mark2'); +} + +test();