Index: content/browser/profiler_controller_impl.cc |
diff --git a/content/browser/profiler_controller_impl.cc b/content/browser/profiler_controller_impl.cc |
index 98fd2c068ac377ccde4b6025ab2758721c1fa738..7427d15f68684ff4d1d8397f1ae9497b6438f56e 100644 |
--- a/content/browser/profiler_controller_impl.cc |
+++ b/content/browser/profiler_controller_impl.cc |
@@ -72,7 +72,8 @@ void ProfilerControllerImpl::Unregister(const ProfilerSubscriber* subscriber) { |
} |
void ProfilerControllerImpl::GetProfilerDataFromChildProcesses( |
- int sequence_number) { |
+ int sequence_number, |
+ int current_profiling_phase) { |
DCHECK_CURRENTLY_ON(BrowserThread::IO); |
int pending_processes = 0; |
@@ -85,8 +86,10 @@ void ProfilerControllerImpl::GetProfilerDataFromChildProcesses( |
continue; |
++pending_processes; |
- if (!iter.Send(new ChildProcessMsg_GetChildProfilerData(sequence_number))) |
+ if (!iter.Send(new ChildProcessMsg_GetChildProfilerData( |
+ sequence_number, current_profiling_phase))) { |
--pending_processes; |
+ } |
} |
BrowserThread::PostTask( |
@@ -100,26 +103,66 @@ void ProfilerControllerImpl::GetProfilerDataFromChildProcesses( |
true)); |
} |
-void ProfilerControllerImpl::GetProfilerData(int sequence_number) { |
+// static |
+void ProfilerControllerImpl::NotifyChildProcessesOfProfilingPhaseCompletion( |
+ int profiling_phase) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ |
+ for (BrowserChildProcessHostIterator iter; !iter.Done(); ++iter) { |
+ // In some cases, there may be no child process of the given type (for |
+ // example, the GPU process may not exist and there may instead just be a |
+ // GPU thread in the browser process). If that's the case, then the process |
+ // handle will be base::kNullProcessHandle and we shouldn't send it a |
+ // message. |
+ if (iter.GetData().handle == base::kNullProcessHandle) |
+ continue; |
+ |
+ iter.Send(new ChildProcessMsg_ProfilingPhaseCompleted(profiling_phase)); |
+ } |
+} |
+ |
+void ProfilerControllerImpl::GetProfilerData(int sequence_number, |
+ int current_profiling_phase) { |
DCHECK_CURRENTLY_ON(BrowserThread::UI); |
+ // Iterates through renderers in UI thread, and through other child processes |
+ // in IO thread, and send them GetChildProfilerData message. Renderers have to |
+ // be contacted from UI thread, and other processes - from IO thread. |
int pending_processes = 0; |
for (RenderProcessHost::iterator it(RenderProcessHost::AllHostsIterator()); |
!it.IsAtEnd(); it.Advance()) { |
++pending_processes; |
- if (!it.GetCurrentValue()->Send( |
- new ChildProcessMsg_GetChildProfilerData(sequence_number))) { |
+ if (!it.GetCurrentValue()->Send(new ChildProcessMsg_GetChildProfilerData( |
+ sequence_number, current_profiling_phase))) { |
--pending_processes; |
} |
} |
OnPendingProcesses(sequence_number, pending_processes, false); |
BrowserThread::PostTask( |
- BrowserThread::IO, |
- FROM_HERE, |
+ BrowserThread::IO, FROM_HERE, |
base::Bind(&ProfilerControllerImpl::GetProfilerDataFromChildProcesses, |
- base::Unretained(this), |
- sequence_number)); |
+ base::Unretained(this), sequence_number, |
+ current_profiling_phase)); |
+} |
+ |
+void ProfilerControllerImpl::OnProfilingPhaseCompleted(int profiling_phase) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::UI); |
+ |
+ // Iterates through renderers in UI thread, and through other child processes |
+ // in IO thread, and send them OnProfilingPhase message. Renderers have to be |
+ // contacted from UI thread, and other processes - from IO thread. |
+ for (RenderProcessHost::iterator it(RenderProcessHost::AllHostsIterator()); |
+ !it.IsAtEnd(); it.Advance()) { |
+ it.GetCurrentValue()->Send( |
+ new ChildProcessMsg_ProfilingPhaseCompleted(profiling_phase)); |
+ } |
+ |
+ BrowserThread::PostTask( |
+ BrowserThread::IO, FROM_HERE, |
+ base::Bind(&ProfilerControllerImpl:: |
+ NotifyChildProcessesOfProfilingPhaseCompletion, |
+ profiling_phase)); |
} |
} // namespace content |