| 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 |