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 247 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
258 } | 258 } |
259 base::KillProcess(GetHandle(), RESULT_CODE_KILLED_BAD_MESSAGE, false); | 259 base::KillProcess(GetHandle(), RESULT_CODE_KILLED_BAD_MESSAGE, false); |
260 } | 260 } |
261 | 261 |
262 bool BrowserChildProcessHostImpl::CanShutdown() { | 262 bool BrowserChildProcessHostImpl::CanShutdown() { |
263 return delegate_->CanShutdown(); | 263 return delegate_->CanShutdown(); |
264 } | 264 } |
265 | 265 |
266 void BrowserChildProcessHostImpl::OnChildDisconnected() { | 266 void BrowserChildProcessHostImpl::OnChildDisconnected() { |
267 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 267 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 268 #if defined(OS_WIN) |
| 269 // OnChildDisconnected may be called without OnChannelConnected, so stop the |
| 270 // early exit watcher so GetTerminationStatus can close the process handle. |
| 271 early_exit_watcher_.StopWatching(); |
| 272 #endif |
268 if (child_process_.get() || data_.handle) { | 273 if (child_process_.get() || data_.handle) { |
269 DCHECK(data_.handle != base::kNullProcessHandle); | 274 DCHECK(data_.handle != base::kNullProcessHandle); |
270 int exit_code; | 275 int exit_code; |
271 base::TerminationStatus status = GetTerminationStatus( | 276 base::TerminationStatus status = GetTerminationStatus( |
272 true /* known_dead */, &exit_code); | 277 true /* known_dead */, &exit_code); |
273 switch (status) { | 278 switch (status) { |
274 case base::TERMINATION_STATUS_PROCESS_CRASHED: | 279 case base::TERMINATION_STATUS_PROCESS_CRASHED: |
275 case base::TERMINATION_STATUS_ABNORMAL_TERMINATION: { | 280 case base::TERMINATION_STATUS_ABNORMAL_TERMINATION: { |
276 delegate_->OnProcessCrashed(exit_code); | 281 delegate_->OnProcessCrashed(exit_code); |
277 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, | 282 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
335 | 340 |
336 #if defined(OS_WIN) | 341 #if defined(OS_WIN) |
337 | 342 |
338 void BrowserChildProcessHostImpl::OnObjectSignaled(HANDLE object) { | 343 void BrowserChildProcessHostImpl::OnObjectSignaled(HANDLE object) { |
339 OnChildDisconnected(); | 344 OnChildDisconnected(); |
340 } | 345 } |
341 | 346 |
342 #endif | 347 #endif |
343 | 348 |
344 } // namespace content | 349 } // namespace content |
OLD | NEW |