From 391db5278f61e1f25d7099e823e111ef96a1e9cc Mon Sep 17 00:00:00 2001 From: Ivo Anjo Date: Mon, 11 Dec 2023 13:03:58 +0000 Subject: [PATCH] Add explanation for why we add both cpu/wall-time duration as well as timeline duration --- .../collectors_thread_context.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/ext/ddtrace_profiling_native_extension/collectors_thread_context.c b/ext/ddtrace_profiling_native_extension/collectors_thread_context.c index c158cea5e6c..7360982d47b 100644 --- a/ext/ddtrace_profiling_native_extension/collectors_thread_context.c +++ b/ext/ddtrace_profiling_native_extension/collectors_thread_context.c @@ -644,6 +644,11 @@ VALUE thread_context_collector_sample_after_gc(VALUE self_instance) { state->sampling_buffer, state->recorder_instance, (sample_values) { + // This event gets both a regular cpu/wall-time duration, as a normal cpu/wall-time sample would, as well as a + // timeline duration. + // This is done to enable two use-cases: + // * regular cpu/wall-time makes this event show up as a regular stack in the flamegraph + // * the timeline duration is used when the event shows up in the timeline .cpu_time_ns = state->gc_tracking.accumulated_cpu_time_ns, .cpu_or_wall_samples = 1, .wall_time_ns = state->gc_tracking.accumulated_wall_time_ns,