OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "content/browser/profiler_controller_impl.h" | 5 #include "content/browser/profiler_controller_impl.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/values.h" | 8 #include "base/tracked_objects.h" |
9 #include "content/common/child_process_messages.h" | 9 #include "content/common/child_process_messages.h" |
10 #include "content/public/browser/browser_child_process_host_iterator.h" | 10 #include "content/public/browser/browser_child_process_host_iterator.h" |
11 #include "content/public/browser/browser_thread.h" | 11 #include "content/public/browser/browser_thread.h" |
12 #include "content/public/browser/child_process_data.h" | 12 #include "content/public/browser/child_process_data.h" |
13 #include "content/public/browser/profiler_subscriber.h" | 13 #include "content/public/browser/profiler_subscriber.h" |
14 #include "content/public/browser/render_process_host.h" | 14 #include "content/public/browser/render_process_host.h" |
15 #include "content/public/common/process_type.h" | 15 #include "content/public/common/serialized_profiler_data.h" |
16 | 16 |
17 using content::BrowserChildProcessHostIterator; | 17 using content::BrowserChildProcessHostIterator; |
18 using content::BrowserThread; | 18 using content::BrowserThread; |
19 | 19 |
20 namespace content { | 20 namespace content { |
21 | 21 |
22 content::ProfilerController* content::ProfilerController::GetInstance() { | 22 content::ProfilerController* content::ProfilerController::GetInstance() { |
23 return ProfilerControllerImpl::GetInstance(); | 23 return ProfilerControllerImpl::GetInstance(); |
24 } | 24 } |
25 | 25 |
(...skipping 10 matching lines...) Expand all Loading... |
36 void ProfilerControllerImpl::OnPendingProcesses(int sequence_number, | 36 void ProfilerControllerImpl::OnPendingProcesses(int sequence_number, |
37 int pending_processes, | 37 int pending_processes, |
38 bool end) { | 38 bool end) { |
39 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 39 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
40 if (subscriber_) | 40 if (subscriber_) |
41 subscriber_->OnPendingProcesses(sequence_number, pending_processes, end); | 41 subscriber_->OnPendingProcesses(sequence_number, pending_processes, end); |
42 } | 42 } |
43 | 43 |
44 void ProfilerControllerImpl::OnProfilerDataCollected( | 44 void ProfilerControllerImpl::OnProfilerDataCollected( |
45 int sequence_number, | 45 int sequence_number, |
46 base::DictionaryValue* profiler_data) { | 46 const SerializedProfilerData& profiler_data) { |
47 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { | 47 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
48 BrowserThread::PostTask( | 48 BrowserThread::PostTask( |
49 BrowserThread::UI, FROM_HERE, | 49 BrowserThread::UI, FROM_HERE, |
50 base::Bind(&ProfilerControllerImpl::OnProfilerDataCollected, | 50 base::Bind(&ProfilerControllerImpl::OnProfilerDataCollected, |
51 base::Unretained(this), | 51 base::Unretained(this), |
52 sequence_number, | 52 sequence_number, |
53 profiler_data)); | 53 profiler_data)); |
54 return; | 54 return; |
55 } | 55 } |
56 | 56 |
57 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 57 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
58 if (subscriber_) | 58 if (subscriber_) |
59 subscriber_->OnProfilerDataCollected(sequence_number, profiler_data); | 59 subscriber_->OnProfilerDataCollected(sequence_number, profiler_data); |
60 } | 60 } |
61 | 61 |
62 void ProfilerControllerImpl::Register(ProfilerSubscriber* subscriber) { | 62 void ProfilerControllerImpl::Register(ProfilerSubscriber* subscriber) { |
63 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 63 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
64 DCHECK(!subscriber_); | 64 DCHECK(!subscriber_); |
65 subscriber_ = subscriber; | 65 subscriber_ = subscriber; |
66 } | 66 } |
67 | 67 |
68 void ProfilerControllerImpl::Unregister(ProfilerSubscriber* subscriber) { | 68 void ProfilerControllerImpl::Unregister(const ProfilerSubscriber* subscriber) { |
69 if (subscriber == subscriber_) | 69 DCHECK_EQ(subscriber_, subscriber); |
70 subscriber_ = NULL; | 70 subscriber_ = NULL; |
71 } | 71 } |
72 | 72 |
73 void ProfilerControllerImpl::GetProfilerDataFromChildProcesses( | 73 void ProfilerControllerImpl::GetProfilerDataFromChildProcesses( |
74 int sequence_number) { | 74 int sequence_number) { |
75 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 75 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
76 | 76 |
77 int pending_processes = 0; | 77 int pending_processes = 0; |
78 for (BrowserChildProcessHostIterator iter; !iter.Done(); ++iter) { | 78 for (BrowserChildProcessHostIterator iter; !iter.Done(); ++iter) { |
79 const std::string process_type = | |
80 content::GetProcessTypeNameInEnglish(iter.GetData().type); | |
81 ++pending_processes; | 79 ++pending_processes; |
82 if (!iter.Send(new ChildProcessMsg_GetChildProfilerData( | 80 if (!iter.Send(new ChildProcessMsg_GetChildProfilerData( |
83 sequence_number, process_type))) { | 81 sequence_number, iter.GetData().type))) { |
84 --pending_processes; | 82 --pending_processes; |
85 } | 83 } |
86 } | 84 } |
87 | 85 |
88 BrowserThread::PostTask( | 86 BrowserThread::PostTask( |
89 BrowserThread::UI, | 87 BrowserThread::UI, |
90 FROM_HERE, | 88 FROM_HERE, |
91 base::Bind( | 89 base::Bind( |
92 &ProfilerControllerImpl::OnPendingProcesses, | 90 &ProfilerControllerImpl::OnPendingProcesses, |
93 base::Unretained(this), | 91 base::Unretained(this), |
94 sequence_number, | 92 sequence_number, |
95 pending_processes, | 93 pending_processes, |
96 true)); | 94 true)); |
97 } | 95 } |
98 | 96 |
99 void ProfilerControllerImpl::GetProfilerData(int sequence_number) { | 97 void ProfilerControllerImpl::GetProfilerData(int sequence_number) { |
100 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 98 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
101 | 99 |
102 int pending_processes = 0; | 100 int pending_processes = 0; |
103 const std::string render_process_type = | |
104 content::GetProcessTypeNameInEnglish(content::PROCESS_TYPE_RENDERER); | |
105 | |
106 for (RenderProcessHost::iterator it(RenderProcessHost::AllHostsIterator()); | 101 for (RenderProcessHost::iterator it(RenderProcessHost::AllHostsIterator()); |
107 !it.IsAtEnd(); it.Advance()) { | 102 !it.IsAtEnd(); it.Advance()) { |
108 ++pending_processes; | 103 ++pending_processes; |
109 if (!it.GetCurrentValue()->Send(new ChildProcessMsg_GetChildProfilerData( | 104 if (!it.GetCurrentValue()->Send(new ChildProcessMsg_GetChildProfilerData( |
110 sequence_number, render_process_type))) { | 105 sequence_number, content::PROCESS_TYPE_RENDERER))) { |
111 --pending_processes; | 106 --pending_processes; |
112 } | 107 } |
113 } | 108 } |
114 OnPendingProcesses(sequence_number, pending_processes, false); | 109 OnPendingProcesses(sequence_number, pending_processes, false); |
115 | 110 |
116 BrowserThread::PostTask( | 111 BrowserThread::PostTask( |
117 BrowserThread::IO, | 112 BrowserThread::IO, |
118 FROM_HERE, | 113 FROM_HERE, |
119 base::Bind(&ProfilerControllerImpl::GetProfilerDataFromChildProcesses, | 114 base::Bind(&ProfilerControllerImpl::GetProfilerDataFromChildProcesses, |
120 base::Unretained(this), | 115 base::Unretained(this), |
121 sequence_number)); | 116 sequence_number)); |
122 } | 117 } |
123 | 118 |
124 void ProfilerControllerImpl::SetProfilerStatusInChildProcesses( | |
125 tracked_objects::ThreadData::Status status) { | |
126 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | |
127 | |
128 for (BrowserChildProcessHostIterator iter; !iter.Done(); ++iter) | |
129 iter.Send(new ChildProcessMsg_SetProfilerStatus(status)); | |
130 } | |
131 | |
132 void ProfilerControllerImpl::SetProfilerStatus( | |
133 tracked_objects::ThreadData::Status status) { | |
134 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
135 | |
136 BrowserThread::PostTask( | |
137 BrowserThread::IO, | |
138 FROM_HERE, | |
139 base::Bind(&ProfilerControllerImpl::SetProfilerStatusInChildProcesses, | |
140 base::Unretained(this), | |
141 status)); | |
142 | |
143 for (content::RenderProcessHost::iterator it( | |
144 content::RenderProcessHost::AllHostsIterator()); | |
145 !it.IsAtEnd(); it.Advance()) { | |
146 it.GetCurrentValue()->Send(new ChildProcessMsg_SetProfilerStatus(status)); | |
147 } | |
148 } | |
149 } // namespace content | 119 } // namespace content |
OLD | NEW |