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/command_line.h" | 10 #include "base/command_line.h" |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
80 MemoryDumpManager* MemoryDumpManager::GetInstance() { | 80 MemoryDumpManager* MemoryDumpManager::GetInstance() { |
81 if (g_instance_for_testing) | 81 if (g_instance_for_testing) |
82 return g_instance_for_testing; | 82 return g_instance_for_testing; |
83 | 83 |
84 return Singleton<MemoryDumpManager, | 84 return Singleton<MemoryDumpManager, |
85 LeakySingletonTraits<MemoryDumpManager>>::get(); | 85 LeakySingletonTraits<MemoryDumpManager>>::get(); |
86 } | 86 } |
87 | 87 |
88 // static | 88 // static |
89 void MemoryDumpManager::SetInstanceForTesting(MemoryDumpManager* instance) { | 89 void MemoryDumpManager::SetInstanceForTesting(MemoryDumpManager* instance) { |
90 if (instance) | |
91 instance->skip_core_dumpers_auto_registration_for_testing_ = true; | |
92 g_instance_for_testing = instance; | 90 g_instance_for_testing = instance; |
93 } | 91 } |
94 | 92 |
95 MemoryDumpManager::MemoryDumpManager() | 93 MemoryDumpManager::MemoryDumpManager() |
96 : delegate_(nullptr), | 94 : delegate_(nullptr), |
97 memory_tracing_enabled_(0), | 95 memory_tracing_enabled_(0), |
98 tracing_process_id_(kInvalidTracingProcessId), | 96 tracing_process_id_(kInvalidTracingProcessId), |
99 system_allocator_pool_name_(nullptr), | 97 system_allocator_pool_name_(nullptr), |
100 skip_core_dumpers_auto_registration_for_testing_(false), | 98 ignore_registrations_for_testing_(false), |
101 disable_periodic_dumps_for_testing_(false) { | 99 disable_periodic_dumps_for_testing_(false) { |
102 g_next_guid.GetNext(); // Make sure that first guid is not zero. | 100 g_next_guid.GetNext(); // Make sure that first guid is not zero. |
103 } | 101 } |
104 | 102 |
105 MemoryDumpManager::~MemoryDumpManager() { | 103 MemoryDumpManager::~MemoryDumpManager() { |
106 base::trace_event::TraceLog::GetInstance()->RemoveEnabledStateObserver(this); | 104 base::trace_event::TraceLog::GetInstance()->RemoveEnabledStateObserver(this); |
107 } | 105 } |
108 | 106 |
109 void MemoryDumpManager::Initialize() { | 107 void MemoryDumpManager::Initialize() { |
110 TRACE_EVENT0(kTraceCategory, "init"); // Add to trace-viewer category list. | 108 TRACE_EVENT0(kTraceCategory, "init"); // Add to trace-viewer category list. |
111 trace_event::TraceLog::GetInstance()->AddEnabledStateObserver(this); | 109 trace_event::TraceLog::GetInstance()->AddEnabledStateObserver(this); |
112 | 110 |
113 if (skip_core_dumpers_auto_registration_for_testing_) | |
114 return; | |
115 | |
116 // Enable the core dump providers. | 111 // Enable the core dump providers. |
117 #if !defined(OS_NACL) | 112 #if !defined(OS_NACL) |
118 RegisterDumpProvider(ProcessMemoryTotalsDumpProvider::GetInstance()); | 113 RegisterDumpProvider(ProcessMemoryTotalsDumpProvider::GetInstance()); |
119 #endif | 114 #endif |
120 | 115 |
121 #if defined(OS_LINUX) || defined(OS_ANDROID) | 116 #if defined(OS_LINUX) || defined(OS_ANDROID) |
122 // The memory maps dump provider is currently disabled for security reasons | 117 // The memory maps dump provider is currently disabled for security reasons |
123 // and will be enabled once tracing is more secure (crbug.com/517906). | 118 // and will be enabled once tracing is more secure (crbug.com/517906). |
124 // It is still enabled for running benchmarks. | 119 // It is still enabled for running benchmarks. |
125 if (CommandLine::ForCurrentProcess()->HasSwitch( | 120 if (CommandLine::ForCurrentProcess()->HasSwitch( |
(...skipping 17 matching lines...) Expand all Loading... |
143 | 138 |
144 void MemoryDumpManager::SetDelegate(MemoryDumpManagerDelegate* delegate) { | 139 void MemoryDumpManager::SetDelegate(MemoryDumpManagerDelegate* delegate) { |
145 AutoLock lock(lock_); | 140 AutoLock lock(lock_); |
146 DCHECK_EQ(static_cast<MemoryDumpManagerDelegate*>(nullptr), delegate_); | 141 DCHECK_EQ(static_cast<MemoryDumpManagerDelegate*>(nullptr), delegate_); |
147 delegate_ = delegate; | 142 delegate_ = delegate; |
148 } | 143 } |
149 | 144 |
150 void MemoryDumpManager::RegisterDumpProvider( | 145 void MemoryDumpManager::RegisterDumpProvider( |
151 MemoryDumpProvider* mdp, | 146 MemoryDumpProvider* mdp, |
152 const scoped_refptr<SingleThreadTaskRunner>& task_runner) { | 147 const scoped_refptr<SingleThreadTaskRunner>& task_runner) { |
| 148 AutoLock lock(lock_); |
| 149 |
| 150 if (ignore_registrations_for_testing_) |
| 151 return; |
| 152 |
153 MemoryDumpProviderInfo mdp_info(mdp, task_runner); | 153 MemoryDumpProviderInfo mdp_info(mdp, task_runner); |
154 AutoLock lock(lock_); | |
155 auto iter_new = dump_providers_.insert(mdp_info); | 154 auto iter_new = dump_providers_.insert(mdp_info); |
156 | 155 |
157 // If there was a previous entry, replace it with the new one. This is to deal | 156 // If there was a previous entry, replace it with the new one. This is to deal |
158 // with the case where a dump provider unregisters itself and then re- | 157 // with the case where a dump provider unregisters itself and then re- |
159 // registers before a memory dump happens, so its entry was still in the | 158 // registers before a memory dump happens, so its entry was still in the |
160 // collection but flagged |unregistered|. | 159 // collection but flagged |unregistered|. |
161 if (!iter_new.second) { | 160 if (!iter_new.second) { |
162 dump_providers_.erase(iter_new.first); | 161 dump_providers_.erase(iter_new.first); |
163 dump_providers_.insert(mdp_info); | 162 dump_providers_.insert(mdp_info); |
164 } | 163 } |
(...skipping 311 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
476 next_dump_provider(next_dump_provider), | 475 next_dump_provider(next_dump_provider), |
477 callback(callback), | 476 callback(callback), |
478 task_runner(MessageLoop::current()->task_runner()) { | 477 task_runner(MessageLoop::current()->task_runner()) { |
479 } | 478 } |
480 | 479 |
481 MemoryDumpManager::ProcessMemoryDumpAsyncState::~ProcessMemoryDumpAsyncState() { | 480 MemoryDumpManager::ProcessMemoryDumpAsyncState::~ProcessMemoryDumpAsyncState() { |
482 } | 481 } |
483 | 482 |
484 } // namespace trace_event | 483 } // namespace trace_event |
485 } // namespace base | 484 } // namespace base |
OLD | NEW |