Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(288)

Side by Side Diff: base/trace_event/process_memory_totals_dump_provider.cc

Issue 1647803004: Move base to DEPS (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/trace_event/process_memory_totals_dump_provider.h"
6
7 #include "base/process/process_metrics.h"
8 #include "base/trace_event/process_memory_dump.h"
9 #include "base/trace_event/process_memory_totals.h"
10
11 #if defined(OS_LINUX) || defined(OS_ANDROID)
12 #include <fcntl.h>
13
14 #include "base/files/file_util.h"
15
16 namespace {
17 bool kernel_supports_rss_peak_reset = true;
18 const char kClearPeakRssCommand[] = "5";
19 }
20 #endif
21
22 namespace base {
23 namespace trace_event {
24
25 // static
26 uint64 ProcessMemoryTotalsDumpProvider::rss_bytes_for_testing = 0;
27
28 namespace {
29
30 ProcessMetrics* CreateProcessMetricsForCurrentProcess() {
31 #if !defined(OS_MACOSX) || defined(OS_IOS)
32 return ProcessMetrics::CreateProcessMetrics(GetCurrentProcessHandle());
33 #else
34 return ProcessMetrics::CreateProcessMetrics(GetCurrentProcessHandle(), NULL);
35 #endif
36 }
37 } // namespace
38
39 // static
40 ProcessMemoryTotalsDumpProvider*
41 ProcessMemoryTotalsDumpProvider::GetInstance() {
42 return Singleton<
43 ProcessMemoryTotalsDumpProvider,
44 LeakySingletonTraits<ProcessMemoryTotalsDumpProvider>>::get();
45 }
46
47 ProcessMemoryTotalsDumpProvider::ProcessMemoryTotalsDumpProvider()
48 : process_metrics_(CreateProcessMetricsForCurrentProcess()) {
49 }
50
51 ProcessMemoryTotalsDumpProvider::~ProcessMemoryTotalsDumpProvider() {
52 }
53
54 // Called at trace dump point time. Creates a snapshot the memory counters for
55 // the current process.
56 bool ProcessMemoryTotalsDumpProvider::OnMemoryDump(ProcessMemoryDump* pmd) {
57 const uint64 rss_bytes = rss_bytes_for_testing
58 ? rss_bytes_for_testing
59 : process_metrics_->GetWorkingSetSize();
60
61 uint64 peak_rss_bytes = 0;
62
63 #if !defined(OS_IOS)
64 peak_rss_bytes = process_metrics_->GetPeakWorkingSetSize();
65 #if defined(OS_LINUX) || defined(OS_ANDROID)
66 if (kernel_supports_rss_peak_reset) {
67 // TODO(ssid): Fix crbug.com/461788 to write to the file from sandboxed
68 // processes.
69 int clear_refs_fd = open("/proc/self/clear_refs", O_WRONLY);
70 if (clear_refs_fd > 0 &&
71 WriteFileDescriptor(clear_refs_fd, kClearPeakRssCommand,
72 sizeof(kClearPeakRssCommand))) {
73 pmd->process_totals()->set_is_peak_rss_resetable(true);
74 } else {
75 kernel_supports_rss_peak_reset = false;
76 }
77 close(clear_refs_fd);
78 }
79 #endif // defined(OS_LINUX) || defined(OS_ANDROID)
80 #endif // !defined(OS_IOS)
81
82 if (rss_bytes > 0) {
83 pmd->process_totals()->set_resident_set_bytes(rss_bytes);
84 pmd->process_totals()->set_peak_resident_set_bytes(peak_rss_bytes);
85 pmd->set_has_process_totals();
86 return true;
87 }
88
89 return false;
90 }
91
92 } // namespace trace_event
93 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698