OLD | NEW |
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 Loading... |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |