blob: 55d53d6ddb8fc7dd7431e8e3fda72c3d53f025aa [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_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
initial.commit09911bf2008-07-26 23:55:298
[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"
[email protected]71d6d852009-12-07 22:12:3614#include "base/time.h"
15#include "base/timer.h"
[email protected]037fce02009-01-22 01:42:1516#include "build/build_config.h"
[email protected]8930d472009-02-21 08:05:2817#include "chrome/common/child_thread.h"
[email protected]b9ab10c2009-08-07 18:09:5518#include "chrome/common/css_colors.h"
[email protected]3e90d4a2009-07-03 17:38:3919#include "chrome/renderer/visitedlink_slave.h"
[email protected]5c7293a2010-03-17 06:40:5720#include "gfx/native_widget_types.h"
[email protected]cb6037d2009-11-16 22:55:1721#include "ipc/ipc_platform_file.h"
initial.commit09911bf2008-07-26 23:55:2922
[email protected]1edc16b82009-04-07 17:45:5423class AppCacheDispatcher;
[email protected]dd9241932010-02-24 19:23:1324class CookieMessageFilter;
[email protected]017022b2009-07-27 23:06:3425class DBMessageFilter;
[email protected]a8624712009-04-17 00:51:3526class DevToolsAgentFilter;
[email protected]39008c02009-02-11 23:59:2527class FilePath;
[email protected]e13ad79b2010-07-22 21:36:5028class GpuChannelHost;
[email protected]70c19a932010-05-14 12:59:1129class IndexedDBDispatcher;
[email protected]dfcb62a2009-06-17 19:32:4330class ListValue;
[email protected]b7c7bcf2009-10-03 07:07:3431class NullableString16;
[email protected]55e57d42009-02-25 06:10:1732class RendererHistogram;
[email protected]e13ad79b2010-07-22 21:36:5033class RendererHistogramSnapshots;
[email protected]74be069e82010-06-25 00:12:4934class RendererNetPredictor;
[email protected]8d86fce2009-02-26 23:37:5535class RendererWebKitClientImpl;
[email protected]85c55dc2009-11-06 03:05:4636class SpellCheck;
[email protected]39008c02009-02-11 23:59:2537class SkBitmap;
[email protected]4d395d092009-02-11 21:40:4038class UserScriptSlave;
[email protected]cccf90932009-08-23 17:56:2539class URLPattern;
[email protected]2b437e232010-04-02 01:30:0840class WebDatabaseObserverImpl;
[email protected]cccf90932009-08-23 17:56:2541
[email protected]f85f0702010-01-30 09:31:0142struct ContentSettings;
[email protected]9b6f40e2009-06-11 15:54:2643struct RendererPreferences;
[email protected]c61cc652009-11-04 05:44:4044struct ViewMsg_DOMStorageEvent_Params;
[email protected]942690b132010-05-11 06:42:1445struct ViewMsg_ExtensionExtentsUpdated_Params;
[email protected]4e6419c2010-01-15 04:50:3446struct ViewMsg_New_Params;
[email protected]39008c02009-02-11 23:59:2547struct WebPreferences;
initial.commit09911bf2008-07-26 23:55:2948
[email protected]46f36a492010-07-28 19:36:4149namespace IPC {
50struct ChannelHandle;
51}
52
[email protected]b7c7bcf2009-10-03 07:07:3453namespace WebKit {
54class WebStorageEventDispatcher;
55}
56
[email protected]81a34412009-01-05 19:17:2457// The RenderThreadBase is the minimal interface that a RenderView/Widget
58// expects from a render thread. The interface basically abstracts a way to send
59// and receive messages.
[email protected]00c39612010-03-06 02:53:2860//
[email protected]f3ede412010-06-21 22:52:1661// TODO(brettw): This has two different and opposing usage patterns which
62// make it confusing.
63//
64// In the first mode, callers call RenderThread::current() to get the one and
65// only global RenderThread (bug 10837: this should be renamed get()). Then
66// they access it. Since RenderThread is a concrete class, this can be NULL
67// during unit tests. Callers need to NULL check this every time. Some callers
68// don't happen to get called during unit tests and don't do the NULL checks,
69// which is also confusing since it's not clear if you need to or not.
70//
71// In the second mode, the abstract base class RenderThreadBase is passed to
72// RenderView and RenderWidget. Normally, this points to
73// RenderThread::current() so it's quite confusing which accessing mode should
74// be used. However, during unit testing, this class is replaced with a mock
75// to support testing functions, and is guaranteed non-NULL.
76//
77// It might be nice not to have the ::current() call and put all of the
78// functions on the abstract class so they can be mocked. However, there are
79// some standalone functions like in ChromiumBridge that are not associated
80// with a view that need to access the current thread to send messages to the
81// browser process. These need the ::current() paradigm. So instead, we should
82// probably remove the render_thread_ parameter to RenderView/Widget in
83// preference to just getting the global singleton. We can make it easier to
84// understand by moving everything to the abstract interface and saying that
85// there should never be a NULL RenderThread::current(). Tests would be
86// responsible for setting up the mock one.
[email protected]8930d472009-02-21 08:05:2887class RenderThreadBase {
[email protected]8085dbc82008-09-26 22:53:4488 public:
89 virtual ~RenderThreadBase() {}
90
[email protected]8930d472009-02-21 08:05:2891 virtual bool Send(IPC::Message* msg) = 0;
92
[email protected]8085dbc82008-09-26 22:53:4493 // Called to add or remove a listener for a particular message routing ID.
94 // These methods normally get delegated to a MessageRouter.
95 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener) = 0;
96 virtual void RemoveRoute(int32 routing_id) = 0;
[email protected]81a34412009-01-05 19:17:2497
98 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
99 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
[email protected]bee16aab2009-08-26 15:55:03100
101 // Called by a RenderWidget when it is hidden or restored.
102 virtual void WidgetHidden() = 0;
103 virtual void WidgetRestored() = 0;
[email protected]b8f41a192010-04-19 18:25:04104
105 // True if this process should be treated as an extension process.
106 virtual bool IsExtensionProcess() const = 0;
[email protected]8085dbc82008-09-26 22:53:44107};
108
initial.commit09911bf2008-07-26 23:55:29109// The RenderThread class represents a background thread where RenderView
110// instances live. The RenderThread supports an API that is used by its
111// consumer to talk indirectly to the RenderViews and supporting objects.
112// Likewise, it provides an API for the RenderViews to talk back to the main
[email protected]57c6a652009-05-04 07:58:34113// process (i.e., their corresponding TabContents).
initial.commit09911bf2008-07-26 23:55:29114//
115// Most of the communication occurs in the form of IPC messages. They are
116// routed to the RenderThread according to the routing IDs of the messages.
117// The routing IDs correspond to RenderView instances.
[email protected]8930d472009-02-21 08:05:28118class RenderThread : public RenderThreadBase,
119 public ChildThread {
initial.commit09911bf2008-07-26 23:55:29120 public:
[email protected]8930d472009-02-21 08:05:28121 // Grabs the IPC channel name from the command line.
122 RenderThread();
123 // Constructor that's used when running in single process mode.
[email protected]11f4857282009-11-13 19:56:17124 explicit RenderThread(const std::string& channel_name);
[email protected]8085dbc82008-09-26 22:53:44125 virtual ~RenderThread();
initial.commit09911bf2008-07-26 23:55:29126
[email protected]8930d472009-02-21 08:05:28127 // Returns the one render thread for this process. Note that this should only
128 // be accessed when running on the render thread itself
[email protected]00c39612010-03-06 02:53:28129 //
130 // TODO(brettw) this should be on the abstract base class instead of here,
131 // and return the base class' interface instead. Currently this causes
132 // problems with testing. See the comment above RenderThreadBase above.
[email protected]8930d472009-02-21 08:05:28133 static RenderThread* current();
initial.commit09911bf2008-07-26 23:55:29134
[email protected]c1f50aa2010-02-18 03:46:57135 // Returns the routing ID of the RenderWidget containing the current script
136 // execution context (corresponding to WebFrame::frameForCurrentContext).
137 static int32 RoutingIDForCurrentContext();
138
[email protected]45776222009-07-15 20:21:58139 // Overridden from RenderThreadBase.
[email protected]c1f50aa2010-02-18 03:46:57140 virtual bool Send(IPC::Message* msg);
141 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener);
142 virtual void RemoveRoute(int32 routing_id);
[email protected]81a34412009-01-05 19:17:24143 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter);
144 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter);
[email protected]bee16aab2009-08-26 15:55:03145 virtual void WidgetHidden();
146 virtual void WidgetRestored();
147
[email protected]c1f50aa2010-02-18 03:46:57148 // These methods modify how the next message is sent. Normally, when sending
149 // a synchronous message that runs a nested message loop, we need to suspend
150 // callbacks into WebKit. This involves disabling timers and deferring
151 // resource loads. However, there are exceptions when we need to customize
152 // the behavior.
153 void DoNotSuspendWebKitSharedTimer();
154 void DoNotNotifyWebKitOfModalLoop();
155
[email protected]8d86fce2009-02-26 23:37:55156 VisitedLinkSlave* visited_link_slave() const {
157 return visited_link_slave_.get();
158 }
initial.commit09911bf2008-07-26 23:55:29159
[email protected]8d86fce2009-02-26 23:37:55160 UserScriptSlave* user_script_slave() const {
161 return user_script_slave_.get();
162 }
[email protected]1e0f70402008-10-16 23:57:47163
[email protected]f430b5712009-08-21 21:46:31164 AppCacheDispatcher* appcache_dispatcher() const {
165 return appcache_dispatcher_.get();
166 }
167
[email protected]70c19a932010-05-14 12:59:11168 IndexedDBDispatcher* indexed_db_dispatcher() const {
169 return indexed_db_dispatcher_.get();
170 }
171
[email protected]85c55dc2009-11-06 03:05:46172 SpellCheck* spellchecker() const {
173 return spellchecker_.get();
174 }
[email protected]85c55dc2009-11-06 03:05:46175
[email protected]b547fd42009-04-23 23:16:27176 bool plugin_refresh_allowed() const { return plugin_refresh_allowed_; }
177
[email protected]b8f41a192010-04-19 18:25:04178 virtual bool IsExtensionProcess() const { return is_extension_process_; }
[email protected]71d6d852009-12-07 22:12:36179
[email protected]b2a74ca2010-03-12 17:57:09180 bool is_incognito_process() const { return is_incognito_process_; }
181
initial.commit09911bf2008-07-26 23:55:29182 // Do DNS prefetch resolution of a hostname.
183 void Resolve(const char* name, size_t length);
184
[email protected]55e57d42009-02-25 06:10:17185 // Send all the Histogram data to browser.
[email protected]c9a3ef82009-05-28 22:02:46186 void SendHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17187
initial.commit09911bf2008-07-26 23:55:29188 // Invokes InformHostOfCacheStats after a short delay. Used to move this
189 // bookkeeping operation off the critical latency path.
190 void InformHostOfCacheStatsLater();
191
[email protected]c40acc32010-01-14 01:02:53192 // Sends a message to the browser to close all connections.
193 void CloseCurrentConnections();
[email protected]b07f29092009-06-05 07:33:21194
195 // Sends a message to the browser to enable or disable the disk cache.
196 void SetCacheMode(bool enabled);
197
[email protected]c5d79342010-06-05 01:27:34198 // Sends a message to the browser to clear the disk cache.
199 void ClearCache();
200
[email protected]c8865962009-12-16 07:47:39201 // Update the list of active extensions that will be reported when we crash.
202 void UpdateActiveExtensions();
203
[email protected]6217d392010-03-25 22:08:35204 // Asynchronously establish a channel to the GPU plugin if not previously
205 // established or if it has been lost (for example if the GPU plugin crashed).
206 // Use GetGpuChannel() to determine when the channel is ready for use.
207 void EstablishGpuChannel();
208
[email protected]3bf4d532010-03-27 00:23:34209 // Synchronously establish a channel to the GPU plugin if not previously
210 // established or if it has been lost (for example if the GPU plugin crashed).
211 // If there is a pending asynchronous request, it will be completed by the
212 // time this routine returns.
213 GpuChannelHost* EstablishGpuChannelSync();
214
[email protected]6217d392010-03-25 22:08:35215 // Get the GPU channel. Returns NULL if the channel is not established or
216 // has been lost.
217 GpuChannelHost* GetGpuChannel();
218
[email protected]3a8eecb2010-04-22 23:56:30219 // Returns the extension ID that the given URL is a part of, or empty if
220 // none. This includes web URLs that are part of an extension's web extent.
221 // TODO(mpcomplete): this doesn't feel like it belongs here. Find a better
222 // place.
[email protected]4fdbc1492010-07-01 01:20:59223 std::string GetExtensionIdByURL(const GURL& url);
224
225 std::string GetExtensionIdByBrowseExtent(const GURL& url);
[email protected]3a8eecb2010-04-22 23:56:30226
[email protected]8930d472009-02-21 08:05:28227 private:
228 virtual void OnControlMessageReceived(const IPC::Message& msg);
initial.commit09911bf2008-07-26 23:55:29229
[email protected]42f1d7822009-07-23 18:17:55230 void Init();
initial.commit09911bf2008-07-26 23:55:29231
[email protected]176aa482008-11-14 03:25:15232 void OnUpdateVisitedLinks(base::SharedMemoryHandle table);
[email protected]3e90d4a2009-07-03 17:38:39233 void OnAddVisitedLinks(const VisitedLinkSlave::Fingerprints& fingerprints);
234 void OnResetVisitedLinks();
[email protected]9d797f32010-04-23 07:17:54235 void OnSetZoomLevelForCurrentURL(const GURL& url, int zoom_level);
[email protected]0314ae02010-04-08 09:18:29236 void OnSetContentSettingsForCurrentURL(
237 const GURL& url, const ContentSettings& content_settings);
[email protected]b2a74ca2010-03-12 17:57:09238 void OnUpdateUserScripts(base::SharedMemoryHandle table);
[email protected]703e807a2009-03-28 19:56:51239 void OnSetExtensionFunctionNames(const std::vector<std::string>& names);
[email protected]3a8eecb2010-04-22 23:56:30240 void OnExtensionExtentsUpdated(
241 const ViewMsg_ExtensionExtentsUpdated_Params& params);
[email protected]45776222009-07-15 20:21:58242 void OnPageActionsUpdated(const std::string& extension_id,
[email protected]b7c7bcf2009-10-03 07:07:34243 const std::vector<std::string>& page_actions);
[email protected]c61cc652009-11-04 05:44:40244 void OnDOMStorageEvent(const ViewMsg_DOMStorageEvent_Params& params);
[email protected]75e126b932009-09-28 19:38:49245 void OnExtensionSetAPIPermissions(
246 const std::string& extension_id,
247 const std::vector<std::string>& permissions);
248 void OnExtensionSetHostPermissions(
249 const GURL& extension_url,
250 const std::vector<URLPattern>& permissions);
[email protected]db7331a2010-02-25 22:10:50251 void OnExtensionSetIncognitoEnabled(
252 const std::string& extension_id,
253 bool enabled);
initial.commit09911bf2008-07-26 23:55:29254 void OnSetNextPageID(int32 next_page_id);
[email protected]b2a74ca2010-03-12 17:57:09255 void OnSetIsIncognitoProcess(bool is_incognito_process);
[email protected]b9ab10c2009-08-07 18:09:55256 void OnSetCSSColors(const std::vector<CSSColors::CSSColorMapping>& colors);
[email protected]4e6419c2010-01-15 04:50:34257 void OnCreateNewView(const ViewMsg_New_Params& params);
initial.commit09911bf2008-07-26 23:55:29258 void OnTransferBitmap(const SkBitmap& bitmap, int resource_id);
259 void OnSetCacheCapacities(size_t min_dead_capacity,
260 size_t max_dead_capacity,
261 size_t capacity);
262 void OnGetCacheResourceStats();
263
[email protected]55e57d42009-02-25 06:10:17264 // Send all histograms to browser.
[email protected]c9a3ef82009-05-28 22:02:46265 void OnGetRendererHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17266
[email protected]d41041092009-10-08 06:56:57267 // Send tcmalloc info to browser.
268 void OnGetRendererTcmalloc();
[email protected]38b48a82009-11-11 01:51:32269 void OnGetV8HeapStats();
[email protected]d41041092009-10-08 06:56:57270
[email protected]dfcb62a2009-06-17 19:32:43271 void OnExtensionMessageInvoke(const std::string& function_name,
[email protected]d7259472010-03-24 08:40:49272 const ListValue& args,
[email protected]a807bbe2010-04-14 10:51:19273 bool requires_incognito_access,
274 const GURL& event_url);
[email protected]fede6ca12009-10-08 18:24:26275 void OnPurgeMemory();
[email protected]b78e168b2009-09-21 22:05:45276 void OnPurgePluginListCache(bool reload_pages);
[email protected]75e5a872009-04-02 23:56:11277
[email protected]cb6037d2009-11-16 22:55:17278 void OnInitSpellChecker(IPC::PlatformFileForTransit bdict_file,
[email protected]85c55dc2009-11-06 03:05:46279 const std::vector<std::string>& custom_words,
280 const std::string& language,
281 bool auto_spell_correct);
282 void OnSpellCheckWordAdded(const std::string& word);
283 void OnSpellCheckEnableAutoSpellCorrect(bool enable);
[email protected]85c55dc2009-11-06 03:05:46284
[email protected]6217d392010-03-25 22:08:35285 void OnGpuChannelEstablished(const IPC::ChannelHandle& channel_handle);
286
[email protected]b3df5a42010-05-11 14:31:09287 void OnGetAccessibilityTree();
288
initial.commit09911bf2008-07-26 23:55:29289 // Gather usage statistics from the in-memory cache and inform our host.
290 // These functions should be call periodically so that the host can make
291 // decisions about how to allocation resources using current information.
292 void InformHostOfCacheStats();
293
[email protected]90a3fbb12009-02-28 01:13:47294 // We initialize WebKit as late as possible.
295 void EnsureWebKitInitialized();
296
[email protected]bee16aab2009-08-26 15:55:03297 // A task we invoke periodically to assist with idle cleanup.
298 void IdleHandler();
299
[email protected]71d6d852009-12-07 22:12:36300 // Schedule a call to IdleHandler with the given initial delay.
301 void ScheduleIdleHandler(double initial_delay_s);
302
initial.commit09911bf2008-07-26 23:55:29303 // These objects live solely on the render thread.
[email protected]bee16aab2009-08-26 15:55:03304 scoped_ptr<ScopedRunnableMethodFactory<RenderThread> > task_factory_;
[email protected]42f1d7822009-07-23 18:17:55305 scoped_ptr<VisitedLinkSlave> visited_link_slave_;
306 scoped_ptr<UserScriptSlave> user_script_slave_;
[email protected]74be069e82010-06-25 00:12:49307 scoped_ptr<RendererNetPredictor> renderer_net_predictor_;
[email protected]f430b5712009-08-21 21:46:31308 scoped_ptr<AppCacheDispatcher> appcache_dispatcher_;
[email protected]70c19a932010-05-14 12:59:11309 scoped_ptr<IndexedDBDispatcher> indexed_db_dispatcher_;
[email protected]9291ed12009-07-23 17:33:22310 scoped_refptr<DevToolsAgentFilter> devtools_agent_filter_;
[email protected]42f1d7822009-07-23 18:17:55311 scoped_ptr<RendererHistogramSnapshots> histogram_snapshots_;
312 scoped_ptr<RendererWebKitClientImpl> webkit_client_;
[email protected]b7c7bcf2009-10-03 07:07:34313 scoped_ptr<WebKit::WebStorageEventDispatcher> dom_storage_event_dispatcher_;
[email protected]2b437e232010-04-02 01:30:08314 scoped_ptr<WebDatabaseObserverImpl> web_database_observer_impl_;
[email protected]85c55dc2009-11-06 03:05:46315 scoped_ptr<SpellCheck> spellchecker_;
[email protected]9291ed12009-07-23 17:33:22316
[email protected]e2b2d4a2009-10-24 03:32:59317 // Used on the renderer and IPC threads.
[email protected]017022b2009-07-27 23:06:34318 scoped_refptr<DBMessageFilter> db_message_filter_;
[email protected]dd9241932010-02-24 19:23:13319 scoped_refptr<CookieMessageFilter> cookie_message_filter_;
[email protected]017022b2009-07-27 23:06:34320
[email protected]5fa1c542009-05-05 20:36:07321#if defined(OS_POSIX)
322 scoped_refptr<IPC::ChannelProxy::MessageFilter>
323 suicide_on_channel_error_filter_;
324#endif
325
[email protected]b547fd42009-04-23 23:16:27326 // If true, then a GetPlugins call is allowed to rescan the disk.
327 bool plugin_refresh_allowed_;
328
[email protected]bee16aab2009-08-26 15:55:03329 // Is there a pending task for doing CacheStats.
330 bool cache_stats_task_pending_;
331
332 // The count of RenderWidgets running through this thread.
333 int widget_count_;
334
335 // The count of hidden RenderWidgets running through this thread.
336 int hidden_widget_count_;
337
338 // The current value of the idle notification timer delay.
339 double idle_notification_delay_in_s_;
340
[email protected]71d6d852009-12-07 22:12:36341 // True if this renderer is running extensions.
342 bool is_extension_process_;
343
[email protected]b2a74ca2010-03-12 17:57:09344 // True if this renderer is incognito.
345 bool is_incognito_process_;
346
[email protected]80fc08c52010-03-09 07:43:50347 bool suspend_webkit_shared_timer_;
348 bool notify_webkit_of_modal_loop_;
[email protected]c1f50aa2010-02-18 03:46:57349
[email protected]71d6d852009-12-07 22:12:36350 // Timer that periodically calls IdleHandler.
351 base::RepeatingTimer<RenderThread> idle_timer_;
352
353 // Same as above, but on a longer timer and will run even if the process is
354 // not idle, to ensure that IdleHandle gets called eventually.
355 base::RepeatingTimer<RenderThread> forced_idle_timer_;
356
[email protected]6217d392010-03-25 22:08:35357 // The channel from the renderer process to the GPU process.
358 scoped_refptr<GpuChannelHost> gpu_channel_;
359
[email protected]3a8eecb2010-04-22 23:56:30360 // A list of extension web extents, which tells us which URLs belong to an
361 // installed app.
[email protected]e13ad79b2010-07-22 21:36:50362 struct ExtensionInfo;
[email protected]3a8eecb2010-04-22 23:56:30363 std::vector<ExtensionInfo> extension_extents_;
364
[email protected]1bc83062009-02-06 00:16:37365 DISALLOW_COPY_AND_ASSIGN(RenderThread);
initial.commit09911bf2008-07-26 23:55:29366};
367
[email protected]1d97d2e2008-12-18 23:39:02368#endif // CHROME_RENDERER_RENDER_THREAD_H_