%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// 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" #include <string.h> #include "src/execution/isolate.h" #include "src/init/v8.h" #include "src/logging/counters.h" #include "src/tracing/traced-value.h" namespace v8 { namespace internal { namespace tracing { #if !defined(V8_USE_PERFETTO) v8::TracingController* TraceEventHelper::GetTracingController() { return v8::internal::V8::GetCurrentPlatform()->GetTracingController(); } #ifdef V8_RUNTIME_CALL_STATS void CallStatsScopedTracer::AddEndTraceEvent() { if (!has_parent_scope_ && p_data_->isolate) { auto value = v8::tracing::TracedValue::Create(); p_data_->isolate->counters()->runtime_call_stats()->Dump(value.get()); 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, "runtime-call-stats", std::move(value)); } 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); } } void CallStatsScopedTracer::Initialize(v8::internal::Isolate* isolate, 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_; RuntimeCallStats* table = isolate->counters()->runtime_call_stats(); has_parent_scope_ = table->InUse(); if (!has_parent_scope_) table->Reset(); 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); } #endif // defined(V8_RUNTIME_CALL_STATS) #endif // !defined(V8_USE_PERFETTO) } // namespace tracing } // namespace internal } // namespace v8