forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfile_tracing.cc
65 lines (51 loc) · 1.72 KB
/
file_tracing.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
// Copyright 2015 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/files/file_tracing.h"
#include "base/atomicops.h"
#include "base/files/file.h"
using base::subtle::AtomicWord;
namespace base {
namespace {
AtomicWord g_provider;
}
FileTracing::Provider* GetProvider() {
AtomicWord provider = base::subtle::Acquire_Load(&g_provider);
return reinterpret_cast<FileTracing::Provider*>(provider);
}
// static
bool FileTracing::IsCategoryEnabled() {
FileTracing::Provider* provider = GetProvider();
return provider && provider->FileTracingCategoryIsEnabled();
}
// static
void FileTracing::SetProvider(FileTracing::Provider* provider) {
base::subtle::Release_Store(&g_provider,
reinterpret_cast<AtomicWord>(provider));
}
FileTracing::ScopedEnabler::ScopedEnabler() {
FileTracing::Provider* provider = GetProvider();
if (provider)
provider->FileTracingEnable(this);
}
FileTracing::ScopedEnabler::~ScopedEnabler() {
FileTracing::Provider* provider = GetProvider();
if (provider)
provider->FileTracingDisable(this);
}
FileTracing::ScopedTrace::ScopedTrace() : id_(nullptr) {}
FileTracing::ScopedTrace::~ScopedTrace() {
if (id_) {
FileTracing::Provider* provider = GetProvider();
if (provider)
provider->FileTracingEventEnd(name_, id_);
}
}
void FileTracing::ScopedTrace::Initialize(const char* name,
const File* file,
int64_t size) {
id_ = &file->trace_enabler_;
name_ = name;
GetProvider()->FileTracingEventBegin(name_, id_, file->tracing_path_, size);
}
} // namespace base