forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathperfetto_platform.cc
98 lines (85 loc) · 3.29 KB
/
perfetto_platform.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// Copyright 2020 The Chromium 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 "base/tracing/perfetto_platform.h"
#include "base/deferred_sequenced_task_runner.h"
#include "base/task/task_traits.h"
#include "base/task/thread_pool.h"
#include "base/trace_event/trace_event.h"
#include "base/tracing/perfetto_task_runner.h"
#include "base/tracing_buildflags.h"
#include "build/build_config.h"
#include "third_party/perfetto/protos/perfetto/trace/track_event/thread_descriptor.gen.h"
#if !defined(OS_NACL)
#include "third_party/perfetto/include/perfetto/ext/base/thread_task_runner.h"
#endif
namespace base {
namespace tracing {
PerfettoPlatform::PerfettoPlatform(TaskRunnerType task_runner_type)
: task_runner_type_(task_runner_type),
deferred_task_runner_(new DeferredSequencedTaskRunner()),
thread_local_object_([](void* object) {
delete static_cast<ThreadLocalObject*>(object);
}) {
ThreadIdNameManager::GetInstance()->AddObserver(this);
}
PerfettoPlatform::~PerfettoPlatform() {
ThreadIdNameManager::GetInstance()->RemoveObserver(this);
}
void PerfettoPlatform::StartTaskRunner(
scoped_refptr<SequencedTaskRunner> task_runner) {
DCHECK_EQ(task_runner_type_, TaskRunnerType::kThreadPool);
DCHECK(!did_start_task_runner_);
deferred_task_runner_->StartWithTaskRunner(task_runner);
did_start_task_runner_ = true;
}
SequencedTaskRunner* PerfettoPlatform::task_runner() const {
return deferred_task_runner_.get();
}
PerfettoPlatform::ThreadLocalObject*
PerfettoPlatform::GetOrCreateThreadLocalObject() {
auto* object = static_cast<ThreadLocalObject*>(thread_local_object_.Get());
if (!object) {
object = ThreadLocalObject::CreateInstance().release();
thread_local_object_.Set(object);
}
return object;
}
std::unique_ptr<perfetto::base::TaskRunner> PerfettoPlatform::CreateTaskRunner(
const CreateTaskRunnerArgs&) {
switch (task_runner_type_) {
case TaskRunnerType::kBuiltin:
#if !defined(OS_NACL)
return std::make_unique<perfetto::base::ThreadTaskRunner>(
perfetto::base::ThreadTaskRunner::CreateAndStart());
#else
DCHECK(false);
return nullptr;
#endif
case TaskRunnerType::kThreadPool:
// We can't create a real task runner yet because the ThreadPool may not
// be initialized. Instead, we point Perfetto to a buffering task runner
// which will become active as soon as the thread pool is up (see
// StartTaskRunner).
return std::make_unique<PerfettoTaskRunner>(deferred_task_runner_);
}
}
std::string PerfettoPlatform::GetCurrentProcessName() {
// TODO(skyostil): Unimplemented since we're not registering producers through
// the client API yet.
return "";
}
void PerfettoPlatform::OnThreadNameChanged(const char* name) {
#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
// TODO(skyostil): Also capture names for threads which predate tracing being
// initialized.
if (perfetto::Tracing::IsInitialized()) {
auto track = perfetto::ThreadTrack::Current();
auto desc = track.Serialize();
desc.mutable_thread()->set_thread_name(name);
perfetto::TrackEvent::SetTrackDescriptor(track, std::move(desc));
}
#endif // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
}
} // namespace tracing
} // namespace base