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
3 // found in the LICENSE file.
5 #ifndef CONTENT_BROWSER_BROWSER_CHILD_PROCESS_HOST_IMPL_H_
6 #define CONTENT_BROWSER_BROWSER_CHILD_PROCESS_HOST_IMPL_H_
10 #include "base/compiler_specific.h"
11 #include "base/memory/scoped_ptr.h"
12 #include "base/process/process.h"
13 #include "base/synchronization/waitable_event_watcher.h"
14 #include "content/browser/child_process_launcher.h"
15 #include "content/browser/power_monitor_message_broadcaster.h"
16 #include "content/public/browser/browser_child_process_host.h"
17 #include "content/public/browser/child_process_data.h"
18 #include "content/public/common/child_process_host_delegate.h"
26 class BrowserChildProcessHostIterator
;
27 class BrowserChildProcessObserver
;
28 class BrowserMessageFilter
;
30 // Plugins/workers and other child processes that live on the IO thread use this
31 // class. RenderProcessHostImpl is the main exception that doesn't use this
32 /// class because it lives on the UI thread.
33 class CONTENT_EXPORT BrowserChildProcessHostImpl
34 : public BrowserChildProcessHost
,
35 public NON_EXPORTED_BASE(ChildProcessHostDelegate
),
36 public ChildProcessLauncher::Client
{
38 BrowserChildProcessHostImpl(
40 BrowserChildProcessHostDelegate
* delegate
);
41 virtual ~BrowserChildProcessHostImpl();
43 // Terminates all child processes and deletes each BrowserChildProcessHost
45 static void TerminateAll();
47 // BrowserChildProcessHost implementation:
48 virtual bool Send(IPC::Message
* message
) OVERRIDE
;
50 SandboxedProcessLauncherDelegate
* delegate
,
51 base::CommandLine
* cmd_line
) OVERRIDE
;
52 virtual const ChildProcessData
& GetData() const OVERRIDE
;
53 virtual ChildProcessHost
* GetHost() const OVERRIDE
;
54 virtual base::TerminationStatus
GetTerminationStatus(
55 bool known_dead
, int* exit_code
) OVERRIDE
;
56 virtual void SetName(const base::string16
& name
) OVERRIDE
;
57 virtual void SetHandle(base::ProcessHandle handle
) OVERRIDE
;
59 // ChildProcessHostDelegate implementation:
60 virtual bool CanShutdown() OVERRIDE
;
61 virtual void OnChildDisconnected() OVERRIDE
;
62 virtual base::ProcessHandle
GetHandle() const OVERRIDE
;
63 virtual bool OnMessageReceived(const IPC::Message
& message
) OVERRIDE
;
64 virtual void OnChannelConnected(int32 peer_pid
) OVERRIDE
;
65 virtual void OnChannelError() OVERRIDE
;
66 virtual void OnBadMessageReceived(const IPC::Message
& message
) OVERRIDE
;
68 // Removes this host from the host list. Calls ChildProcessHost::ForceShutdown
71 // Callers can reduce the BrowserChildProcess' priority.
72 void SetBackgrounded(bool backgrounded
);
74 // Controls whether the child process should be terminated on browser
75 // shutdown. Default is to always terminate.
76 void SetTerminateChildOnShutdown(bool terminate_on_shutdown
);
78 // Adds an IPC message filter.
79 void AddFilter(BrowserMessageFilter
* filter
);
81 // Called when an instance of a particular child is created in a page.
82 static void NotifyProcessInstanceCreated(const ChildProcessData
& data
);
84 static void HistogramBadMessageTerminated(int process_type
);
86 BrowserChildProcessHostDelegate
* delegate() const { return delegate_
; }
88 typedef std::list
<BrowserChildProcessHostImpl
*> BrowserChildProcessList
;
90 friend class BrowserChildProcessHostIterator
;
91 friend class BrowserChildProcessObserver
;
93 static BrowserChildProcessList
* GetIterator();
95 static void AddObserver(BrowserChildProcessObserver
* observer
);
96 static void RemoveObserver(BrowserChildProcessObserver
* observer
);
98 // ChildProcessLauncher::Client implementation.
99 virtual void OnProcessLaunched() OVERRIDE
;
100 virtual void OnProcessLaunchFailed() OVERRIDE
;
103 void DeleteProcessWaitableEvent(base::WaitableEvent
* event
);
104 void OnProcessExitedEarly(base::WaitableEvent
* event
);
107 ChildProcessData data_
;
108 BrowserChildProcessHostDelegate
* delegate_
;
109 scoped_ptr
<ChildProcessHost
> child_process_host_
;
111 scoped_ptr
<ChildProcessLauncher
> child_process_
;
113 PowerMonitorMessageBroadcaster power_monitor_message_broadcaster_
;
116 // Watches to see if the child process exits before the IPC channel has
117 // been connected. Thereafter, its exit is determined by an error on the
119 base::WaitableEventWatcher early_exit_watcher_
;
123 } // namespace content
125 #endif // CONTENT_BROWSER_BROWSER_CHILD_PROCESS_HOST_IMPL_H_