blob: 9fbb1ed08fe685dcc60e4f647d54aca97b101283 [file] [log] [blame]
[email protected]f85f0702010-01-30 09:31:011// Copyright (c) 2010 The Chromium Authors. All rights reserved.
license.botbf09a502008-08-24 00:55:552// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit09911bf2008-07-26 23:55:294
[email protected]1d97d2e2008-12-18 23:39:025#ifndef CHROME_RENDERER_RENDER_THREAD_H_
6#define CHROME_RENDERER_RENDER_THREAD_H_
initial.commit09911bf2008-07-26 23:55:297
[email protected]c8865962009-12-16 07:47:398#include <set>
[email protected]b68d5ed2009-04-16 02:41:289#include <string>
[email protected]1bc83062009-02-06 00:16:3710#include <vector>
11
initial.commit09911bf2008-07-26 23:55:2912#include "base/shared_memory.h"
[email protected]85c55dc2009-11-06 03:05:4613#include "base/string16.h"
initial.commit09911bf2008-07-26 23:55:2914#include "base/task.h"
[email protected]71d6d852009-12-07 22:12:3615#include "base/time.h"
16#include "base/timer.h"
[email protected]037fce02009-01-22 01:42:1517#include "build/build_config.h"
[email protected]8930d472009-02-21 08:05:2818#include "chrome/common/child_thread.h"
[email protected]b9ab10c2009-08-07 18:09:5519#include "chrome/common/css_colors.h"
[email protected]3e90d4a2009-07-03 17:38:3920#include "chrome/renderer/visitedlink_slave.h"
[email protected]5c7293a2010-03-17 06:40:5721#include "gfx/native_widget_types.h"
[email protected]6217d392010-03-25 22:08:3522#include "ipc/ipc_channel_handle.h"
[email protected]cb6037d2009-11-16 22:55:1723#include "ipc/ipc_platform_file.h"
initial.commit09911bf2008-07-26 23:55:2924
[email protected]1edc16b82009-04-07 17:45:5425class AppCacheDispatcher;
[email protected]dd9241932010-02-24 19:23:1326class CookieMessageFilter;
[email protected]017022b2009-07-27 23:06:3427class DBMessageFilter;
[email protected]a8624712009-04-17 00:51:3528class DevToolsAgentFilter;
[email protected]39008c02009-02-11 23:59:2529class FilePath;
[email protected]e13ad79b2010-07-22 21:36:5030class GpuChannelHost;
[email protected]70c19a932010-05-14 12:59:1131class IndexedDBDispatcher;
[email protected]dfcb62a2009-06-17 19:32:4332class ListValue;
[email protected]b7c7bcf2009-10-03 07:07:3433class NullableString16;
[email protected]55e57d42009-02-25 06:10:1734class RendererHistogram;
[email protected]e13ad79b2010-07-22 21:36:5035class RendererHistogramSnapshots;
[email protected]74be069e82010-06-25 00:12:4936class RendererNetPredictor;
[email protected]8d86fce2009-02-26 23:37:5537class RendererWebKitClientImpl;
[email protected]85c55dc2009-11-06 03:05:4638class SpellCheck;
[email protected]39008c02009-02-11 23:59:2539class SkBitmap;
[email protected]4d395d092009-02-11 21:40:4040class UserScriptSlave;
[email protected]cccf90932009-08-23 17:56:2541class URLPattern;
[email protected]2b437e232010-04-02 01:30:0842class WebDatabaseObserverImpl;
[email protected]cccf90932009-08-23 17:56:2543
[email protected]f85f0702010-01-30 09:31:0144struct ContentSettings;
[email protected]9b6f40e2009-06-11 15:54:2645struct RendererPreferences;
[email protected]c61cc652009-11-04 05:44:4046struct ViewMsg_DOMStorageEvent_Params;
[email protected]942690b132010-05-11 06:42:1447struct ViewMsg_ExtensionExtentsUpdated_Params;
[email protected]4e6419c2010-01-15 04:50:3448struct ViewMsg_New_Params;
[email protected]39008c02009-02-11 23:59:2549struct WebPreferences;
initial.commit09911bf2008-07-26 23:55:2950
[email protected]b7c7bcf2009-10-03 07:07:3451namespace WebKit {
52class WebStorageEventDispatcher;
53}
54
[email protected]81a34412009-01-05 19:17:2455// The RenderThreadBase is the minimal interface that a RenderView/Widget
56// expects from a render thread. The interface basically abstracts a way to send
57// and receive messages.
[email protected]00c39612010-03-06 02:53:2858//
[email protected]f3ede412010-06-21 22:52:1659// TODO(brettw): This has two different and opposing usage patterns which
60// make it confusing.
61//
62// In the first mode, callers call RenderThread::current() to get the one and
63// only global RenderThread (bug 10837: this should be renamed get()). Then
64// they access it. Since RenderThread is a concrete class, this can be NULL
65// during unit tests. Callers need to NULL check this every time. Some callers
66// don't happen to get called during unit tests and don't do the NULL checks,
67// which is also confusing since it's not clear if you need to or not.
68//
69// In the second mode, the abstract base class RenderThreadBase is passed to
70// RenderView and RenderWidget. Normally, this points to
71// RenderThread::current() so it's quite confusing which accessing mode should
72// be used. However, during unit testing, this class is replaced with a mock
73// to support testing functions, and is guaranteed non-NULL.
74//
75// It might be nice not to have the ::current() call and put all of the
76// functions on the abstract class so they can be mocked. However, there are
77// some standalone functions like in ChromiumBridge that are not associated
78// with a view that need to access the current thread to send messages to the
79// browser process. These need the ::current() paradigm. So instead, we should
80// probably remove the render_thread_ parameter to RenderView/Widget in
81// preference to just getting the global singleton. We can make it easier to
82// understand by moving everything to the abstract interface and saying that
83// there should never be a NULL RenderThread::current(). Tests would be
84// responsible for setting up the mock one.
[email protected]8930d472009-02-21 08:05:2885class RenderThreadBase {
[email protected]8085dbc82008-09-26 22:53:4486 public:
87 virtual ~RenderThreadBase() {}
88
[email protected]8930d472009-02-21 08:05:2889 virtual bool Send(IPC::Message* msg) = 0;
90
[email protected]8085dbc82008-09-26 22:53:4491 // Called to add or remove a listener for a particular message routing ID.
92 // These methods normally get delegated to a MessageRouter.
93 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener) = 0;
94 virtual void RemoveRoute(int32 routing_id) = 0;
[email protected]81a34412009-01-05 19:17:2495
96 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
97 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
[email protected]bee16aab2009-08-26 15:55:0398
99 // Called by a RenderWidget when it is hidden or restored.
100 virtual void WidgetHidden() = 0;
101 virtual void WidgetRestored() = 0;
[email protected]b8f41a192010-04-19 18:25:04102
103 // True if this process should be treated as an extension process.
104 virtual bool IsExtensionProcess() const = 0;
[email protected]8085dbc82008-09-26 22:53:44105};
106
initial.commit09911bf2008-07-26 23:55:29107// The RenderThread class represents a background thread where RenderView
108// instances live. The RenderThread supports an API that is used by its
109// consumer to talk indirectly to the RenderViews and supporting objects.
110// Likewise, it provides an API for the RenderViews to talk back to the main
[email protected]57c6a652009-05-04 07:58:34111// process (i.e., their corresponding TabContents).
initial.commit09911bf2008-07-26 23:55:29112//
113// Most of the communication occurs in the form of IPC messages. They are
114// routed to the RenderThread according to the routing IDs of the messages.
115// The routing IDs correspond to RenderView instances.
[email protected]8930d472009-02-21 08:05:28116class RenderThread : public RenderThreadBase,
117 public ChildThread {
initial.commit09911bf2008-07-26 23:55:29118 public:
[email protected]8930d472009-02-21 08:05:28119 // Grabs the IPC channel name from the command line.
120 RenderThread();
121 // Constructor that's used when running in single process mode.
[email protected]11f4857282009-11-13 19:56:17122 explicit RenderThread(const std::string& channel_name);
[email protected]8085dbc82008-09-26 22:53:44123 virtual ~RenderThread();
initial.commit09911bf2008-07-26 23:55:29124
[email protected]8930d472009-02-21 08:05:28125 // Returns the one render thread for this process. Note that this should only
126 // be accessed when running on the render thread itself
[email protected]00c39612010-03-06 02:53:28127 //
128 // TODO(brettw) this should be on the abstract base class instead of here,
129 // and return the base class' interface instead. Currently this causes
130 // problems with testing. See the comment above RenderThreadBase above.
[email protected]8930d472009-02-21 08:05:28131 static RenderThread* current();
initial.commit09911bf2008-07-26 23:55:29132
[email protected]c1f50aa2010-02-18 03:46:57133 // Returns the routing ID of the RenderWidget containing the current script
134 // execution context (corresponding to WebFrame::frameForCurrentContext).
135 static int32 RoutingIDForCurrentContext();
136
[email protected]45776222009-07-15 20:21:58137 // Overridden from RenderThreadBase.
[email protected]c1f50aa2010-02-18 03:46:57138 virtual bool Send(IPC::Message* msg);
139 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener);
140 virtual void RemoveRoute(int32 routing_id);
[email protected]81a34412009-01-05 19:17:24141 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter);
142 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter);
[email protected]bee16aab2009-08-26 15:55:03143 virtual void WidgetHidden();
144 virtual void WidgetRestored();
145
[email protected]c1f50aa2010-02-18 03:46:57146 // These methods modify how the next message is sent. Normally, when sending
147 // a synchronous message that runs a nested message loop, we need to suspend
148 // callbacks into WebKit. This involves disabling timers and deferring
149 // resource loads. However, there are exceptions when we need to customize
150 // the behavior.
151 void DoNotSuspendWebKitSharedTimer();
152 void DoNotNotifyWebKitOfModalLoop();
153
[email protected]8d86fce2009-02-26 23:37:55154 VisitedLinkSlave* visited_link_slave() const {
155 return visited_link_slave_.get();
156 }
initial.commit09911bf2008-07-26 23:55:29157
[email protected]8d86fce2009-02-26 23:37:55158 UserScriptSlave* user_script_slave() const {
159 return user_script_slave_.get();
160 }
[email protected]1e0f70402008-10-16 23:57:47161
[email protected]f430b5712009-08-21 21:46:31162 AppCacheDispatcher* appcache_dispatcher() const {
163 return appcache_dispatcher_.get();
164 }
165
[email protected]70c19a932010-05-14 12:59:11166 IndexedDBDispatcher* indexed_db_dispatcher() const {
167 return indexed_db_dispatcher_.get();
168 }
169
[email protected]85c55dc2009-11-06 03:05:46170 SpellCheck* spellchecker() const {
171 return spellchecker_.get();
172 }
[email protected]85c55dc2009-11-06 03:05:46173
[email protected]b547fd42009-04-23 23:16:27174 bool plugin_refresh_allowed() const { return plugin_refresh_allowed_; }
175
[email protected]b8f41a192010-04-19 18:25:04176 virtual bool IsExtensionProcess() const { return is_extension_process_; }
[email protected]71d6d852009-12-07 22:12:36177
[email protected]b2a74ca2010-03-12 17:57:09178 bool is_incognito_process() const { return is_incognito_process_; }
179
initial.commit09911bf2008-07-26 23:55:29180 // Do DNS prefetch resolution of a hostname.
181 void Resolve(const char* name, size_t length);
182
[email protected]55e57d42009-02-25 06:10:17183 // Send all the Histogram data to browser.
[email protected]c9a3ef82009-05-28 22:02:46184 void SendHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17185
initial.commit09911bf2008-07-26 23:55:29186 // Invokes InformHostOfCacheStats after a short delay. Used to move this
187 // bookkeeping operation off the critical latency path.
188 void InformHostOfCacheStatsLater();
189
[email protected]c40acc32010-01-14 01:02:53190 // Sends a message to the browser to close all connections.
191 void CloseCurrentConnections();
[email protected]b07f29092009-06-05 07:33:21192
193 // Sends a message to the browser to enable or disable the disk cache.
194 void SetCacheMode(bool enabled);
195
[email protected]c5d79342010-06-05 01:27:34196 // Sends a message to the browser to clear the disk cache.
197 void ClearCache();
198
[email protected]c8865962009-12-16 07:47:39199 // Update the list of active extensions that will be reported when we crash.
200 void UpdateActiveExtensions();
201
[email protected]6217d392010-03-25 22:08:35202 // Asynchronously establish a channel to the GPU plugin if not previously
203 // established or if it has been lost (for example if the GPU plugin crashed).
204 // Use GetGpuChannel() to determine when the channel is ready for use.
205 void EstablishGpuChannel();
206
[email protected]3bf4d532010-03-27 00:23:34207 // Synchronously establish a channel to the GPU plugin if not previously
208 // established or if it has been lost (for example if the GPU plugin crashed).
209 // If there is a pending asynchronous request, it will be completed by the
210 // time this routine returns.
211 GpuChannelHost* EstablishGpuChannelSync();
212
[email protected]6217d392010-03-25 22:08:35213 // Get the GPU channel. Returns NULL if the channel is not established or
214 // has been lost.
215 GpuChannelHost* GetGpuChannel();
216
[email protected]3a8eecb2010-04-22 23:56:30217 // Returns the extension ID that the given URL is a part of, or empty if
218 // none. This includes web URLs that are part of an extension's web extent.
219 // TODO(mpcomplete): this doesn't feel like it belongs here. Find a better
220 // place.
[email protected]4fdbc1492010-07-01 01:20:59221 std::string GetExtensionIdByURL(const GURL& url);
222
223 std::string GetExtensionIdByBrowseExtent(const GURL& url);
[email protected]3a8eecb2010-04-22 23:56:30224
[email protected]8930d472009-02-21 08:05:28225 private:
226 virtual void OnControlMessageReceived(const IPC::Message& msg);
initial.commit09911bf2008-07-26 23:55:29227
[email protected]42f1d7822009-07-23 18:17:55228 void Init();
initial.commit09911bf2008-07-26 23:55:29229
[email protected]176aa482008-11-14 03:25:15230 void OnUpdateVisitedLinks(base::SharedMemoryHandle table);
[email protected]3e90d4a2009-07-03 17:38:39231 void OnAddVisitedLinks(const VisitedLinkSlave::Fingerprints& fingerprints);
232 void OnResetVisitedLinks();
[email protected]9d797f32010-04-23 07:17:54233 void OnSetZoomLevelForCurrentURL(const GURL& url, int zoom_level);
[email protected]0314ae02010-04-08 09:18:29234 void OnSetContentSettingsForCurrentURL(
235 const GURL& url, const ContentSettings& content_settings);
[email protected]b2a74ca2010-03-12 17:57:09236 void OnUpdateUserScripts(base::SharedMemoryHandle table);
[email protected]703e807a2009-03-28 19:56:51237 void OnSetExtensionFunctionNames(const std::vector<std::string>& names);
[email protected]3a8eecb2010-04-22 23:56:30238 void OnExtensionExtentsUpdated(
239 const ViewMsg_ExtensionExtentsUpdated_Params& params);
[email protected]45776222009-07-15 20:21:58240 void OnPageActionsUpdated(const std::string& extension_id,
[email protected]b7c7bcf2009-10-03 07:07:34241 const std::vector<std::string>& page_actions);
[email protected]c61cc652009-11-04 05:44:40242 void OnDOMStorageEvent(const ViewMsg_DOMStorageEvent_Params& params);
[email protected]75e126b932009-09-28 19:38:49243 void OnExtensionSetAPIPermissions(
244 const std::string& extension_id,
245 const std::vector<std::string>& permissions);
246 void OnExtensionSetHostPermissions(
247 const GURL& extension_url,
248 const std::vector<URLPattern>& permissions);
[email protected]db7331a2010-02-25 22:10:50249 void OnExtensionSetIncognitoEnabled(
250 const std::string& extension_id,
251 bool enabled);
initial.commit09911bf2008-07-26 23:55:29252 void OnSetNextPageID(int32 next_page_id);
[email protected]b2a74ca2010-03-12 17:57:09253 void OnSetIsIncognitoProcess(bool is_incognito_process);
[email protected]b9ab10c2009-08-07 18:09:55254 void OnSetCSSColors(const std::vector<CSSColors::CSSColorMapping>& colors);
[email protected]4e6419c2010-01-15 04:50:34255 void OnCreateNewView(const ViewMsg_New_Params& params);
initial.commit09911bf2008-07-26 23:55:29256 void OnTransferBitmap(const SkBitmap& bitmap, int resource_id);
257 void OnSetCacheCapacities(size_t min_dead_capacity,
258 size_t max_dead_capacity,
259 size_t capacity);
260 void OnGetCacheResourceStats();
261
[email protected]55e57d42009-02-25 06:10:17262 // Send all histograms to browser.
[email protected]c9a3ef82009-05-28 22:02:46263 void OnGetRendererHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17264
[email protected]d41041092009-10-08 06:56:57265 // Send tcmalloc info to browser.
266 void OnGetRendererTcmalloc();
[email protected]38b48a82009-11-11 01:51:32267 void OnGetV8HeapStats();
[email protected]d41041092009-10-08 06:56:57268
[email protected]dfcb62a2009-06-17 19:32:43269 void OnExtensionMessageInvoke(const std::string& function_name,
[email protected]d7259472010-03-24 08:40:49270 const ListValue& args,
[email protected]a807bbe2010-04-14 10:51:19271 bool requires_incognito_access,
272 const GURL& event_url);
[email protected]fede6ca12009-10-08 18:24:26273 void OnPurgeMemory();
[email protected]b78e168b2009-09-21 22:05:45274 void OnPurgePluginListCache(bool reload_pages);
[email protected]75e5a872009-04-02 23:56:11275
[email protected]cb6037d2009-11-16 22:55:17276 void OnInitSpellChecker(IPC::PlatformFileForTransit bdict_file,
[email protected]85c55dc2009-11-06 03:05:46277 const std::vector<std::string>& custom_words,
278 const std::string& language,
279 bool auto_spell_correct);
280 void OnSpellCheckWordAdded(const std::string& word);
281 void OnSpellCheckEnableAutoSpellCorrect(bool enable);
[email protected]85c55dc2009-11-06 03:05:46282
[email protected]6217d392010-03-25 22:08:35283 void OnGpuChannelEstablished(const IPC::ChannelHandle& channel_handle);
284
[email protected]b3df5a42010-05-11 14:31:09285 void OnGetAccessibilityTree();
286
initial.commit09911bf2008-07-26 23:55:29287 // Gather usage statistics from the in-memory cache and inform our host.
288 // These functions should be call periodically so that the host can make
289 // decisions about how to allocation resources using current information.
290 void InformHostOfCacheStats();
291
[email protected]90a3fbb12009-02-28 01:13:47292 // We initialize WebKit as late as possible.
293 void EnsureWebKitInitialized();
294
[email protected]bee16aab2009-08-26 15:55:03295 // A task we invoke periodically to assist with idle cleanup.
296 void IdleHandler();
297
[email protected]71d6d852009-12-07 22:12:36298 // Schedule a call to IdleHandler with the given initial delay.
299 void ScheduleIdleHandler(double initial_delay_s);
300
initial.commit09911bf2008-07-26 23:55:29301 // These objects live solely on the render thread.
[email protected]bee16aab2009-08-26 15:55:03302 scoped_ptr<ScopedRunnableMethodFactory<RenderThread> > task_factory_;
[email protected]42f1d7822009-07-23 18:17:55303 scoped_ptr<VisitedLinkSlave> visited_link_slave_;
304 scoped_ptr<UserScriptSlave> user_script_slave_;
[email protected]74be069e82010-06-25 00:12:49305 scoped_ptr<RendererNetPredictor> renderer_net_predictor_;
[email protected]f430b5712009-08-21 21:46:31306 scoped_ptr<AppCacheDispatcher> appcache_dispatcher_;
[email protected]70c19a932010-05-14 12:59:11307 scoped_ptr<IndexedDBDispatcher> indexed_db_dispatcher_;
[email protected]9291ed12009-07-23 17:33:22308 scoped_refptr<DevToolsAgentFilter> devtools_agent_filter_;
[email protected]42f1d7822009-07-23 18:17:55309 scoped_ptr<RendererHistogramSnapshots> histogram_snapshots_;
310 scoped_ptr<RendererWebKitClientImpl> webkit_client_;
[email protected]b7c7bcf2009-10-03 07:07:34311 scoped_ptr<WebKit::WebStorageEventDispatcher> dom_storage_event_dispatcher_;
[email protected]2b437e232010-04-02 01:30:08312 scoped_ptr<WebDatabaseObserverImpl> web_database_observer_impl_;
[email protected]85c55dc2009-11-06 03:05:46313 scoped_ptr<SpellCheck> spellchecker_;
[email protected]9291ed12009-07-23 17:33:22314
[email protected]e2b2d4a2009-10-24 03:32:59315 // Used on the renderer and IPC threads.
[email protected]017022b2009-07-27 23:06:34316 scoped_refptr<DBMessageFilter> db_message_filter_;
[email protected]dd9241932010-02-24 19:23:13317 scoped_refptr<CookieMessageFilter> cookie_message_filter_;
[email protected]017022b2009-07-27 23:06:34318
[email protected]5fa1c542009-05-05 20:36:07319#if defined(OS_POSIX)
320 scoped_refptr<IPC::ChannelProxy::MessageFilter>
321 suicide_on_channel_error_filter_;
322#endif
323
[email protected]b547fd42009-04-23 23:16:27324 // If true, then a GetPlugins call is allowed to rescan the disk.
325 bool plugin_refresh_allowed_;
326
[email protected]bee16aab2009-08-26 15:55:03327 // Is there a pending task for doing CacheStats.
328 bool cache_stats_task_pending_;
329
330 // The count of RenderWidgets running through this thread.
331 int widget_count_;
332
333 // The count of hidden RenderWidgets running through this thread.
334 int hidden_widget_count_;
335
336 // The current value of the idle notification timer delay.
337 double idle_notification_delay_in_s_;
338
[email protected]71d6d852009-12-07 22:12:36339 // True if this renderer is running extensions.
340 bool is_extension_process_;
341
[email protected]b2a74ca2010-03-12 17:57:09342 // True if this renderer is incognito.
343 bool is_incognito_process_;
344
[email protected]80fc08c52010-03-09 07:43:50345 bool suspend_webkit_shared_timer_;
346 bool notify_webkit_of_modal_loop_;
[email protected]c1f50aa2010-02-18 03:46:57347
[email protected]71d6d852009-12-07 22:12:36348 // Timer that periodically calls IdleHandler.
349 base::RepeatingTimer<RenderThread> idle_timer_;
350
351 // Same as above, but on a longer timer and will run even if the process is
352 // not idle, to ensure that IdleHandle gets called eventually.
353 base::RepeatingTimer<RenderThread> forced_idle_timer_;
354
[email protected]6217d392010-03-25 22:08:35355 // The channel from the renderer process to the GPU process.
356 scoped_refptr<GpuChannelHost> gpu_channel_;
357
[email protected]3a8eecb2010-04-22 23:56:30358 // A list of extension web extents, which tells us which URLs belong to an
359 // installed app.
[email protected]e13ad79b2010-07-22 21:36:50360 struct ExtensionInfo;
[email protected]3a8eecb2010-04-22 23:56:30361 std::vector<ExtensionInfo> extension_extents_;
362
[email protected]1bc83062009-02-06 00:16:37363 DISALLOW_COPY_AND_ASSIGN(RenderThread);
initial.commit09911bf2008-07-26 23:55:29364};
365
[email protected]1d97d2e2008-12-18 23:39:02366#endif // CHROME_RENDERER_RENDER_THREAD_H_