| 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/browser_child_process_host_impl.h" | 5 #include "content/browser/browser_child_process_host_impl.h" |
| 6 | 6 |
| 7 #include "base/base_switches.h" | 7 #include "base/base_switches.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 105 AddFilter(new HistogramMessageFilter); | 105 AddFilter(new HistogramMessageFilter); |
| 106 | 106 |
| 107 g_child_process_list.Get().push_back(this); | 107 g_child_process_list.Get().push_back(this); |
| 108 GetContentClient()->browser()->BrowserChildProcessHostCreated(this); | 108 GetContentClient()->browser()->BrowserChildProcessHostCreated(this); |
| 109 | 109 |
| 110 power_monitor_message_broadcaster_.Init(); | 110 power_monitor_message_broadcaster_.Init(); |
| 111 } | 111 } |
| 112 | 112 |
| 113 BrowserChildProcessHostImpl::~BrowserChildProcessHostImpl() { | 113 BrowserChildProcessHostImpl::~BrowserChildProcessHostImpl() { |
| 114 g_child_process_list.Get().remove(this); | 114 g_child_process_list.Get().remove(this); |
| 115 | |
| 116 #if defined(OS_WIN) | |
| 117 DeleteProcessWaitableEvent(early_exit_watcher_.GetWatchedEvent()); | |
| 118 #endif | |
| 119 } | 115 } |
| 120 | 116 |
| 121 // static | 117 // static |
| 122 void BrowserChildProcessHostImpl::TerminateAll() { | 118 void BrowserChildProcessHostImpl::TerminateAll() { |
| 123 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 119 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 124 // Make a copy since the BrowserChildProcessHost dtor mutates the original | 120 // Make a copy since the BrowserChildProcessHost dtor mutates the original |
| 125 // list. | 121 // list. |
| 126 BrowserChildProcessList copy = g_child_process_list.Get(); | 122 BrowserChildProcessList copy = g_child_process_list.Get(); |
| 127 for (BrowserChildProcessList::iterator it = copy.begin(); | 123 for (BrowserChildProcessList::iterator it = copy.begin(); |
| 128 it != copy.end(); ++it) { | 124 it != copy.end(); ++it) { |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 166 | 162 |
| 167 ChildProcessHost* BrowserChildProcessHostImpl::GetHost() const { | 163 ChildProcessHost* BrowserChildProcessHostImpl::GetHost() const { |
| 168 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 164 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 169 return child_process_host_.get(); | 165 return child_process_host_.get(); |
| 170 } | 166 } |
| 171 | 167 |
| 172 base::ProcessHandle BrowserChildProcessHostImpl::GetHandle() const { | 168 base::ProcessHandle BrowserChildProcessHostImpl::GetHandle() const { |
| 173 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 169 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 174 DCHECK(child_process_.get()) | 170 DCHECK(child_process_.get()) |
| 175 << "Requesting a child process handle before launching."; | 171 << "Requesting a child process handle before launching."; |
| 176 DCHECK(child_process_->GetHandle()) | 172 DCHECK(child_process_->GetProcess().IsValid()) |
| 177 << "Requesting a child process handle before launch has completed OK."; | 173 << "Requesting a child process handle before launch has completed OK."; |
| 178 return child_process_->GetHandle(); | 174 return child_process_->GetProcess().Handle(); |
| 179 } | 175 } |
| 180 | 176 |
| 181 void BrowserChildProcessHostImpl::SetName(const base::string16& name) { | 177 void BrowserChildProcessHostImpl::SetName(const base::string16& name) { |
| 182 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 178 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 183 data_.name = name; | 179 data_.name = name; |
| 184 } | 180 } |
| 185 | 181 |
| 186 void BrowserChildProcessHostImpl::SetHandle(base::ProcessHandle handle) { | 182 void BrowserChildProcessHostImpl::SetHandle(base::ProcessHandle handle) { |
| 187 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 183 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 188 data_.handle = handle; | 184 data_.handle = handle; |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 232 | 228 |
| 233 bool BrowserChildProcessHostImpl::OnMessageReceived( | 229 bool BrowserChildProcessHostImpl::OnMessageReceived( |
| 234 const IPC::Message& message) { | 230 const IPC::Message& message) { |
| 235 return delegate_->OnMessageReceived(message); | 231 return delegate_->OnMessageReceived(message); |
| 236 } | 232 } |
| 237 | 233 |
| 238 void BrowserChildProcessHostImpl::OnChannelConnected(int32 peer_pid) { | 234 void BrowserChildProcessHostImpl::OnChannelConnected(int32 peer_pid) { |
| 239 #if defined(OS_WIN) | 235 #if defined(OS_WIN) |
| 240 // From this point onward, the exit of the child process is detected by an | 236 // From this point onward, the exit of the child process is detected by an |
| 241 // error on the IPC channel. | 237 // error on the IPC channel. |
| 242 DeleteProcessWaitableEvent(early_exit_watcher_.GetWatchedEvent()); | |
| 243 early_exit_watcher_.StopWatching(); | 238 early_exit_watcher_.StopWatching(); |
| 244 #endif | 239 #endif |
| 245 | 240 |
| 246 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 241 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 247 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 242 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 248 base::Bind(&NotifyProcessHostConnected, data_)); | 243 base::Bind(&NotifyProcessHostConnected, data_)); |
| 249 | 244 |
| 250 delegate_->OnChannelConnected(peer_pid); | 245 delegate_->OnChannelConnected(peer_pid); |
| 251 } | 246 } |
| 252 | 247 |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 314 bool BrowserChildProcessHostImpl::Send(IPC::Message* message) { | 309 bool BrowserChildProcessHostImpl::Send(IPC::Message* message) { |
| 315 return child_process_host_->Send(message); | 310 return child_process_host_->Send(message); |
| 316 } | 311 } |
| 317 | 312 |
| 318 void BrowserChildProcessHostImpl::OnProcessLaunchFailed() { | 313 void BrowserChildProcessHostImpl::OnProcessLaunchFailed() { |
| 319 delegate_->OnProcessLaunchFailed(); | 314 delegate_->OnProcessLaunchFailed(); |
| 320 delete delegate_; // Will delete us | 315 delete delegate_; // Will delete us |
| 321 } | 316 } |
| 322 | 317 |
| 323 void BrowserChildProcessHostImpl::OnProcessLaunched() { | 318 void BrowserChildProcessHostImpl::OnProcessLaunched() { |
| 324 base::ProcessHandle handle = child_process_->GetHandle(); | 319 const base::ProcessObject& process = child_process_->GetProcess(); |
| 325 if (!handle) { | 320 DCHECK(process.IsValid()); |
| 326 delete delegate_; // Will delete us | |
| 327 return; | |
| 328 } | |
| 329 | 321 |
| 330 #if defined(OS_WIN) | 322 #if defined(OS_WIN) |
| 331 // Start a WaitableEventWatcher that will invoke OnProcessExitedEarly if the | 323 // Start a WaitableEventWatcher that will invoke OnProcessExitedEarly if the |
| 332 // child process exits. This watcher is stopped once the IPC channel is | 324 // child process exits. This watcher is stopped once the IPC channel is |
| 333 // connected and the exit of the child process is detecter by an error on the | 325 // connected and the exit of the child process is detecter by an error on the |
| 334 // IPC channel thereafter. | 326 // IPC channel thereafter. |
| 335 DCHECK(!early_exit_watcher_.GetWatchedEvent()); | 327 DCHECK(!early_exit_watcher_.GetWatchedObject()); |
| 336 early_exit_watcher_.StartWatching( | 328 early_exit_watcher_.StartWatching(process.Handle(), this); |
| 337 new base::WaitableEvent(handle), | |
| 338 base::Bind(&BrowserChildProcessHostImpl::OnProcessExitedEarly, | |
| 339 base::Unretained(this))); | |
| 340 #endif | 329 #endif |
| 341 | 330 |
| 342 data_.handle = handle; | 331 // TODO(rvargas) crbug.com/417532: Don't store a handle. |
| 332 data_.handle = process.Handle(); |
| 343 delegate_->OnProcessLaunched(); | 333 delegate_->OnProcessLaunched(); |
| 344 } | 334 } |
| 345 | 335 |
| 346 #if defined(OS_WIN) | 336 #if defined(OS_WIN) |
| 347 | 337 |
| 348 void BrowserChildProcessHostImpl::DeleteProcessWaitableEvent( | 338 void BrowserChildProcessHostImpl::OnObjectSignaled(HANDLE object) { |
| 349 base::WaitableEvent* event) { | |
| 350 if (!event) | |
| 351 return; | |
| 352 | |
| 353 // The WaitableEvent does not own the process handle so ensure it does not | |
| 354 // close it. | |
| 355 event->Release(); | |
| 356 | |
| 357 delete event; | |
| 358 } | |
| 359 | |
| 360 void BrowserChildProcessHostImpl::OnProcessExitedEarly( | |
| 361 base::WaitableEvent* event) { | |
| 362 DeleteProcessWaitableEvent(event); | |
| 363 OnChildDisconnected(); | 339 OnChildDisconnected(); |
| 364 } | 340 } |
| 365 | 341 |
| 366 #endif | 342 #endif |
| 367 | 343 |
| 368 } // namespace content | 344 } // namespace content |
| OLD | NEW |