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

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

Issue 1417003003: [tracing] Dump child processes' memory metrics in browser (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@web_cache2_base
Patch Set: Nits. Created 5 years, 1 month 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
1 // Copyright 2015 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/trace_event/memory_dump_manager.h" 5 #include "base/trace_event/memory_dump_manager.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/atomic_sequence_num.h" 9 #include "base/atomic_sequence_num.h"
10 #include "base/base_switches.h" 10 #include "base/base_switches.h"
11 #include "base/command_line.h" 11 #include "base/command_line.h"
12 #include "base/compiler_specific.h" 12 #include "base/compiler_specific.h"
13 #include "base/thread_task_runner_handle.h" 13 #include "base/thread_task_runner_handle.h"
14 #include "base/threading/thread.h" 14 #include "base/threading/thread.h"
15 #include "base/trace_event/memory_dump_provider.h" 15 #include "base/trace_event/memory_dump_provider.h"
16 #include "base/trace_event/memory_dump_session_state.h" 16 #include "base/trace_event/memory_dump_session_state.h"
17 #include "base/trace_event/memory_profiler_allocation_context.h" 17 #include "base/trace_event/memory_profiler_allocation_context.h"
18 #include "base/trace_event/process_memory_dump.h" 18 #include "base/trace_event/process_memory_dump.h"
19 #include "base/trace_event/trace_event_argument.h" 19 #include "base/trace_event/trace_event_argument.h"
20 #include "build/build_config.h" 20 #include "build/build_config.h"
21 21
22 #if !defined(OS_NACL)
23 #include "base/trace_event/process_memory_totals_dump_provider.h"
24 #endif
25
26 #if defined(OS_LINUX) || defined(OS_ANDROID) 22 #if defined(OS_LINUX) || defined(OS_ANDROID)
27 #include "base/trace_event/malloc_dump_provider.h" 23 #include "base/trace_event/malloc_dump_provider.h"
28 #include "base/trace_event/process_memory_maps_dump_provider.h"
29 #endif 24 #endif
30 25
31 #if defined(OS_ANDROID) 26 #if defined(OS_ANDROID)
32 #include "base/trace_event/java_heap_dump_provider_android.h" 27 #include "base/trace_event/java_heap_dump_provider_android.h"
33 #endif 28 #endif
34 29
35 #if defined(OS_WIN) 30 #if defined(OS_WIN)
36 #include "base/trace_event/winheap_dump_provider_win.h" 31 #include "base/trace_event/winheap_dump_provider_win.h"
37 #endif 32 #endif
38 33
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after
143 bool is_coordinator) { 138 bool is_coordinator) {
144 { 139 {
145 AutoLock lock(lock_); 140 AutoLock lock(lock_);
146 DCHECK(delegate); 141 DCHECK(delegate);
147 DCHECK(!delegate_); 142 DCHECK(!delegate_);
148 delegate_ = delegate; 143 delegate_ = delegate;
149 is_coordinator_ = is_coordinator; 144 is_coordinator_ = is_coordinator;
150 } 145 }
151 146
152 // Enable the core dump providers. 147 // Enable the core dump providers.
153 #if !defined(OS_NACL) 148 #if defined(OS_ANDROID)
154 RegisterDumpProvider(ProcessMemoryTotalsDumpProvider::GetInstance(), 149 const ProcessHandle current_process = GetCurrentProcessHandle();
155 "ProcessMemoryTotals", nullptr); 150 scoped_ptr<ProcessMemoryTotalsDumpProvider> totals_provider(
156 #endif 151 ProcessMemoryTotalsDumpProvider::CreateForProcess(current_process));
152 RegisterDumpProvider(totals_provider.get(), "ProcessMemoryTotals", nullptr);
153 process_totals_providers_map_.insert(current_process, totals_provider.Pass());
154
155 scoped_ptr<ProcessMemoryMapsDumpProvider> mmaps_provider(
156 ProcessMemoryMapsDumpProvider::CreateForProcess(current_process));
157 RegisterDumpProvider(mmaps_provider.get(), "ProcessMemoryMaps", nullptr);
158 process_mmaps_providers_map_.insert(current_process, mmaps_provider.Pass());
159
160 RegisterDumpProvider(JavaHeapDumpProvider::GetInstance(), "JavaHeap",
161 nullptr);
162 #endif // defined(OS_ANDROID)
157 163
158 #if defined(OS_LINUX) || defined(OS_ANDROID) 164 #if defined(OS_LINUX) || defined(OS_ANDROID)
159 RegisterDumpProvider(ProcessMemoryMapsDumpProvider::GetInstance(),
160 "ProcessMemoryMaps", nullptr);
161 RegisterDumpProvider(MallocDumpProvider::GetInstance(), "Malloc", nullptr); 165 RegisterDumpProvider(MallocDumpProvider::GetInstance(), "Malloc", nullptr);
162 #endif 166 #elif defined(OS_WIN)
163
164 #if defined(OS_ANDROID)
165 RegisterDumpProvider(JavaHeapDumpProvider::GetInstance(), "JavaHeap",
166 nullptr);
167 #endif
168
169 #if defined(OS_WIN)
170 RegisterDumpProvider(WinHeapDumpProvider::GetInstance(), "WinHeap", nullptr); 167 RegisterDumpProvider(WinHeapDumpProvider::GetInstance(), "WinHeap", nullptr);
171 #endif 168 #endif
172 169
173 // If tracing was enabled before initializing MemoryDumpManager, we missed the 170 // If tracing was enabled before initializing MemoryDumpManager, we missed the
174 // OnTraceLogEnabled() event. Synthetize it so we can late-join the party. 171 // OnTraceLogEnabled() event. Synthetize it so we can late-join the party.
175 bool is_tracing_already_enabled = TraceLog::GetInstance()->IsEnabled(); 172 bool is_tracing_already_enabled = TraceLog::GetInstance()->IsEnabled();
176 TRACE_EVENT0(kTraceCategory, "init"); // Add to trace-viewer category list. 173 TRACE_EVENT0(kTraceCategory, "init"); // Add to trace-viewer category list.
177 TraceLog::GetInstance()->AddEnabledStateObserver(this); 174 TraceLog::GetInstance()->AddEnabledStateObserver(this);
178 if (is_tracing_already_enabled) 175 if (is_tracing_already_enabled)
179 OnTraceLogEnabled(); 176 OnTraceLogEnabled();
(...skipping 415 matching lines...) Expand 10 before | Expand all | Expand 10 after
595 // or will deadlock (e.g., if ContinueAsyncProcessDump() tries to acquire it). 592 // or will deadlock (e.g., if ContinueAsyncProcessDump() tries to acquire it).
596 periodic_dump_timer_.Stop(); 593 periodic_dump_timer_.Stop();
597 if (dump_thread) 594 if (dump_thread)
598 dump_thread->Stop(); 595 dump_thread->Stop();
599 } 596 }
600 597
601 uint64_t MemoryDumpManager::GetTracingProcessId() const { 598 uint64_t MemoryDumpManager::GetTracingProcessId() const {
602 return delegate_->GetTracingProcessId(); 599 return delegate_->GetTracingProcessId();
603 } 600 }
604 601
602 void MemoryDumpManager::RegisterProcessMetricsProvidersFor(
603 ProcessHandle process) {
604 #if defined(OS_LINUX)
605 scoped_ptr<ProcessMemoryTotalsDumpProvider> totals_provider(
606 ProcessMemoryTotalsDumpProvider::CreateForProcess(process));
607 MemoryDumpProvider::Options totals_options = {process};
608 RegisterDumpProvider(totals_provider.get(), "ProcessMemoryTotals", nullptr,
609 totals_options);
610 process_totals_providers_map_.insert(process, totals_provider.Pass());
611
612 scoped_ptr<ProcessMemoryMapsDumpProvider> mmaps_provider(
613 ProcessMemoryMapsDumpProvider::CreateForProcess(process));
614 MemoryDumpProvider::Options mmaps_options = {process};
615 RegisterDumpProvider(mmaps_provider.get(), "ProcessMemoryMaps", nullptr,
616 mmaps_options);
617 process_mmaps_providers_map_.insert(process, mmaps_provider.Pass());
618 #endif // defined(OS_LINUX)
619 }
620
621 void MemoryDumpManager::UnregisterProcessMetricsProvidersFor(
622 ProcessHandle process) {
623 #if defined(OS_LINUX)
624 ProcessTotalsDumpProvidersMap::const_iterator totals_it =
625 process_totals_providers_map_.find(process);
626 DCHECK(totals_it != process_totals_providers_map_.end());
627 UnregisterDumpProvider(totals_it->second);
628 process_totals_providers_map_.erase(totals_it);
629
630 ProcessMapsDumpProvidersMap::const_iterator mmaps_it =
631 process_mmaps_providers_map_.find(process);
632 DCHECK(mmaps_it != process_mmaps_providers_map_.begin());
633 UnregisterDumpProvider(mmaps_it->second);
634 process_mmaps_providers_map_.erase(mmaps_it);
635 #endif // defined(OS_LINUX)
636 }
637
605 MemoryDumpManager::MemoryDumpProviderInfo::MemoryDumpProviderInfo( 638 MemoryDumpManager::MemoryDumpProviderInfo::MemoryDumpProviderInfo(
606 MemoryDumpProvider* dump_provider, 639 MemoryDumpProvider* dump_provider,
607 const char* name, 640 const char* name,
608 const scoped_refptr<SingleThreadTaskRunner>& task_runner, 641 const scoped_refptr<SingleThreadTaskRunner>& task_runner,
609 const MemoryDumpProvider::Options& options) 642 const MemoryDumpProvider::Options& options)
610 : dump_provider(dump_provider), 643 : dump_provider(dump_provider),
611 name(name), 644 name(name),
612 task_runner(task_runner), 645 task_runner(task_runner),
613 options(options), 646 options(options),
614 consecutive_failures(0), 647 consecutive_failures(0),
(...skipping 21 matching lines...) Expand all
636 session_state(session_state), 669 session_state(session_state),
637 callback(callback), 670 callback(callback),
638 callback_task_runner(MessageLoop::current()->task_runner()), 671 callback_task_runner(MessageLoop::current()->task_runner()),
639 dump_thread_task_runner(dump_thread_task_runner) {} 672 dump_thread_task_runner(dump_thread_task_runner) {}
640 673
641 MemoryDumpManager::ProcessMemoryDumpAsyncState::~ProcessMemoryDumpAsyncState() { 674 MemoryDumpManager::ProcessMemoryDumpAsyncState::~ProcessMemoryDumpAsyncState() {
642 } 675 }
643 676
644 } // namespace trace_event 677 } // namespace trace_event
645 } // namespace base 678 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698