render_process_host.h revision 5821806d5e7f356e8fa4b058a389a808ea183019
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#ifndef CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_H_
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#define CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_H_
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/basictypes.h"
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/id_map.h"
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/process.h"
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/process_util.h"
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/common/content_export.h"
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ipc/ipc_channel_proxy.h"
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ipc/ipc_sender.h"
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/gfx/native_widget_types.h"
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/surface/transport_dib.h"
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class GURL;
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)struct ViewMsg_SwapOut_Params;
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace content {
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class BrowserContext;
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class RenderWidgetHost;
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class StoragePartition;
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace base {
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class TimeDelta;
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace content {
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Interface that represents the browser side of the browser <-> renderer
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// communication channel. There will generally be one RenderProcessHost per
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// renderer process.
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class CONTENT_EXPORT RenderProcessHost : public IPC::Sender,
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                         public IPC::Listener {
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) public:
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  typedef IDMap<RenderProcessHost>::iterator iterator;
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  typedef IDMap<RenderWidgetHost>::const_iterator RenderWidgetHostsIterator;
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Details for RENDERER_PROCESS_CLOSED notifications.
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  struct RendererClosedDetails {
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    RendererClosedDetails(base::ProcessHandle handle,
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                          base::TerminationStatus status,
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                          int exit_code) {
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      this->handle = handle;
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      this->status = status;
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      this->exit_code = exit_code;
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    }
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    base::ProcessHandle handle;
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    base::TerminationStatus status;
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    int exit_code;
545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  };
555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual ~RenderProcessHost() {}
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Initialize the new renderer process, returning true on success. This must
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // be called once before the object can be used, but can be called after
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // that with no effect. Therefore, if the caller isn't sure about whether
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the process has been created, it should just call Init().
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool Init() = 0;
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Gets the next available routing id.
655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual int GetNextRoutingID() = 0;
665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Called on the UI thread to cancel any outstanding resource requests for
685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the specified render widget.
695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void CancelResourceRequests(int render_widget_id) = 0;
705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Called on the UI thread to simulate a SwapOut_ACK message to the
725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ResourceDispatcherHost.  Necessary for a cross-site request, in the case
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // that the original RenderViewHost is not live and thus cannot run an
745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // unload handler.
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void SimulateSwapOutACK(const ViewMsg_SwapOut_Params& params) = 0;
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Called to wait for the next UpdateRect message for the specified render
785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // widget.  Returns true if successful, and the msg out-param will contain a
795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // copy of the received UpdateRect message.
805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool WaitForBackingStoreMsg(int render_widget_id,
815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                      const base::TimeDelta& max_delay,
825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                      IPC::Message* msg) = 0;
835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Called when a received message cannot be decoded.
855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void ReceivedBadMessage() = 0;
865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Track the count of visible widgets. Called by listeners to register and
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // unregister visibility.
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void WidgetRestored() = 0;
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void WidgetHidden() = 0;
915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual int VisibleWidgetCount() const = 0;
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Indicates whether the current RenderProcessHost associated with a guest
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // renderer process.
955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool IsGuest() const = 0;
965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the storage partition associated with this process.
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  //
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // TODO(nasko): Remove this function from the public API once
1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // URLRequestContextGetter's creation is moved into StoragePartition.
1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // http://crbug.com/158595
1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual StoragePartition* GetStoragePartition() const = 0;
1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Try to shutdown the associated renderer process as fast as possible.
1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // If this renderer has any RenderViews with unload handlers, then this
1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // function does nothing.  The current implementation uses TerminateProcess.
1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns True if it was able to do fast shutdown.
1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool FastShutdownIfPossible() = 0;
1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns true if fast shutdown was started for the renderer.
1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool FastShutdownStarted() const = 0;
1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Dump the child process' handle table before shutting down.
1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void DumpHandles() = 0;
1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the process object associated with the child process.  In certain
1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // tests or single-process mode, this will actually represent the current
1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // process.
1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  //
1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // NOTE: this is not necessarily valid immediately after calling Init, as
1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Init starts the process asynchronously.  It's guaranteed to be valid after
1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the first IPC arrives.
1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual base::ProcessHandle GetHandle() = 0;
1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Transport DIB functions ---------------------------------------------------
1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Return the TransportDIB for the given id. On Linux, this can involve
1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // mapping shared memory. On Mac, the shared memory is created in the browser
1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // process and the cached metadata is returned. On Windows, this involves
1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // duplicating the handle from the remote process.  The RenderProcessHost
1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // still owns the returned DIB.
1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual TransportDIB* GetTransportDIB(TransportDIB::Id dib_id) = 0;
1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the user browser context associated with this renderer process.
1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual content::BrowserContext* GetBrowserContext() const = 0;
1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns whether this process is using the same StoragePartition as
1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // |partition|.
1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool InSameStoragePartition(StoragePartition* partition) const = 0;
1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the unique ID for this child process. This can be used later in
1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // a call to FromID() to get back to this object (this is used to avoid
1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // sending non-threadsafe pointers to other threads).
1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  //
1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // This ID will be unique for all child processes, including workers, plugins,
1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // etc.
1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual int GetID() const = 0;
1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the render widget host for the routing id passed in.
1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual RenderWidgetHost* GetRenderWidgetHostByID(int routing_id) = 0;
1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns true iff channel_ has been set to non-NULL. Use this for checking
1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // if there is connection or not. Virtual for mocking out for tests.
1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool HasConnection() const = 0;
1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Call this to allow queueing of IPC messages that are sent before the
1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // process is launched.
1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void EnableSendQueue() = 0;
1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the renderer channel.
1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual IPC::ChannelProxy* GetChannel() = 0;
1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the list of attached render widget hosts.
1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual RenderWidgetHostsIterator GetRenderWidgetHostsIterator() = 0;
1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Try to shutdown the associated render process as fast as possible
1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool FastShutdownForPageCount(size_t count) = 0;
1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // TODO(ananta)
1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Revisit whether the virtual functions declared from here on need to be
1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // part of the interface.
1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void SetIgnoreInputEvents(bool ignore_input_events) = 0;
1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool IgnoreInputEvents() const = 0;
1745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Used for refcounting, each holder of this object must Attach and Release
1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // just like it would for a COM object. This object should be allocated on
1775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the heap; when no listeners own it any more, it will delete itself.
1785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void Attach(content::RenderWidgetHost* host, int routing_id) = 0;
1795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // See Attach()
1815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void Release(int routing_id) = 0;
1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Schedules the host for deletion and removes it from the all_hosts list.
1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void Cleanup() = 0;
1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Track the count of pending views that are being swapped back in.  Called
1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // by listeners to register and unregister pending views to prevent the
1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // process from exiting.
1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void AddPendingView() = 0;
1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void RemovePendingView() = 0;
1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Sets a flag indicating that the process can be abnormally terminated.
1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void SetSuddenTerminationAllowed(bool allowed) = 0;
1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns true if the process can be abnormally terminated.
1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual bool SuddenTerminationAllowed() const = 0;
1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns how long the child has been idle. The definition of idle
1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // depends on when a derived class calls mark_child_process_activity_time().
1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // This is a rough indicator and its resolution should not be better than
2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // 10 milliseconds.
2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual base::TimeDelta GetChildProcessIdleTime() const = 0;
2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Signals that a compositing surface has been updated after a lost context
2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // event, so that we can process requests from the renderer to create contexts
2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // with that surface.
2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void SurfaceUpdated(int32 surface_id) = 0;
2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Called to resume the requests for a view created through window.open that
2095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // were initially blocked.
2105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void ResumeRequestsForView(int route_id) = 0;
2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Static management functions -----------------------------------------------
2135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Flag to run the renderer in process.  This is primarily
2155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // for debugging purposes.  When running "in process", the
2165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // browser maintains a single RenderProcessHost which communicates
2175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // to a RenderProcess which is instantiated in the same process
2185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // with the Browser.  All IPC between the Browser and the
2195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Renderer is the same, it's just not crossing a process boundary.
2205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static bool run_renderer_in_process();
2225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // This also calls out to ContentBrowserClient::GetApplicationLocale and
2245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // modifies the current process' command line.
2255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static void SetRunRendererInProcess(bool value);
2265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Allows iteration over all the RenderProcessHosts in the browser. Note
2285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // that each host may not be active, and therefore may have NULL channels.
2295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static iterator AllHostsIterator();
2305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the RenderProcessHost given its ID.  Returns NULL if the ID does
2325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // not correspond to a live RenderProcessHost.
2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static RenderProcessHost* FromID(int render_process_id);
2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns true if the caller should attempt to use an existing
2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // RenderProcessHost rather than creating a new one.
2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static bool ShouldTryToUseExistingProcessHost(
2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      content::BrowserContext* browser_context, const GURL& site_url);
2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Get an existing RenderProcessHost associated with the given browser
2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // context, if possible.  The renderer process is chosen randomly from
2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // suitable renderers that share the same context and type (determined by the
2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // site url).
2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns NULL if no suitable renderer process is available, in which case
2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the caller is free to create a new renderer.
2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static RenderProcessHost* GetExistingProcessHost(
2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      content::BrowserContext* browser_context, const GURL& site_url);
2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Overrides the default heuristic for limiting the max renderer process
2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // count.  This is useful for unit testing process limit behaviors.  It is
2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // also used to allow a command line parameter to configure the max number of
2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // renderer processes and should only be called once during startup.
2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // A value of zero means to use the default heuristic.
2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static void SetMaxRendererProcessCount(size_t count);
2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Returns the current max number of renderer processes used by the content
2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // module.
2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  static size_t GetMaxRendererProcessCount();
2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)};
2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace content.
2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif  // CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_H_
264