trace-event.cc 2.24 KB
Newer Older
1 2 3 4 5 6
// Copyright 2015 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "src/tracing/trace-event.h"

7 8
#include <string.h>

9
#include "src/execution/isolate.h"
10
#include "src/init/v8.h"
11
#include "src/logging/counters.h"
12
#include "src/tracing/traced-value.h"
13 14 15 16 17

namespace v8 {
namespace internal {
namespace tracing {

18
#if !defined(V8_USE_PERFETTO)
19 20
v8::TracingController* TraceEventHelper::GetTracingController() {
  return v8::internal::V8::GetCurrentPlatform()->GetTracingController();
21 22
}

23 24
#ifdef V8_RUNTIME_CALL_STATS

25 26
void CallStatsScopedTracer::AddEndTraceEvent() {
  if (!has_parent_scope_ && p_data_->isolate) {
27 28
    auto value = v8::tracing::TracedValue::Create();
    p_data_->isolate->counters()->runtime_call_stats()->Dump(value.get());
29 30 31
    v8::internal::tracing::AddTraceEvent(
        TRACE_EVENT_PHASE_END, p_data_->category_group_enabled, p_data_->name,
        v8::internal::tracing::kGlobalScope, v8::internal::tracing::kNoId,
32
        v8::internal::tracing::kNoId, TRACE_EVENT_FLAG_NONE,
33
        "runtime-call-stats", std::move(value));
34 35 36 37 38 39 40 41
  } else {
    v8::internal::tracing::AddTraceEvent(
        TRACE_EVENT_PHASE_END, p_data_->category_group_enabled, p_data_->name,
        v8::internal::tracing::kGlobalScope, v8::internal::tracing::kNoId,
        v8::internal::tracing::kNoId, TRACE_EVENT_FLAG_NONE);
  }
}

42
void CallStatsScopedTracer::Initialize(v8::internal::Isolate* isolate,
43 44 45 46 47 48
                                       const uint8_t* category_group_enabled,
                                       const char* name) {
  data_.isolate = isolate;
  data_.category_group_enabled = category_group_enabled;
  data_.name = name;
  p_data_ = &data_;
49
  RuntimeCallStats* table = isolate->counters()->runtime_call_stats();
50
  has_parent_scope_ = table->InUse();
51
  if (!has_parent_scope_) table->Reset();
52 53 54 55 56
  v8::internal::tracing::AddTraceEvent(
      TRACE_EVENT_PHASE_BEGIN, category_group_enabled, name,
      v8::internal::tracing::kGlobalScope, v8::internal::tracing::kNoId,
      TRACE_EVENT_FLAG_NONE, v8::internal::tracing::kNoId);
}
57 58

#endif  // defined(V8_RUNTIME_CALL_STATS)
59
#endif  // !defined(V8_USE_PERFETTO)
60

61 62 63
}  // namespace tracing
}  // namespace internal
}  // namespace v8