[email protected] | d3d6325d | 2012-01-03 21:17:36 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
license.bot | bf09a50 | 2008-08-24 00:55:55 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 4 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 5 | #include "content/renderer/render_thread_impl.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 6 | |
[email protected] | da00a288 | 2009-03-09 17:51:19 | [diff] [blame] | 7 | #include <algorithm> |
[email protected] | 61a9b2d8 | 2010-02-26 00:31:08 | [diff] [blame] | 8 | #include <limits> |
[email protected] | 75e126b93 | 2009-09-28 19:38:49 | [diff] [blame] | 9 | #include <map> |
dcheng | 07945f63 | 2015-12-26 07:59:32 | [diff] [blame] | 10 | #include <utility> |
[email protected] | da00a288 | 2009-03-09 17:51:19 | [diff] [blame] | 11 | #include <vector> |
| 12 | |
[email protected] | 237a1485 | 2012-04-28 02:56:38 | [diff] [blame] | 13 | #include "base/allocator/allocator_extension.h" |
haraken | bbfdd9f0 | 2017-01-12 07:14:04 | [diff] [blame] | 14 | #include "base/at_exit.h" |
[email protected] | 06533c0b | 2009-03-05 21:39:11 | [diff] [blame] | 15 | #include "base/command_line.h" |
creis | 9f7248b | 2016-01-27 20:27:39 | [diff] [blame] | 16 | #include "base/debug/crash_logging.h" |
[email protected] | 94f9a0f68 | 2009-06-15 18:30:30 | [diff] [blame] | 17 | #include "base/lazy_instance.h" |
[email protected] | bee16aab | 2009-08-26 15:55:03 | [diff] [blame] | 18 | #include "base/logging.h" |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 19 | #include "base/macros.h" |
reveman | 1af05cb3 | 2015-03-17 23:18:16 | [diff] [blame] | 20 | #include "base/memory/discardable_memory_allocator.h" |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 21 | #include "base/memory/memory_coordinator_client_registry.h" |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 22 | #include "base/memory/ptr_util.h" |
[email protected] | 8bac37b | 2013-07-18 19:13:56 | [diff] [blame] | 23 | #include "base/memory/shared_memory.h" |
[email protected] | 835d7c8 | 2010-10-14 04:38:38 | [diff] [blame] | 24 | #include "base/metrics/field_trial.h" |
asvitkine | 8d51e9d | 2016-09-02 23:55:43 | [diff] [blame] | 25 | #include "base/metrics/histogram_macros.h" |
[email protected] | 433df47 | 2012-03-07 20:33:39 | [diff] [blame] | 26 | #include "base/path_service.h" |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 27 | #include "base/process/process_metrics.h" |
fdoray | 2df4a9e | 2016-07-18 23:47:16 | [diff] [blame] | 28 | #include "base/run_loop.h" |
[email protected] | 21aa9968 | 2013-06-11 07:17:01 | [diff] [blame] | 29 | #include "base/strings/string16.h" |
[email protected] | 1e1d1e1 | 2014-01-17 16:14:29 | [diff] [blame] | 30 | #include "base/strings/string_number_conversions.h" |
hablich | d6a4f12 | 2015-10-28 11:34:49 | [diff] [blame] | 31 | #include "base/strings/string_split.h" |
ccameron | 6728bae3 | 2015-01-09 20:18:06 | [diff] [blame] | 32 | #include "base/strings/sys_string_conversions.h" |
[email protected] | 74ebfb1 | 2013-06-07 20:48:00 | [diff] [blame] | 33 | #include "base/strings/utf_string_conversions.h" |
fdoray | 50a3834 | 2016-11-21 20:46:04 | [diff] [blame] | 34 | #include "base/threading/sequenced_worker_pool.h" |
reveman | 34b7a152 | 2015-03-23 20:27:47 | [diff] [blame] | 35 | #include "base/threading/simple_thread.h" |
[email protected] | 1357c32 | 2010-12-30 22:18:56 | [diff] [blame] | 36 | #include "base/threading/thread_local.h" |
[email protected] | d293572a | 2013-05-23 18:50:45 | [diff] [blame] | 37 | #include "base/threading/thread_restrictions.h" |
gab | 30f26df | 2016-05-11 19:37:55 | [diff] [blame] | 38 | #include "base/threading/thread_task_runner_handle.h" |
ccameron | 9c48d1d4 | 2016-09-22 01:46:01 | [diff] [blame] | 39 | #include "base/trace_event/memory_dump_manager.h" |
primiano | 9e38d55 | 2015-01-28 04:18:01 | [diff] [blame] | 40 | #include "base/trace_event/trace_event.h" |
[email protected] | 7a4de7a6 | 2010-08-17 18:38:24 | [diff] [blame] | 41 | #include "base/values.h" |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 42 | #include "build/build_config.h" |
jbroman | 0d30216 | 2015-09-05 05:46:23 | [diff] [blame] | 43 | #include "cc/base/histograms.h" |
[email protected] | d7249315 | 2014-01-08 17:37:45 | [diff] [blame] | 44 | #include "cc/base/switches.h" |
[email protected] | 3856462 | 2014-08-19 02:47:18 | [diff] [blame] | 45 | #include "cc/blink/web_layer_impl.h" |
ericrk | 9151705c | 2016-07-26 19:53:16 | [diff] [blame] | 46 | #include "cc/output/buffer_to_texture_target_map.h" |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 47 | #include "cc/output/compositor_frame_sink.h" |
jbroman | 6ccbc7d47 | 2016-07-27 04:45:41 | [diff] [blame] | 48 | #include "cc/output/copy_output_request.h" |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 49 | #include "cc/output/vulkan_in_process_context_provider.h" |
danakj | 92015685 | 2015-05-18 20:22:29 | [diff] [blame] | 50 | #include "cc/raster/task_graph_runner.h" |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 51 | #include "cc/trees/layer_tree_host_common.h" |
loyso | a6edaaff | 2015-05-25 03:26:44 | [diff] [blame] | 52 | #include "cc/trees/layer_tree_settings.h" |
penghuang | d81c1a6 | 2016-11-02 20:06:06 | [diff] [blame] | 53 | #include "components/discardable_memory/client/client_discardable_shared_memory_manager.h" |
[email protected] | a8cb3b73b | 2013-08-12 05:50:50 | [diff] [blame] | 54 | #include "content/child/appcache/appcache_dispatcher.h" |
| 55 | #include "content/child/appcache/appcache_frontend_impl.h" |
dmurph | 1fb9848 | 2016-03-30 21:14:26 | [diff] [blame] | 56 | #include "content/child/blob_storage/blob_message_filter.h" |
[email protected] | 10208ea | 2013-06-06 20:08:03 | [diff] [blame] | 57 | #include "content/child/child_histogram_message_filter.h" |
alexclarke | 0bc36e8d3 | 2014-12-17 17:29:20 | [diff] [blame] | 58 | #include "content/child/child_resource_message_filter.h" |
jbauman | 2f5c194 | 2014-12-06 03:28:24 | [diff] [blame] | 59 | #include "content/child/child_shared_bitmap_manager.h" |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 60 | #include "content/child/content_child_helpers.h" |
[email protected] | 89c36f8 | 2013-07-17 06:23:27 | [diff] [blame] | 61 | #include "content/child/db_message_filter.h" |
[email protected] | c7199a6e | 2013-06-04 12:56:01 | [diff] [blame] | 62 | #include "content/child/indexed_db/indexed_db_dispatcher.h" |
bashi | a626404 | 2016-09-15 04:49:51 | [diff] [blame] | 63 | #include "content/child/memory/child_memory_coordinator_impl.h" |
[email protected] | 10208ea | 2013-06-06 20:08:03 | [diff] [blame] | 64 | #include "content/child/resource_dispatcher.h" |
alexclarke | 0bc36e8d3 | 2014-12-17 17:29:20 | [diff] [blame] | 65 | #include "content/child/resource_scheduling_filter.h" |
[email protected] | 643255da | 2013-06-12 20:55:13 | [diff] [blame] | 66 | #include "content/child/runtime_features.h" |
[email protected] | 57cf9788 | 2013-06-26 20:39:01 | [diff] [blame] | 67 | #include "content/child/thread_safe_sender.h" |
[email protected] | c7199a6e | 2013-06-04 12:56:01 | [diff] [blame] | 68 | #include "content/child/web_database_observer_impl.h" |
kinuko | ef64741 | 2015-12-23 06:10:43 | [diff] [blame] | 69 | #include "content/child/worker_thread_registry.h" |
[email protected] | bdae981 | 2011-10-15 00:33:03 | [diff] [blame] | 70 | #include "content/common/child_process_messages.h" |
[email protected] | 89c36f8 | 2013-07-17 06:23:27 | [diff] [blame] | 71 | #include "content/common/content_constants_internal.h" |
[email protected] | 5f2aa72 | 2013-08-07 16:59:41 | [diff] [blame] | 72 | #include "content/common/dom_storage/dom_storage_messages.h" |
thakis | 18e42641 | 2017-03-15 12:06:37 | [diff] [blame] | 73 | #include "content/common/features.h" |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 74 | #include "content/common/field_trial_recorder.mojom.h" |
[email protected] | 82307f6b | 2014-08-07 03:30:12 | [diff] [blame] | 75 | #include "content/common/frame_messages.h" |
raymes | bba82b3 | 2016-07-19 00:41:38 | [diff] [blame] | 76 | #include "content/common/frame_owner_properties.h" |
avi | a7c3f51c | 2015-09-16 00:30:31 | [diff] [blame] | 77 | #include "content/common/render_process_messages.h" |
[email protected] | 94dc971d | 2011-03-05 19:08:32 | [diff] [blame] | 78 | #include "content/common/resource_messages.h" |
alexmos | 6873421 | 2016-08-27 00:06:31 | [diff] [blame] | 79 | #include "content/common/site_isolation_policy.h" |
[email protected] | 778574e | 2011-03-21 22:03:50 | [diff] [blame] | 80 | #include "content/common/view_messages.h" |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 81 | #include "content/common/worker_messages.h" |
[email protected] | a458504b | 2012-07-23 19:57:06 | [diff] [blame] | 82 | #include "content/public/common/content_constants.h" |
bashi | a626404 | 2016-09-15 04:49:51 | [diff] [blame] | 83 | #include "content/public/common/content_features.h" |
[email protected] | 433df47 | 2012-03-07 20:33:39 | [diff] [blame] | 84 | #include "content/public/common/content_paths.h" |
[email protected] | c08950d2 | 2011-10-13 22:20:29 | [diff] [blame] | 85 | #include "content/public/common/content_switches.h" |
[email protected] | daf82f8 | 2011-10-31 22:35:31 | [diff] [blame] | 86 | #include "content/public/common/renderer_preferences.h" |
[email protected] | 58436a1 | 2012-03-21 17:10:26 | [diff] [blame] | 87 | #include "content/public/common/url_constants.h" |
[email protected] | d344114c | 2011-10-01 01:24:34 | [diff] [blame] | 88 | #include "content/public/renderer/content_renderer_client.h" |
tyoshino | 832a58a | 2016-04-18 08:14:08 | [diff] [blame] | 89 | #include "content/public/renderer/render_thread_observer.h" |
[email protected] | 64ffa044 | 2011-10-03 22:08:36 | [diff] [blame] | 90 | #include "content/public/renderer/render_view_visitor.h" |
fsamuel | 6c1dfeb | 2014-12-18 19:21:33 | [diff] [blame] | 91 | #include "content/renderer/browser_plugin/browser_plugin_manager.h" |
jsbell | 279efb4 | 2015-03-31 17:02:46 | [diff] [blame] | 92 | #include "content/renderer/cache_storage/cache_storage_dispatcher.h" |
| 93 | #include "content/renderer/cache_storage/cache_storage_message_filter.h" |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 94 | #include "content/renderer/categorized_worker_pool.h" |
[email protected] | 7001915 | 2012-12-19 11:44:19 | [diff] [blame] | 95 | #include "content/renderer/devtools/devtools_agent_filter.h" |
[email protected] | 1910fe8 | 2012-05-10 00:04:10 | [diff] [blame] | 96 | #include "content/renderer/dom_storage/dom_storage_dispatcher.h" |
| 97 | #include "content/renderer/dom_storage/webstoragearea_impl.h" |
| 98 | #include "content/renderer/dom_storage/webstoragenamespace_impl.h" |
simonhong | a7e3ac4 | 2014-11-11 20:50:22 | [diff] [blame] | 99 | #include "content/renderer/gpu/compositor_external_begin_frame_source.h" |
| 100 | #include "content/renderer/gpu/compositor_forwarding_message_filter.h" |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 101 | #include "content/renderer/gpu/frame_swap_message_queue.h" |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 102 | #include "content/renderer/gpu/renderer_compositor_frame_sink.h" |
[email protected] | 7a72d45 | 2013-12-13 10:01:13 | [diff] [blame] | 103 | #include "content/renderer/input/input_event_filter.h" |
| 104 | #include "content/renderer/input/input_handler_manager.h" |
jdduke | 691dd57 | 2014-12-02 20:47:52 | [diff] [blame] | 105 | #include "content/renderer/input/main_thread_input_event_filter.h" |
[email protected] | f7eb0a39 | 2011-07-12 10:19:51 | [diff] [blame] | 106 | #include "content/renderer/media/audio_input_message_filter.h" |
| 107 | #include "content/renderer/media/audio_message_filter.h" |
[email protected] | 3958e97 | 2012-07-17 00:25:41 | [diff] [blame] | 108 | #include "content/renderer/media/audio_renderer_mixer_manager.h" |
[email protected] | d8cd837 | 2012-03-09 10:49:51 | [diff] [blame] | 109 | #include "content/renderer/media/media_stream_center.h" |
[email protected] | a987515 | 2013-06-22 04:03:03 | [diff] [blame] | 110 | #include "content/renderer/media/midi_message_filter.h" |
xhwang | 194acae | 2014-11-12 22:46:33 | [diff] [blame] | 111 | #include "content/renderer/media/render_media_client.h" |
[email protected] | 2329bfc7 | 2014-02-28 02:03:21 | [diff] [blame] | 112 | #include "content/renderer/media/renderer_gpu_video_accelerator_factories.h" |
[email protected] | 80b161a | 2011-06-27 17:42:11 | [diff] [blame] | 113 | #include "content/renderer/media/video_capture_impl_manager.h" |
[email protected] | d7ff5fb | 2014-05-29 19:50:25 | [diff] [blame] | 114 | #include "content/renderer/net_info_helper.h" |
[email protected] | 4761cf1 | 2012-09-12 10:37:55 | [diff] [blame] | 115 | #include "content/renderer/p2p/socket_dispatcher.h" |
[email protected] | 82307f6b | 2014-08-07 03:30:12 | [diff] [blame] | 116 | #include "content/renderer/render_frame_proxy.h" |
[email protected] | 8704f89b | 2011-04-15 00:30:05 | [diff] [blame] | 117 | #include "content/renderer/render_process_impl.h" |
[email protected] | 310ebd630 | 2011-10-10 19:06:28 | [diff] [blame] | 118 | #include "content/renderer/render_view_impl.h" |
tfarina | 556a723 | 2014-10-05 01:02:09 | [diff] [blame] | 119 | #include "content/renderer/renderer_blink_platform_impl.h" |
jdduke | 94ae1f3 | 2015-02-05 06:27:13 | [diff] [blame] | 120 | #include "content/renderer/scheduler/resource_dispatch_throttler.h" |
[email protected] | 7670d433 | 2013-11-29 04:35:00 | [diff] [blame] | 121 | #include "content/renderer/service_worker/embedded_worker_dispatcher.h" |
shimazu | 5de409e4 | 2016-09-29 08:45:28 | [diff] [blame] | 122 | #include "content/renderer/service_worker/embedded_worker_instance_client_impl.h" |
mek | 27c9d74 | 2015-07-16 18:30:18 | [diff] [blame] | 123 | #include "content/renderer/service_worker/service_worker_context_client.h" |
kinuko | 5af4ffe | 2015-06-09 03:38:46 | [diff] [blame] | 124 | #include "content/renderer/service_worker/service_worker_context_message_filter.h" |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 125 | #include "content/renderer/shared_worker/embedded_shared_worker_stub.h" |
chunyang.dai | be874c5 | 2014-11-14 06:45:05 | [diff] [blame] | 126 | #include "gin/public/debug.h" |
dongseong.hwang | 72183b0 | 2014-12-08 10:41:55 | [diff] [blame] | 127 | #include "gpu/GLES2/gl2extchromium.h" |
danakj | 6f4e1e2 | 2016-04-20 03:27:34 | [diff] [blame] | 128 | #include "gpu/command_buffer/client/shared_memory_limits.h" |
danakj | 870925d4 | 2016-05-03 20:07:38 | [diff] [blame] | 129 | #include "gpu/ipc/client/command_buffer_proxy_impl.h" |
penghuang | 346a46f9 | 2016-03-31 21:37:52 | [diff] [blame] | 130 | #include "gpu/ipc/client/gpu_channel_host.h" |
[email protected] | 46f36a49 | 2010-07-28 19:36:41 | [diff] [blame] | 131 | #include "ipc/ipc_channel_handle.h" |
amistry | d4aa70d | 2016-06-23 07:52:37 | [diff] [blame] | 132 | #include "ipc/ipc_channel_mojo.h" |
[email protected] | cb6037d | 2009-11-16 22:55:17 | [diff] [blame] | 133 | #include "ipc/ipc_platform_file.h" |
[email protected] | 433df47 | 2012-03-07 20:33:39 | [diff] [blame] | 134 | #include "media/base/media.h" |
chcunningham | 9a285ed | 2017-03-08 21:48:56 | [diff] [blame] | 135 | #include "media/base/media_switches.h" |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 136 | #include "media/media_features.h" |
servolk | 8b3b39b | 2015-03-03 19:08:18 | [diff] [blame] | 137 | #include "media/renderers/gpu_video_accelerator_factories.h" |
rockot | 85dce086 | 2015-11-13 01:33:59 | [diff] [blame] | 138 | #include "mojo/public/cpp/bindings/strong_binding.h" |
[email protected] | 620161e | 2011-03-07 18:05:26 | [diff] [blame] | 139 | #include "net/base/net_errors.h" |
eroman | 9ab6484 | 2015-07-21 05:07:52 | [diff] [blame] | 140 | #include "net/base/port_util.h" |
hablich | d6a4f12 | 2015-10-28 11:34:49 | [diff] [blame] | 141 | #include "net/base/registry_controlled_domains/registry_controlled_domain.h" |
tfarina | 7a4a7fd | 2016-01-20 14:23:44 | [diff] [blame] | 142 | #include "net/base/url_util.h" |
brettw | 4b46108 | 2016-11-19 18:55:16 | [diff] [blame] | 143 | #include "ppapi/features/features.h" |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 144 | #include "services/service_manager/public/cpp/connector.h" |
rockot | 734fb66 | 2016-10-15 16:41:30 | [diff] [blame] | 145 | #include "services/service_manager/public/cpp/interface_provider.h" |
| 146 | #include "services/service_manager/public/cpp/interface_registry.h" |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 147 | #include "services/ui/public/cpp/gpu/context_provider_command_buffer.h" |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 148 | #include "services/ui/public/interfaces/constants.mojom.h" |
[email protected] | b48c53ad | 2014-02-05 21:59:18 | [diff] [blame] | 149 | #include "skia/ext/event_tracer_impl.h" |
ssid | 59c96916 | 2015-07-28 13:02:58 | [diff] [blame] | 150 | #include "skia/ext/skia_memory_dump_provider.h" |
kinuko | ed1ed1d | 2017-02-08 09:13:43 | [diff] [blame] | 151 | #include "third_party/WebKit/public/platform/WebCache.h" |
reed | 6e5a7222 | 2015-08-06 20:37:16 | [diff] [blame] | 152 | #include "third_party/WebKit/public/platform/WebImageGenerator.h" |
bashi | 5f4c7892 | 2016-08-18 23:06:08 | [diff] [blame] | 153 | #include "third_party/WebKit/public/platform/WebMemoryCoordinator.h" |
kinuko | fbfee76 | 2017-03-08 04:01:06 | [diff] [blame] | 154 | #include "third_party/WebKit/public/platform/WebNetworkStateNotifier.h" |
[email protected] | 89c36f8 | 2013-07-17 06:23:27 | [diff] [blame] | 155 | #include "third_party/WebKit/public/platform/WebString.h" |
skyostil | 457b0a1 | 2014-09-09 10:12:07 | [diff] [blame] | 156 | #include "third_party/WebKit/public/platform/WebThread.h" |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 157 | #include "third_party/WebKit/public/platform/scheduler/child/compositor_worker_scheduler.h" |
| 158 | #include "third_party/WebKit/public/platform/scheduler/child/webthread_impl_for_worker_scheduler.h" |
| 159 | #include "third_party/WebKit/public/platform/scheduler/renderer/renderer_scheduler.h" |
[email protected] | 2255a933 | 2013-06-17 05:12:31 | [diff] [blame] | 160 | #include "third_party/WebKit/public/web/WebDatabase.h" |
| 161 | #include "third_party/WebKit/public/web/WebDocument.h" |
| 162 | #include "third_party/WebKit/public/web/WebFrame.h" |
| 163 | #include "third_party/WebKit/public/web/WebKit.h" |
[email protected] | 2255a933 | 2013-06-17 05:12:31 | [diff] [blame] | 164 | #include "third_party/WebKit/public/web/WebRuntimeFeatures.h" |
| 165 | #include "third_party/WebKit/public/web/WebScriptController.h" |
| 166 | #include "third_party/WebKit/public/web/WebSecurityPolicy.h" |
[email protected] | 2255a933 | 2013-06-17 05:12:31 | [diff] [blame] | 167 | #include "third_party/WebKit/public/web/WebView.h" |
[email protected] | ddbb5334 | 2014-01-06 10:59:47 | [diff] [blame] | 168 | #include "third_party/skia/include/core/SkGraphics.h" |
[email protected] | c49201a | 2012-05-24 11:04:57 | [diff] [blame] | 169 | #include "ui/base/layout.h" |
[email protected] | 18ad677 | 2011-09-20 21:51:32 | [diff] [blame] | 170 | #include "ui/base/ui_base_switches.h" |
enne | e292bdc | 2016-09-15 19:57:15 | [diff] [blame] | 171 | #include "ui/gl/gl_switches.h" |
[email protected] | 2c62b56 | 2009-01-27 19:04:50 | [diff] [blame] | 172 | |
[email protected] | 33b0299 | 2014-03-01 01:06:29 | [diff] [blame] | 173 | #if defined(OS_ANDROID) |
| 174 | #include <cpu-features.h> |
boliu | bee541f4 | 2015-11-05 00:52:53 | [diff] [blame] | 175 | #include "content/renderer/android/synchronous_compositor_filter.h" |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 176 | #include "content/renderer/android/synchronous_compositor_frame_sink.h" |
boliu | e81d1613 | 2016-04-26 00:54:41 | [diff] [blame] | 177 | #include "content/renderer/media/android/stream_texture_factory.h" |
dalecurtis | 88af393 | 2016-02-20 00:12:20 | [diff] [blame] | 178 | #include "media/base/android/media_codec_util.h" |
[email protected] | 33b0299 | 2014-03-01 01:06:29 | [diff] [blame] | 179 | #endif |
| 180 | |
| 181 | #if defined(OS_MACOSX) |
ccameron | a764475 | 2014-12-30 01:16:31 | [diff] [blame] | 182 | #include "base/mac/mac_util.h" |
rsesek | 1efb3c3 | 2015-09-29 15:39:50 | [diff] [blame] | 183 | #include "content/renderer/theme_helper_mac.h" |
[email protected] | 33b0299 | 2014-03-01 01:06:29 | [diff] [blame] | 184 | #include "content/renderer/webscrollbarbehavior_impl_mac.h" |
| 185 | #endif |
| 186 | |
[email protected] | da00a288 | 2009-03-09 17:51:19 | [diff] [blame] | 187 | #if defined(OS_WIN) |
| 188 | #include <windows.h> |
| 189 | #include <objbase.h> |
| 190 | #endif |
| 191 | |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 192 | #if BUILDFLAG(ENABLE_WEBRTC) |
liushouqun | 517b129 | 2016-09-14 05:58:59 | [diff] [blame] | 193 | #include "content/renderer/media/aec_dump_message_filter.h" |
[email protected] | 22fe91d | 2014-08-12 17:07:12 | [diff] [blame] | 194 | #include "content/renderer/media/peer_connection_tracker.h" |
| 195 | #include "content/renderer/media/rtc_peer_connection_handler.h" |
| 196 | #include "content/renderer/media/webrtc/peer_connection_dependency_factory.h" |
[email protected] | 22fe91d | 2014-08-12 17:07:12 | [diff] [blame] | 197 | #endif |
| 198 | |
chunyang.dai | be874c5 | 2014-11-14 06:45:05 | [diff] [blame] | 199 | #ifdef ENABLE_VTUNE_JIT_INTERFACE |
| 200 | #include "v8/src/third_party/vtune/v8-vtune.h" |
| 201 | #endif |
| 202 | |
ben | d32292b | 2016-10-07 00:21:58 | [diff] [blame] | 203 | #include "content/public/common/service_manager_connection.h" |
fsamuel | 2545ecc | 2015-12-05 00:44:46 | [diff] [blame] | 204 | #include "content/renderer/mus/render_widget_window_tree_client_factory.h" |
sadrul | 602ce136 | 2017-01-26 06:41:10 | [diff] [blame] | 205 | #include "content/renderer/mus/renderer_window_tree_client.h" |
sadrul | 04cfa89 | 2016-12-09 17:53:49 | [diff] [blame] | 206 | #include "services/ui/public/cpp/gpu/gpu.h" |
fsamuel | 6c6da023 | 2015-11-26 05:13:46 | [diff] [blame] | 207 | |
ochang | dd89a1e | 2016-06-08 16:39:01 | [diff] [blame] | 208 | #if defined(ENABLE_IPC_FUZZER) |
| 209 | #include "content/common/external_ipc_dumper.h" |
| 210 | #endif |
| 211 | |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 212 | #if defined(OS_MACOSX) |
| 213 | #include <malloc/malloc.h> |
| 214 | #else |
| 215 | #include <malloc.h> |
| 216 | #endif |
| 217 | |
[email protected] | d293572a | 2013-05-23 18:50:45 | [diff] [blame] | 218 | using base::ThreadRestrictions; |
[email protected] | 180ef24 | 2013-11-07 06:50:46 | [diff] [blame] | 219 | using blink::WebDocument; |
| 220 | using blink::WebFrame; |
| 221 | using blink::WebNetworkStateNotifier; |
| 222 | using blink::WebRuntimeFeatures; |
| 223 | using blink::WebScriptController; |
| 224 | using blink::WebSecurityPolicy; |
| 225 | using blink::WebString; |
| 226 | using blink::WebView; |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 227 | using blink::scheduler::WebThreadImplForWorkerScheduler; |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 228 | |
| 229 | namespace content { |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 230 | |
[email protected] | 42f1d782 | 2009-07-23 18:17:55 | [diff] [blame] | 231 | namespace { |
[email protected] | da9ccfb | 2012-01-28 00:34:40 | [diff] [blame] | 232 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 233 | const int64_t kInitialIdleHandlerDelayMs = 1000; |
| 234 | const int64_t kLongIdleHandlerDelayMs = 30 * 1000; |
[email protected] | bee16aab | 2009-08-26 15:55:03 | [diff] [blame] | 235 | |
jdduke | 94ae1f3 | 2015-02-05 06:27:13 | [diff] [blame] | 236 | #if defined(OS_ANDROID) |
| 237 | // On Android, resource messages can each take ~1.5ms to dispatch on the browser |
| 238 | // IO thread. Limiting the message rate to 3/frame at 60hz ensures that the |
| 239 | // induced work takes but a fraction (~1/4) of the overall frame budget. |
| 240 | const int kMaxResourceRequestsPerFlushWhenThrottled = 3; |
| 241 | #else |
| 242 | const int kMaxResourceRequestsPerFlushWhenThrottled = 8; |
| 243 | #endif |
| 244 | const double kThrottledResourceRequestFlushPeriodS = 1. / 60.; |
| 245 | |
[email protected] | dd2c102 | 2014-07-22 23:13:57 | [diff] [blame] | 246 | // Maximum allocation size allowed for image scaling filters that |
| 247 | // require pre-scaling. Skia will fallback to a filter that doesn't |
| 248 | // require pre-scaling if the default filter would require an |
| 249 | // allocation that exceeds this limit. |
| 250 | const size_t kImageCacheSingleAllocationByteLimit = 64 * 1024 * 1024; |
| 251 | |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 252 | // Unique identifier for each output surface created. |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 253 | uint32_t g_next_compositor_frame_sink_id = 1; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 254 | |
rockot | 5c478a7 | 2016-09-28 23:14:18 | [diff] [blame] | 255 | // An implementation of mojom::RenderMessageFilter which can be mocked out |
| 256 | // for tests which may indirectly send messages over this interface. |
| 257 | mojom::RenderMessageFilter* g_render_message_filter_for_testing; |
| 258 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 259 | // Keep the global RenderThreadImpl in a TLS slot so it is impossible to access |
[email protected] | f3ede41 | 2010-06-21 22:52:16 | [diff] [blame] | 260 | // incorrectly from the wrong thread. |
scottmg | 5e65e3a | 2017-03-08 08:48:46 | [diff] [blame] | 261 | base::LazyInstance<base::ThreadLocalPointer<RenderThreadImpl>>::DestructorAtExit |
[email protected] | 6de0fd1d | 2011-11-15 13:31:49 | [diff] [blame] | 262 | lazy_tls = LAZY_INSTANCE_INITIALIZER; |
[email protected] | 1edc16b8 | 2009-04-07 17:45:54 | [diff] [blame] | 263 | |
hong.zheng | b28b533 | 2016-05-11 02:33:39 | [diff] [blame] | 264 | // v8::MemoryPressureLevel should correspond to base::MemoryPressureListener. |
| 265 | static_assert(static_cast<v8::MemoryPressureLevel>( |
| 266 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE) == |
| 267 | v8::MemoryPressureLevel::kNone, "none level not align"); |
| 268 | static_assert(static_cast<v8::MemoryPressureLevel>( |
| 269 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE) == |
| 270 | v8::MemoryPressureLevel::kModerate, "moderate level not align"); |
| 271 | static_assert(static_cast<v8::MemoryPressureLevel>( |
| 272 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_CRITICAL) == |
| 273 | v8::MemoryPressureLevel::kCritical, "critical level not align"); |
| 274 | |
hong.zheng | 2e296f82 | 2016-06-29 02:47:44 | [diff] [blame] | 275 | // WebMemoryPressureLevel should correspond to base::MemoryPressureListener. |
| 276 | static_assert(static_cast<blink::WebMemoryPressureLevel>( |
| 277 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE) == |
| 278 | blink::WebMemoryPressureLevelNone, |
| 279 | "blink::WebMemoryPressureLevelNone not align"); |
| 280 | static_assert(static_cast<blink::WebMemoryPressureLevel>( |
| 281 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE) == |
| 282 | blink::WebMemoryPressureLevelModerate, |
| 283 | "blink::WebMemoryPressureLevelModerate not align"); |
| 284 | static_assert(static_cast<blink::WebMemoryPressureLevel>( |
| 285 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_CRITICAL) == |
| 286 | blink::WebMemoryPressureLevelCritical, |
| 287 | "blink::WebMemoryPressureLevelCritical not align"); |
| 288 | |
sadrul | ff12c00 | 2016-01-14 20:52:20 | [diff] [blame] | 289 | class WebThreadForCompositor : public WebThreadImplForWorkerScheduler { |
| 290 | public: |
| 291 | explicit WebThreadForCompositor(base::Thread::Options options) |
| 292 | : WebThreadImplForWorkerScheduler("Compositor", options) { |
| 293 | Init(); |
| 294 | } |
| 295 | ~WebThreadForCompositor() override {} |
| 296 | |
| 297 | private: |
| 298 | // WebThreadImplForWorkerScheduler: |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 299 | std::unique_ptr<blink::scheduler::WorkerScheduler> CreateWorkerScheduler() |
| 300 | override { |
ricea | 29649b9 | 2016-08-31 09:30:21 | [diff] [blame] | 301 | return base::MakeUnique<blink::scheduler::CompositorWorkerScheduler>( |
| 302 | thread()); |
sadrul | ff12c00 | 2016-01-14 20:52:20 | [diff] [blame] | 303 | } |
| 304 | |
| 305 | DISALLOW_COPY_AND_ASSIGN(WebThreadForCompositor); |
| 306 | }; |
| 307 | |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 308 | void* CreateHistogram( |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 309 | const char *name, int min, int max, size_t buckets) { |
| 310 | if (min <= 0) |
| 311 | min = 1; |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 312 | std::string histogram_name; |
| 313 | RenderThreadImpl* render_thread_impl = RenderThreadImpl::current(); |
| 314 | if (render_thread_impl) { // Can be null in tests. |
| 315 | histogram_name = render_thread_impl-> |
| 316 | histogram_customizer()->ConvertToCustomHistogramName(name); |
| 317 | } else { |
| 318 | histogram_name = std::string(name); |
| 319 | } |
[email protected] | de41555 | 2013-01-23 04:12:17 | [diff] [blame] | 320 | base::HistogramBase* histogram = base::Histogram::FactoryGet( |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 321 | histogram_name, min, max, buckets, |
| 322 | base::Histogram::kUmaTargetedHistogramFlag); |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 323 | return histogram; |
| 324 | } |
| 325 | |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 326 | void AddHistogramSample(void* hist, int sample) { |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 327 | base::Histogram* histogram = static_cast<base::Histogram*>(hist); |
| 328 | histogram->Add(sample); |
| 329 | } |
| 330 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 331 | class FrameFactoryImpl : public mojom::FrameFactory { |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 332 | public: |
rockot | 8e66a08d | 2016-09-13 00:48:21 | [diff] [blame] | 333 | FrameFactoryImpl() : routing_id_highmark_(-1) {} |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 334 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 335 | private: |
| 336 | // mojom::FrameFactory: |
| 337 | void CreateFrame(int32_t frame_routing_id, |
| 338 | mojom::FrameRequest frame_request, |
| 339 | mojom::FrameHostPtr frame_host) override { |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 340 | // TODO(morrita): This is for investigating http://crbug.com/415059 and |
| 341 | // should be removed once it is fixed. |
| 342 | CHECK_LT(routing_id_highmark_, frame_routing_id); |
| 343 | routing_id_highmark_ = frame_routing_id; |
| 344 | |
| 345 | RenderFrameImpl* frame = RenderFrameImpl::FromRoutingID(frame_routing_id); |
| 346 | // We can receive a GetServiceProviderForFrame message for a frame not yet |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 347 | // created due to a race between the message and a |
| 348 | // mojom::Renderer::CreateView IPC that triggers creation of the RenderFrame |
| 349 | // we want. |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 350 | if (!frame) { |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 351 | RenderThreadImpl::current()->RegisterPendingFrameCreate( |
| 352 | frame_routing_id, std::move(frame_request), std::move(frame_host)); |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 353 | return; |
| 354 | } |
| 355 | |
dominickn | 6c1f1cf | 2016-12-20 06:13:33 | [diff] [blame] | 356 | frame->BindFrame(std::move(frame_request), std::move(frame_host)); |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 357 | } |
| 358 | |
| 359 | private: |
| 360 | int32_t routing_id_highmark_; |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 361 | }; |
| 362 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 363 | void CreateFrameFactory(mojom::FrameFactoryRequest request) { |
rockot | 8e66a08d | 2016-09-13 00:48:21 | [diff] [blame] | 364 | mojo::MakeStrongBinding(base::MakeUnique<FrameFactoryImpl>(), |
| 365 | std::move(request)); |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 366 | } |
| 367 | |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 368 | scoped_refptr<ui::ContextProviderCommandBuffer> CreateOffscreenContext( |
danakj | c398355 | 2016-05-03 00:04:35 | [diff] [blame] | 369 | scoped_refptr<gpu::GpuChannelHost> gpu_channel_host, |
danakj | 0dd9e1e | 2016-05-11 22:15:09 | [diff] [blame] | 370 | const gpu::SharedMemoryLimits& limits, |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 371 | bool support_locking, |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 372 | ui::command_buffer_metrics::ContextType type, |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 373 | int32_t stream_id, |
| 374 | gpu::GpuStreamPriority stream_priority) { |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 375 | DCHECK(gpu_channel_host); |
| 376 | // This is used to create a few different offscreen contexts: |
| 377 | // - The shared main thread context (offscreen) used by blink for canvas. |
| 378 | // - The worker context (offscreen) used for GPU raster and video decoding. |
| 379 | // This is for an offscreen context, so the default framebuffer doesn't need |
| 380 | // alpha, depth, stencil, antialiasing. |
| 381 | gpu::gles2::ContextCreationAttribHelper attributes; |
| 382 | attributes.alpha_size = -1; |
| 383 | attributes.depth_size = 0; |
| 384 | attributes.stencil_size = 0; |
| 385 | attributes.samples = 0; |
| 386 | attributes.sample_buffers = 0; |
| 387 | attributes.bind_generates_resource = false; |
| 388 | attributes.lose_context_when_out_of_memory = true; |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 389 | const bool automatic_flushes = false; |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 390 | return make_scoped_refptr(new ui::ContextProviderCommandBuffer( |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 391 | std::move(gpu_channel_host), stream_id, stream_priority, |
| 392 | gpu::kNullSurfaceHandle, |
zmo | 09ea813b | 2017-01-20 23:38:36 | [diff] [blame] | 393 | GURL("chrome://gpu/RenderThreadImpl::CreateOffscreenContext/" + |
| 394 | ui::command_buffer_metrics::ContextTypeToString(type)), |
piman | d488e8b4 | 2016-06-30 19:06:59 | [diff] [blame] | 395 | automatic_flushes, support_locking, limits, attributes, nullptr, type)); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 396 | } |
| 397 | |
penghuang | e1d8651 | 2016-07-08 18:15:00 | [diff] [blame] | 398 | bool IsRunningInMash() { |
| 399 | const base::CommandLine* cmdline = base::CommandLine::ForCurrentProcess(); |
| 400 | return cmdline->HasSwitch(switches::kIsRunningInMash); |
| 401 | } |
| 402 | |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 403 | } // namespace |
| 404 | |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 405 | // For measuring memory usage after each task. Behind a command line flag. |
| 406 | class MemoryObserver : public base::MessageLoop::TaskObserver { |
| 407 | public: |
| 408 | MemoryObserver() {} |
dcheng | 6d18e40 | 2014-10-21 12:32:52 | [diff] [blame] | 409 | ~MemoryObserver() override {} |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 410 | |
dcheng | 6d18e40 | 2014-10-21 12:32:52 | [diff] [blame] | 411 | void WillProcessTask(const base::PendingTask& pending_task) override {} |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 412 | |
dcheng | 6d18e40 | 2014-10-21 12:32:52 | [diff] [blame] | 413 | void DidProcessTask(const base::PendingTask& pending_task) override { |
asvitkine | c0fb802 | 2014-08-26 04:39:35 | [diff] [blame] | 414 | LOCAL_HISTOGRAM_MEMORY_KB("Memory.RendererUsed", GetMemoryUsageKB()); |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 415 | } |
| 416 | |
| 417 | private: |
| 418 | DISALLOW_COPY_AND_ASSIGN(MemoryObserver); |
| 419 | }; |
| 420 | |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 421 | RenderThreadImpl::HistogramCustomizer::HistogramCustomizer() { |
| 422 | custom_histograms_.insert("V8.MemoryExternalFragmentationTotal"); |
| 423 | custom_histograms_.insert("V8.MemoryHeapSampleTotalCommitted"); |
| 424 | custom_histograms_.insert("V8.MemoryHeapSampleTotalUsed"); |
hablich | 4598ddc | 2015-11-07 18:37:28 | [diff] [blame] | 425 | custom_histograms_.insert("V8.MemoryHeapUsed"); |
| 426 | custom_histograms_.insert("V8.MemoryHeapCommitted"); |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 427 | } |
| 428 | |
| 429 | RenderThreadImpl::HistogramCustomizer::~HistogramCustomizer() {} |
| 430 | |
| 431 | void RenderThreadImpl::HistogramCustomizer::RenderViewNavigatedToHost( |
| 432 | const std::string& host, size_t view_count) { |
avi | 83883c8 | 2014-12-23 00:08:49 | [diff] [blame] | 433 | if (base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 434 | switches::kDisableHistogramCustomizer)) { |
[email protected] | 9baee83 | 2012-12-10 11:07:15 | [diff] [blame] | 435 | return; |
| 436 | } |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 437 | // Check if all RenderViews are displaying a page from the same host. If there |
| 438 | // is only one RenderView, the common host is this view's host. If there are |
| 439 | // many, check if this one shares the common host of the other |
| 440 | // RenderViews. It's ok to not detect some cases where the RenderViews share a |
| 441 | // common host. This information is only used for producing custom histograms. |
| 442 | if (view_count == 1) |
| 443 | SetCommonHost(host); |
| 444 | else if (host != common_host_) |
| 445 | SetCommonHost(std::string()); |
| 446 | } |
| 447 | |
| 448 | std::string RenderThreadImpl::HistogramCustomizer::ConvertToCustomHistogramName( |
| 449 | const char* histogram_name) const { |
| 450 | std::string name(histogram_name); |
| 451 | if (!common_host_histogram_suffix_.empty() && |
| 452 | custom_histograms_.find(name) != custom_histograms_.end()) |
| 453 | name += common_host_histogram_suffix_; |
| 454 | return name; |
| 455 | } |
| 456 | |
| 457 | void RenderThreadImpl::HistogramCustomizer::SetCommonHost( |
| 458 | const std::string& host) { |
| 459 | if (host != common_host_) { |
| 460 | common_host_ = host; |
| 461 | common_host_histogram_suffix_ = HostToCustomHistogramSuffix(host); |
[email protected] | 4b534028 | 2014-07-08 11:37:34 | [diff] [blame] | 462 | blink::mainThreadIsolate()->SetCreateHistogramFunction(CreateHistogram); |
[email protected] | b2d9876 | 2012-09-03 17:04:06 | [diff] [blame] | 463 | } |
| 464 | } |
| 465 | |
hablich | d6a4f12 | 2015-10-28 11:34:49 | [diff] [blame] | 466 | std::string RenderThreadImpl::HistogramCustomizer::HostToCustomHistogramSuffix( |
| 467 | const std::string& host) { |
| 468 | if (host == "mail.google.com") |
| 469 | return ".gmail"; |
| 470 | if (host == "docs.google.com" || host == "drive.google.com") |
| 471 | return ".docs"; |
| 472 | if (host == "plus.google.com") |
| 473 | return ".plus"; |
| 474 | if (host == "inbox.google.com") |
| 475 | return ".inbox"; |
hpayer | dd4def05 | 2016-02-06 19:06:10 | [diff] [blame] | 476 | if (host == "calendar.google.com") |
| 477 | return ".calendar"; |
hablich | d6a4f12 | 2015-10-28 11:34:49 | [diff] [blame] | 478 | if (host == "www.youtube.com") |
| 479 | return ".youtube"; |
| 480 | if (IsAlexaTop10NonGoogleSite(host)) |
| 481 | return ".top10"; |
| 482 | |
| 483 | return std::string(); |
| 484 | } |
| 485 | |
| 486 | bool RenderThreadImpl::HistogramCustomizer::IsAlexaTop10NonGoogleSite( |
| 487 | const std::string& host) { |
| 488 | // The Top10 sites have different TLD and/or subdomains depending on the |
| 489 | // localization. |
| 490 | if (host == "sina.com.cn") |
| 491 | return true; |
| 492 | |
| 493 | std::string sanitized_host = |
| 494 | net::registry_controlled_domains::GetDomainAndRegistry( |
| 495 | host, net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES); |
| 496 | |
| 497 | if (sanitized_host == "facebook.com") |
| 498 | return true; |
| 499 | if (sanitized_host == "baidu.com") |
| 500 | return true; |
| 501 | if (sanitized_host == "qq.com") |
| 502 | return true; |
| 503 | if (sanitized_host == "twitter.com") |
| 504 | return true; |
| 505 | if (sanitized_host == "taobao.com") |
| 506 | return true; |
| 507 | if (sanitized_host == "live.com") |
| 508 | return true; |
| 509 | |
| 510 | if (!sanitized_host.empty()) { |
| 511 | std::vector<base::StringPiece> host_tokens = base::SplitStringPiece( |
| 512 | sanitized_host, ".", base::TRIM_WHITESPACE, base::SPLIT_WANT_NONEMPTY); |
| 513 | |
| 514 | if (host_tokens.size() >= 2) { |
| 515 | if ((host_tokens[0] == "yahoo") || (host_tokens[0] == "amazon") || |
| 516 | (host_tokens[0] == "wikipedia")) { |
| 517 | return true; |
| 518 | } |
| 519 | } |
| 520 | } |
| 521 | return false; |
| 522 | } |
| 523 | |
leon.han | 2c0f9f1 | 2015-07-11 02:01:19 | [diff] [blame] | 524 | // static |
| 525 | RenderThreadImpl* RenderThreadImpl::Create( |
| 526 | const InProcessChildThreadParams& params) { |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 527 | std::unique_ptr<blink::scheduler::RendererScheduler> renderer_scheduler = |
| 528 | blink::scheduler::RendererScheduler::Create(); |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 529 | scoped_refptr<base::SingleThreadTaskRunner> test_task_counter; |
| 530 | return new RenderThreadImpl( |
| 531 | params, std::move(renderer_scheduler), test_task_counter); |
leon.han | 2c0f9f1 | 2015-07-11 02:01:19 | [diff] [blame] | 532 | } |
| 533 | |
| 534 | // static |
| 535 | RenderThreadImpl* RenderThreadImpl::Create( |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 536 | std::unique_ptr<base::MessageLoop> main_message_loop, |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 537 | std::unique_ptr<blink::scheduler::RendererScheduler> renderer_scheduler) { |
dcheng | 07945f63 | 2015-12-26 07:59:32 | [diff] [blame] | 538 | return new RenderThreadImpl(std::move(main_message_loop), |
| 539 | std::move(renderer_scheduler)); |
leon.han | 2c0f9f1 | 2015-07-11 02:01:19 | [diff] [blame] | 540 | } |
| 541 | |
rockot | 5c478a7 | 2016-09-28 23:14:18 | [diff] [blame] | 542 | // static |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 543 | RenderThreadImpl* RenderThreadImpl::current() { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 544 | return lazy_tls.Pointer()->Get(); |
| 545 | } |
| 546 | |
rockot | 5c478a7 | 2016-09-28 23:14:18 | [diff] [blame] | 547 | // static |
| 548 | mojom::RenderMessageFilter* RenderThreadImpl::current_render_message_filter() { |
| 549 | if (g_render_message_filter_for_testing) |
| 550 | return g_render_message_filter_for_testing; |
| 551 | DCHECK(current()); |
| 552 | return current()->render_message_filter(); |
| 553 | } |
| 554 | |
| 555 | // static |
jcivelli | 315d17f | 2016-11-29 16:15:05 | [diff] [blame] | 556 | const scoped_refptr<mojom::ThreadSafeRenderMessageFilterAssociatedPtr>& |
| 557 | RenderThreadImpl::current_thread_safe_render_message_filter() { |
| 558 | DCHECK(current()); |
| 559 | return current()->thread_safe_render_message_filter(); |
| 560 | } |
| 561 | |
| 562 | // static |
rockot | 5c478a7 | 2016-09-28 23:14:18 | [diff] [blame] | 563 | void RenderThreadImpl::SetRenderMessageFilterForTesting( |
| 564 | mojom::RenderMessageFilter* render_message_filter) { |
| 565 | g_render_message_filter_for_testing = render_message_filter; |
| 566 | } |
| 567 | |
staraz | 067f5824 | 2016-11-07 21:06:41 | [diff] [blame] | 568 | // In single-process mode used for debugging, we don't pass a renderer client |
| 569 | // ID via command line because RenderThreadImpl lives in the same process as |
| 570 | // the browser |
leon.han | 2c0f9f1 | 2015-07-11 02:01:19 | [diff] [blame] | 571 | RenderThreadImpl::RenderThreadImpl( |
| 572 | const InProcessChildThreadParams& params, |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 573 | std::unique_ptr<blink::scheduler::RendererScheduler> scheduler, |
rockot | 97a8683 | 2016-12-10 04:53:06 | [diff] [blame] | 574 | const scoped_refptr<base::SingleThreadTaskRunner>& resource_task_queue) |
morrita | c6238ab | 2015-03-18 01:48:29 | [diff] [blame] | 575 | : ChildThreadImpl(Options::Builder() |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 576 | .InBrowserProcess(params) |
ben | d32292b | 2016-10-07 00:21:58 | [diff] [blame] | 577 | .AutoStartServiceManagerConnection(false) |
ben | 5be0b913 | 2016-08-03 00:17:18 | [diff] [blame] | 578 | .ConnectToBrowser(true) |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 579 | .Build()), |
dcheng | 07945f63 | 2015-12-26 07:59:32 | [diff] [blame] | 580 | renderer_scheduler_(std::move(scheduler)), |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 581 | categorized_worker_pool_(new CategorizedWorkerPool()), |
staraz | 067f5824 | 2016-11-07 21:06:41 | [diff] [blame] | 582 | renderer_binding_(this), |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 583 | client_id_(1), |
| 584 | field_trial_syncer_(this) { |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 585 | Init(resource_task_queue); |
morrita | c6238ab | 2015-03-18 01:48:29 | [diff] [blame] | 586 | } |
| 587 | |
[email protected] | 42f1d782 | 2009-07-23 18:17:55 | [diff] [blame] | 588 | // When we run plugins in process, we actually run them on the render thread, |
| 589 | // which means that we need to make the render thread pump UI events. |
haraken | 53f081d | 2014-11-11 01:03:40 | [diff] [blame] | 590 | RenderThreadImpl::RenderThreadImpl( |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 591 | std::unique_ptr<base::MessageLoop> main_message_loop, |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 592 | std::unique_ptr<blink::scheduler::RendererScheduler> scheduler) |
rockot | cef3827 | 2016-07-15 22:47:47 | [diff] [blame] | 593 | : ChildThreadImpl(Options::Builder() |
ben | d32292b | 2016-10-07 00:21:58 | [diff] [blame] | 594 | .AutoStartServiceManagerConnection(false) |
ben | 5be0b913 | 2016-08-03 00:17:18 | [diff] [blame] | 595 | .ConnectToBrowser(true) |
rockot | cef3827 | 2016-07-15 22:47:47 | [diff] [blame] | 596 | .Build()), |
dcheng | 07945f63 | 2015-12-26 07:59:32 | [diff] [blame] | 597 | renderer_scheduler_(std::move(scheduler)), |
| 598 | main_message_loop_(std::move(main_message_loop)), |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 599 | categorized_worker_pool_(new CategorizedWorkerPool()), |
wjmaclean | 1d97062 | 2017-01-21 22:28:24 | [diff] [blame] | 600 | is_scroll_animator_enabled_(false), |
fsamuel | 4c5c8714 | 2017-03-14 03:14:26 | [diff] [blame] | 601 | is_surface_synchronization_enabled_(false), |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 602 | renderer_binding_(this), |
| 603 | field_trial_syncer_(this) { |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 604 | scoped_refptr<base::SingleThreadTaskRunner> test_task_counter; |
staraz | 067f5824 | 2016-11-07 21:06:41 | [diff] [blame] | 605 | DCHECK(base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 606 | switches::kRendererClientId)); |
| 607 | base::StringToInt(base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
| 608 | switches::kRendererClientId), |
| 609 | &client_id_); |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 610 | Init(test_task_counter); |
haraken | 53f081d | 2014-11-11 01:03:40 | [diff] [blame] | 611 | } |
| 612 | |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 613 | void RenderThreadImpl::Init( |
rockot | 97a8683 | 2016-12-10 04:53:06 | [diff] [blame] | 614 | const scoped_refptr<base::SingleThreadTaskRunner>& resource_task_queue) { |
fdoray | f6d8624 | 2015-10-08 16:49:53 | [diff] [blame] | 615 | TRACE_EVENT0("startup", "RenderThreadImpl::Init"); |
[email protected] | a872ea1f | 2010-08-11 04:45:33 | [diff] [blame] | 616 | |
ssid | b2e3ece | 2015-02-09 16:02:20 | [diff] [blame] | 617 | base::trace_event::TraceLog::GetInstance()->SetThreadSortIndex( |
[email protected] | 91a2aea | 2013-07-08 23:14:39 | [diff] [blame] | 618 | base::PlatformThread::CurrentId(), |
| 619 | kTraceEventRendererMainThreadSortIndex); |
| 620 | |
thakis | 18e42641 | 2017-03-15 12:06:37 | [diff] [blame] | 621 | #if BUILDFLAG(USE_EXTERNAL_POPUP_MENU) |
sievers | 9dff7205 | 2015-11-16 18:35:57 | [diff] [blame] | 622 | // On Mac and Android Java UI, the select popups are rendered by the browser. |
[email protected] | 180ef24 | 2013-11-07 06:50:46 | [diff] [blame] | 623 | blink::WebView::setUseExternalPopupMenus(true); |
[email protected] | 53c607c | 2011-03-21 23:19:04 | [diff] [blame] | 624 | #endif |
| 625 | |
[email protected] | 94f9a0f68 | 2009-06-15 18:30:30 | [diff] [blame] | 626 | lazy_tls.Pointer()->Set(this); |
[email protected] | b3e83de | 2012-02-07 03:33:28 | [diff] [blame] | 627 | |
[email protected] | 06c694d | 2012-02-01 22:26:16 | [diff] [blame] | 628 | // Register this object as the main thread. |
| 629 | ChildProcess::current()->set_main_thread(this); |
| 630 | |
sadrul | 62c3113 | 2016-08-11 04:13:17 | [diff] [blame] | 631 | if (IsRunningInMash()) { |
sadrul | 04cfa89 | 2016-12-09 17:53:49 | [diff] [blame] | 632 | gpu_ = ui::Gpu::Create(GetServiceManagerConnection()->GetConnector(), |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 633 | GetIOTaskRunner()); |
sadrul | 5354659 | 2016-12-17 01:44:21 | [diff] [blame] | 634 | } else { |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 635 | gpu_ = ui::Gpu::Create(GetRemoteInterfaces(), GetIOTaskRunner()); |
sadrul | 62c3113 | 2016-08-11 04:13:17 | [diff] [blame] | 636 | } |
penghuang | e1d8651 | 2016-07-08 18:15:00 | [diff] [blame] | 637 | |
rockot | a628d0b | 2017-02-09 08:40:15 | [diff] [blame] | 638 | channel()->GetThreadSafeRemoteAssociatedInterface( |
| 639 | &thread_safe_render_message_filter_); |
jcivelli | 0f21bd5 | 2016-12-07 21:21:33 | [diff] [blame] | 640 | shared_bitmap_manager_.reset( |
| 641 | new ChildSharedBitmapManager(thread_safe_render_message_filter_)); |
| 642 | |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 643 | InitializeWebKit(resource_task_queue); |
| 644 | |
[email protected] | 31f8713 | 2010-04-21 23:36:21 | [diff] [blame] | 645 | // In single process the single process is all there is. |
[email protected] | 26e8232 | 2014-01-20 14:18:22 | [diff] [blame] | 646 | webkit_shared_timer_suspended_ = false; |
[email protected] | bee16aab | 2009-08-26 15:55:03 | [diff] [blame] | 647 | widget_count_ = 0; |
| 648 | hidden_widget_count_ = 0; |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 649 | idle_notification_delay_in_ms_ = kInitialIdleHandlerDelayMs; |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 650 | idle_notifications_to_skip_ = 0; |
[email protected] | 8d86fce | 2009-02-26 23:37:55 | [diff] [blame] | 651 | |
[email protected] | d5b2fdf | 2013-06-05 09:36:55 | [diff] [blame] | 652 | appcache_dispatcher_.reset( |
[email protected] | a8cb3b73b | 2013-08-12 05:50:50 | [diff] [blame] | 653 | new AppCacheDispatcher(Get(), new AppCacheFrontendImpl())); |
[email protected] | 1910fe8 | 2012-05-10 00:04:10 | [diff] [blame] | 654 | dom_storage_dispatcher_.reset(new DomStorageDispatcher()); |
reillyg | 39fb466 | 2016-11-22 20:27:17 | [diff] [blame] | 655 | main_thread_indexed_db_dispatcher_.reset(new IndexedDBDispatcher()); |
jsbell | abadb9b | 2015-03-23 21:03:44 | [diff] [blame] | 656 | main_thread_cache_storage_dispatcher_.reset( |
jsbell | 279efb4 | 2015-03-31 17:02:46 | [diff] [blame] | 657 | new CacheStorageDispatcher(thread_safe_sender())); |
[email protected] | 7670d433 | 2013-11-29 04:35:00 | [diff] [blame] | 658 | embedded_worker_dispatcher_.reset(new EmbeddedWorkerDispatcher()); |
[email protected] | dd924193 | 2010-02-24 19:23:13 | [diff] [blame] | 659 | |
jdduke | 94ae1f3 | 2015-02-05 06:27:13 | [diff] [blame] | 660 | // Note: This may reorder messages from the ResourceDispatcher with respect to |
| 661 | // other subsystems. |
| 662 | resource_dispatch_throttler_.reset(new ResourceDispatchThrottler( |
| 663 | static_cast<RenderThread*>(this), renderer_scheduler_.get(), |
| 664 | base::TimeDelta::FromSecondsD(kThrottledResourceRequestFlushPeriodS), |
| 665 | kMaxResourceRequestsPerFlushWhenThrottled)); |
| 666 | resource_dispatcher()->set_message_sender(resource_dispatch_throttler_.get()); |
| 667 | |
penghuang | e1d8651 | 2016-07-08 18:15:00 | [diff] [blame] | 668 | media_stream_center_ = nullptr; |
[email protected] | d8cd837 | 2012-03-09 10:49:51 | [diff] [blame] | 669 | |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 670 | blob_message_filter_ = new BlobMessageFilter(GetFileThreadTaskRunner()); |
dmurph | 1fb9848 | 2016-03-30 21:14:26 | [diff] [blame] | 671 | AddFilter(blob_message_filter_.get()); |
[email protected] | 017022b | 2009-07-27 23:06:34 | [diff] [blame] | 672 | db_message_filter_ = new DBMessageFilter(); |
| 673 | AddFilter(db_message_filter_.get()); |
[email protected] | dd924193 | 2010-02-24 19:23:13 | [diff] [blame] | 674 | |
[email protected] | 4504807 | 2014-01-14 13:51:29 | [diff] [blame] | 675 | vc_manager_.reset(new VideoCaptureImplManager()); |
[email protected] | c9c43a0 | 2013-12-17 08:59:54 | [diff] [blame] | 676 | |
fsamuel | 6c1dfeb | 2014-12-18 19:21:33 | [diff] [blame] | 677 | browser_plugin_manager_.reset(new BrowserPluginManager()); |
| 678 | AddObserver(browser_plugin_manager_.get()); |
| 679 | |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 680 | #if BUILDFLAG(ENABLE_WEBRTC) |
[email protected] | af08997 | 2013-01-10 04:04:40 | [diff] [blame] | 681 | peer_connection_tracker_.reset(new PeerConnectionTracker()); |
| 682 | AddObserver(peer_connection_tracker_.get()); |
| 683 | |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 684 | p2p_socket_dispatcher_ = new P2PSocketDispatcher(GetIOTaskRunner().get()); |
[email protected] | fc72bb1 | 2013-06-02 21:13:46 | [diff] [blame] | 685 | AddFilter(p2p_socket_dispatcher_.get()); |
[email protected] | 921480f6 | 2013-07-20 03:42:57 | [diff] [blame] | 686 | |
ivoc | add54f0d | 2015-12-18 23:17:05 | [diff] [blame] | 687 | peer_connection_factory_.reset( |
| 688 | new PeerConnectionDependencyFactory(p2p_socket_dispatcher_.get())); |
| 689 | |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 690 | aec_dump_message_filter_ = new AecDumpMessageFilter( |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 691 | GetIOTaskRunner(), message_loop()->task_runner()); |
ivoc | add54f0d | 2015-12-18 23:17:05 | [diff] [blame] | 692 | |
[email protected] | da9f30a | 2014-06-18 19:39:04 | [diff] [blame] | 693 | AddFilter(aec_dump_message_filter_.get()); |
| 694 | |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 695 | #endif // BUILDFLAG(ENABLE_WEBRTC) |
[email protected] | e25f4d7 | 2011-06-08 20:58:46 | [diff] [blame] | 696 | |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 697 | audio_input_message_filter_ = new AudioInputMessageFilter(GetIOTaskRunner()); |
[email protected] | f7eb0a39 | 2011-07-12 10:19:51 | [diff] [blame] | 698 | AddFilter(audio_input_message_filter_.get()); |
| 699 | |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 700 | audio_message_filter_ = new AudioMessageFilter(GetIOTaskRunner()); |
[email protected] | f7eb0a39 | 2011-07-12 10:19:51 | [diff] [blame] | 701 | AddFilter(audio_message_filter_.get()); |
| 702 | |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 703 | midi_message_filter_ = new MidiMessageFilter(GetIOTaskRunner()); |
[email protected] | a987515 | 2013-06-22 04:03:03 | [diff] [blame] | 704 | AddFilter(midi_message_filter_.get()); |
| 705 | |
jsbell | abadb9b | 2015-03-23 21:03:44 | [diff] [blame] | 706 | AddFilter((new CacheStorageMessageFilter(thread_safe_sender()))->GetFilter()); |
| 707 | |
kinuko | 5af4ffe | 2015-06-09 03:38:46 | [diff] [blame] | 708 | AddFilter((new ServiceWorkerContextMessageFilter())->GetFilter()); |
[email protected] | ddbb5334 | 2014-01-06 10:59:47 | [diff] [blame] | 709 | |
sadrul | 943e3b3 | 2016-08-04 18:22:59 | [diff] [blame] | 710 | #if defined(USE_AURA) |
fsamuel | 098eade | 2017-03-21 18:06:14 | [diff] [blame] | 711 | if (IsRunningInMash()) { |
ben | d32292b | 2016-10-07 00:21:58 | [diff] [blame] | 712 | CreateRenderWidgetWindowTreeClientFactory(GetServiceManagerConnection()); |
rockot | cef3827 | 2016-07-15 22:47:47 | [diff] [blame] | 713 | } |
| 714 | #endif |
| 715 | |
| 716 | // Must be called before RenderThreadStarted() below. |
ben | d32292b | 2016-10-07 00:21:58 | [diff] [blame] | 717 | StartServiceManagerConnection(); |
rockot | cef3827 | 2016-07-15 22:47:47 | [diff] [blame] | 718 | |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 719 | GetContentClient()->renderer()->RenderThreadStarted(); |
[email protected] | 6779aa1 | 2011-03-29 17:32:24 | [diff] [blame] | 720 | |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 721 | field_trial_syncer_.InitFieldTrialObserving( |
| 722 | *base::CommandLine::ForCurrentProcess(), switches::kSingleProcess); |
| 723 | |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 724 | GetAssociatedInterfaceRegistry()->AddInterface( |
| 725 | base::Bind(&RenderThreadImpl::OnRendererInterfaceRequest, |
| 726 | base::Unretained(this))); |
| 727 | |
[email protected] | b48c53ad | 2014-02-05 21:59:18 | [diff] [blame] | 728 | InitSkiaEventTracer(); |
ssid | 59c96916 | 2015-07-28 13:02:58 | [diff] [blame] | 729 | base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider( |
primiano | 186d6bfe | 2015-10-30 13:21:40 | [diff] [blame] | 730 | skia::SkiaMemoryDumpProvider::GetInstance(), "Skia", nullptr); |
[email protected] | b48c53ad | 2014-02-05 21:59:18 | [diff] [blame] | 731 | |
avi | 83883c8 | 2014-12-23 00:08:49 | [diff] [blame] | 732 | const base::CommandLine& command_line = |
| 733 | *base::CommandLine::ForCurrentProcess(); |
[email protected] | e54ab49 | 2012-06-12 19:40:01 | [diff] [blame] | 734 | |
ochang | dd89a1e | 2016-06-08 16:39:01 | [diff] [blame] | 735 | #if defined(ENABLE_IPC_FUZZER) |
| 736 | if (command_line.HasSwitch(switches::kIpcDumpDirectory)) { |
| 737 | base::FilePath dump_directory = |
| 738 | command_line.GetSwitchValuePath(switches::kIpcDumpDirectory); |
| 739 | IPC::ChannelProxy::OutgoingMessageFilter* filter = |
| 740 | LoadExternalIPCDumper(dump_directory); |
| 741 | GetChannel()->set_outgoing_message_filter(filter); |
| 742 | } |
| 743 | #endif |
| 744 | |
jbroman | 0d30216 | 2015-09-05 05:46:23 | [diff] [blame] | 745 | cc::SetClientNameForMetrics("Renderer"); |
loyso | a6edaaff | 2015-05-25 03:26:44 | [diff] [blame] | 746 | |
loyso | 65c93c60 | 2015-08-11 05:15:57 | [diff] [blame] | 747 | is_threaded_animation_enabled_ = |
| 748 | !command_line.HasSwitch(cc::switches::kDisableThreadedAnimation); |
| 749 | |
fsamuel | 4c5c8714 | 2017-03-14 03:14:26 | [diff] [blame] | 750 | is_surface_synchronization_enabled_ = |
| 751 | command_line.HasSwitch(cc::switches::kEnableSurfaceSynchronization); |
| 752 | |
reveman | 91a0a87 | 2014-11-04 03:40:32 | [diff] [blame] | 753 | is_zero_copy_enabled_ = command_line.HasSwitch(switches::kEnableZeroCopy); |
ericrk | 1d17f75 | 2015-10-20 03:03:07 | [diff] [blame] | 754 | is_partial_raster_enabled_ = |
dongseong.hwang | 23db47f | 2016-03-08 07:50:02 | [diff] [blame] | 755 | !command_line.HasSwitch(switches::kDisablePartialRaster); |
ccameron | c7fcd13 | 2015-11-03 20:14:31 | [diff] [blame] | 756 | is_gpu_memory_buffer_compositor_resources_enabled_ = command_line.HasSwitch( |
| 757 | switches::kEnableGpuMemoryBufferCompositorResources); |
[email protected] | a23530d | 2014-03-11 06:04:14 | [diff] [blame] | 758 | |
jam | e1f453c | 2016-03-21 15:51:34 | [diff] [blame] | 759 | #if defined(OS_MACOSX) |
thakis | 114a1ef | 2016-04-26 16:02:59 | [diff] [blame] | 760 | base::ScopedCFTypeRef<CFStringRef> key( |
| 761 | base::SysUTF8ToCFStringRef("NSScrollViewRubberbanding")); |
| 762 | Boolean key_exists = false; |
| 763 | Boolean value = CFPreferencesGetAppBooleanValue( |
| 764 | key, kCFPreferencesCurrentApplication, &key_exists); |
| 765 | is_elastic_overscroll_enabled_ = !key_exists || value; |
ccameron | a764475 | 2014-12-30 01:16:31 | [diff] [blame] | 766 | #else |
| 767 | is_elastic_overscroll_enabled_ = false; |
| 768 | #endif |
| 769 | |
danakj | e6eb185c | 2015-02-27 23:52:05 | [diff] [blame] | 770 | std::string image_texture_target_string = |
dcastagna | 7f2f719 | 2015-06-16 18:44:35 | [diff] [blame] | 771 | command_line.GetSwitchValueASCII(switches::kContentImageTextureTarget); |
ericrk | 9151705c | 2016-07-26 19:53:16 | [diff] [blame] | 772 | buffer_to_texture_target_map_ = |
| 773 | cc::StringToBufferToTextureTargetMap(image_texture_target_string); |
reveman | 44b807f1 | 2014-11-26 02:44:50 | [diff] [blame] | 774 | |
[email protected] | a23530d | 2014-03-11 06:04:14 | [diff] [blame] | 775 | if (command_line.HasSwitch(switches::kDisableLCDText)) { |
| 776 | is_lcd_text_enabled_ = false; |
| 777 | } else if (command_line.HasSwitch(switches::kEnableLCDText)) { |
| 778 | is_lcd_text_enabled_ = true; |
| 779 | } else { |
| 780 | #if defined(OS_ANDROID) |
| 781 | is_lcd_text_enabled_ = false; |
| 782 | #else |
| 783 | is_lcd_text_enabled_ = true; |
| 784 | #endif |
| 785 | } |
| 786 | |
[email protected] | b8d82c2 | 2014-03-31 20:12:46 | [diff] [blame] | 787 | is_gpu_rasterization_forced_ = |
| 788 | command_line.HasSwitch(switches::kForceGpuRasterization); |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 789 | is_async_worker_context_enabled_ = |
| 790 | command_line.HasSwitch(switches::kEnableGpuAsyncWorkerContext); |
[email protected] | a23530d | 2014-03-11 06:04:14 | [diff] [blame] | 791 | |
senorblanco | b60ba95 | 2015-01-27 19:12:36 | [diff] [blame] | 792 | if (command_line.HasSwitch(switches::kGpuRasterizationMSAASampleCount)) { |
| 793 | std::string string_value = command_line.GetSwitchValueASCII( |
| 794 | switches::kGpuRasterizationMSAASampleCount); |
| 795 | bool parsed_msaa_sample_count = |
| 796 | base::StringToInt(string_value, &gpu_rasterization_msaa_sample_count_); |
| 797 | DCHECK(parsed_msaa_sample_count) << string_value; |
| 798 | DCHECK_GE(gpu_rasterization_msaa_sample_count_, 0); |
| 799 | } else { |
senorblanco | 2a5b0e1 | 2015-08-14 21:55:37 | [diff] [blame] | 800 | gpu_rasterization_msaa_sample_count_ = -1; |
senorblanco | b60ba95 | 2015-01-27 19:12:36 | [diff] [blame] | 801 | } |
| 802 | |
[email protected] | b242b14 | 2014-05-07 14:48:49 | [diff] [blame] | 803 | if (command_line.HasSwitch(switches::kDisableDistanceFieldText)) { |
| 804 | is_distance_field_text_enabled_ = false; |
| 805 | } else if (command_line.HasSwitch(switches::kEnableDistanceFieldText)) { |
| 806 | is_distance_field_text_enabled_ = true; |
| 807 | } else { |
| 808 | is_distance_field_text_enabled_ = false; |
| 809 | } |
| 810 | |
[email protected] | 433df47 | 2012-03-07 20:33:39 | [diff] [blame] | 811 | // Note that under Linux, the media library will normally already have |
| 812 | // been initialized by the Zygote before this instance became a Renderer. |
chcunningham | fd11b3c | 2015-06-09 02:09:42 | [diff] [blame] | 813 | media::InitializeMediaLibrary(); |
[email protected] | 433df47 | 2012-03-07 20:33:39 | [diff] [blame] | 814 | |
dalecurtis | 88af393 | 2016-02-20 00:12:20 | [diff] [blame] | 815 | #if defined(OS_ANDROID) |
| 816 | if (!command_line.HasSwitch(switches::kDisableAcceleratedVideoDecode) && |
| 817 | media::MediaCodecUtil::IsMediaCodecAvailable()) { |
| 818 | media::EnablePlatformDecoderSupport(); |
| 819 | } |
| 820 | #endif |
| 821 | |
hubbe | e6c6eb34 | 2017-03-15 20:34:11 | [diff] [blame] | 822 | if (base::CommandLine::ForCurrentProcess()->HasSwitch(switches::kEnableHDR) || |
chcunningham | 9a285ed | 2017-03-08 21:48:56 | [diff] [blame] | 823 | base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 824 | switches::kEnableNewVp9CodecString)) { |
| 825 | media::EnableNewVp9CodecStringSupport(); |
| 826 | } |
| 827 | |
[email protected] | 5071cb2 | 2013-07-10 02:19:06 | [diff] [blame] | 828 | memory_pressure_listener_.reset(new base::MemoryPressureListener( |
hong.zheng | b28b533 | 2016-05-11 02:33:39 | [diff] [blame] | 829 | base::Bind(&RenderThreadImpl::OnMemoryPressure, base::Unretained(this)), |
| 830 | base::Bind(&RenderThreadImpl::OnSyncMemoryPressure, |
| 831 | base::Unretained(this)))); |
[email protected] | 5071cb2 | 2013-07-10 02:19:06 | [diff] [blame] | 832 | |
bashi | a626404 | 2016-09-15 04:49:51 | [diff] [blame] | 833 | if (base::FeatureList::IsEnabled(features::kMemoryCoordinator)) { |
bashi | 58dd2fa | 2016-10-17 00:01:07 | [diff] [blame] | 834 | // Disable MemoryPressureListener when memory coordinator is enabled. |
| 835 | base::MemoryPressureListener::SetNotificationsSuppressed(true); |
| 836 | |
bashi | 77f19b3 | 2016-07-19 11:19:43 | [diff] [blame] | 837 | // TODO(bashi): Revisit how to manage the lifetime of |
| 838 | // ChildMemoryCoordinatorImpl. |
| 839 | // https://codereview.chromium.org/2094583002/#msg52 |
bashi | a626404 | 2016-09-15 04:49:51 | [diff] [blame] | 840 | mojom::MemoryCoordinatorHandlePtr parent_coordinator; |
blundell | e0a9f158 | 2016-12-20 11:23:32 | [diff] [blame] | 841 | GetRemoteInterfaces()->GetInterface(mojo::MakeRequest(&parent_coordinator)); |
bashi | a626404 | 2016-09-15 04:49:51 | [diff] [blame] | 842 | memory_coordinator_ = CreateChildMemoryCoordinator( |
bashi | c4b4afcb | 2016-08-23 06:37:52 | [diff] [blame] | 843 | std::move(parent_coordinator), this); |
bashi | 77f19b3 | 2016-07-19 11:19:43 | [diff] [blame] | 844 | } |
| 845 | |
danakj | 16275d4c | 2015-06-11 19:23:51 | [diff] [blame] | 846 | int num_raster_threads = 0; |
| 847 | std::string string_value = |
| 848 | command_line.GetSwitchValueASCII(switches::kNumRasterThreads); |
| 849 | bool parsed_num_raster_threads = |
| 850 | base::StringToInt(string_value, &num_raster_threads); |
| 851 | DCHECK(parsed_num_raster_threads) << string_value; |
| 852 | DCHECK_GT(num_raster_threads, 0); |
vmiura | 78b6928 | 2015-02-14 00:01:17 | [diff] [blame] | 853 | |
vmpstr | 6c0b511 | 2016-04-25 22:12:14 | [diff] [blame] | 854 | // TODO(vmpstr): If the flag sticks, we should clean it up and always have |
| 855 | // image decode tasks. |
vmpstr | 9dd810a | 2016-01-19 21:16:10 | [diff] [blame] | 856 | are_image_decode_tasks_enabled_ = true; |
halliwell | 4b3deee | 2014-12-19 19:57:49 | [diff] [blame] | 857 | |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 858 | categorized_worker_pool_->Start(num_raster_threads); |
[email protected] | 1e1d1e1 | 2014-01-17 16:14:29 | [diff] [blame] | 859 | |
penghuang | 342762b | 2016-12-02 21:04:58 | [diff] [blame] | 860 | discardable_memory::mojom::DiscardableSharedMemoryManagerPtr manager_ptr; |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 861 | if (IsRunningInMash()) { |
| 862 | #if defined(USE_AURA) |
ben | bd3c248 | 2017-01-07 05:48:21 | [diff] [blame] | 863 | GetServiceManagerConnection()->GetConnector()->BindInterface( |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 864 | ui::mojom::kServiceName, &manager_ptr); |
| 865 | #else |
| 866 | NOTREACHED(); |
| 867 | #endif |
| 868 | } else { |
| 869 | ChildThread::Get()->GetRemoteInterfaces()->GetInterface( |
blundell | e0a9f158 | 2016-12-20 11:23:32 | [diff] [blame] | 870 | mojo::MakeRequest(&manager_ptr)); |
penghuang | d6843e4 | 2016-12-17 13:57:20 | [diff] [blame] | 871 | } |
| 872 | |
penghuang | 342762b | 2016-12-02 21:04:58 | [diff] [blame] | 873 | discardable_shared_memory_manager_ = base::MakeUnique< |
| 874 | discardable_memory::ClientDiscardableSharedMemoryManager>( |
| 875 | std::move(manager_ptr), GetIOTaskRunner()); |
| 876 | |
boliu | 9760e21 | 2015-06-23 22:49:06 | [diff] [blame] | 877 | // TODO(boliu): In single process, browser main loop should set up the |
| 878 | // discardable memory manager, and should skip this if kSingleProcess. |
| 879 | // See crbug.com/503724. |
| 880 | base::DiscardableMemoryAllocator::SetInstance( |
penghuang | 342762b | 2016-12-02 21:04:58 | [diff] [blame] | 881 | discardable_shared_memory_manager_.get()); |
reveman | cb5a66af | 2014-10-25 00:34:39 | [diff] [blame] | 882 | |
ben | d1dd50f5 | 2016-06-26 22:10:48 | [diff] [blame] | 883 | GetContentClient()->renderer()->ExposeInterfacesToBrowser( |
| 884 | GetInterfaceRegistry()); |
rockot | 229fb28e | 2016-06-16 04:46:16 | [diff] [blame] | 885 | |
shimazu | 5de409e4 | 2016-09-29 08:45:28 | [diff] [blame] | 886 | GetInterfaceRegistry()->AddInterface(base::Bind(&CreateFrameFactory)); |
shimazu | 5de409e4 | 2016-09-29 08:45:28 | [diff] [blame] | 887 | GetInterfaceRegistry()->AddInterface( |
| 888 | base::Bind(&EmbeddedWorkerInstanceClientImpl::Create, |
| 889 | base::Unretained(embedded_worker_dispatcher_.get()))); |
fsamuel | 6c6da023 | 2015-11-26 05:13:46 | [diff] [blame] | 890 | |
ben | d1dd50f5 | 2016-06-26 22:10:48 | [diff] [blame] | 891 | GetRemoteInterfaces()->GetInterface( |
blundell | e0a9f158 | 2016-12-20 11:23:32 | [diff] [blame] | 892 | mojo::MakeRequest(&storage_partition_service_)); |
hajimehoshi | 6909327 | 2016-05-13 08:30:58 | [diff] [blame] | 893 | |
reveman | 7b97c32 | 2016-09-20 02:10:58 | [diff] [blame] | 894 | #if defined(OS_LINUX) |
| 895 | ChildProcess::current()->SetIOThreadPriority(base::ThreadPriority::DISPLAY); |
| 896 | ChildThreadImpl::current()->SetThreadPriority( |
battre | 40937c0 | 2017-02-07 17:40:55 | [diff] [blame] | 897 | categorized_worker_pool_->background_worker_thread_id(), |
reveman | 7b97c32 | 2016-09-20 02:10:58 | [diff] [blame] | 898 | base::ThreadPriority::BACKGROUND); |
| 899 | #endif |
| 900 | |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 901 | record_purge_suspend_metric_closure_.Reset(base::Bind( |
| 902 | &RenderThreadImpl::RecordPurgeAndSuspendMetrics, base::Unretained(this))); |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 903 | record_purge_suspend_growth_metric_closure_.Reset( |
| 904 | base::Bind(&RenderThreadImpl::RecordPurgeAndSuspendMemoryGrowthMetrics, |
| 905 | base::Unretained(this))); |
tasak | b95dbb50c | 2017-02-08 18:07:50 | [diff] [blame] | 906 | needs_to_record_first_active_paint_ = false; |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 907 | |
| 908 | base::MemoryCoordinatorClientRegistry::GetInstance()->Register(this); |
fdoray | 50a3834 | 2016-11-21 20:46:04 | [diff] [blame] | 909 | |
| 910 | // If this renderer doesn't run inside the browser process, enable |
| 911 | // SequencedWorkerPool. Otherwise, it should already have been enabled. |
| 912 | // TODO(fdoray): Remove this once the SequencedWorkerPool to TaskScheduler |
| 913 | // redirection experiment concludes https://crbug.com/622400. |
| 914 | if (!command_line.HasSwitch(switches::kSingleProcess)) |
| 915 | base::SequencedWorkerPool::EnableForProcess(); |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 916 | } |
| 917 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 918 | RenderThreadImpl::~RenderThreadImpl() { |
[email protected] | ce79d851 | 2013-04-22 22:44:41 | [diff] [blame] | 919 | } |
| 920 | |
| 921 | void RenderThreadImpl::Shutdown() { |
haraken | bbfdd9f0 | 2017-01-12 07:14:04 | [diff] [blame] | 922 | // In a multi-process mode, we immediately exit the renderer. |
| 923 | // Historically we had a graceful shutdown sequence here but it was |
| 924 | // 1) a waste of performance and 2) a source of lots of complicated |
| 925 | // crashes caused by shutdown ordering. Immediate exit eliminates |
| 926 | // those problems. |
cbruni | a3f655b | 2017-03-20 11:36:41 | [diff] [blame] | 927 | |
| 928 | // Give the V8 isolate a chance to dump internal stats useful for performance |
| 929 | // evaluation and debugging. |
| 930 | blink::mainThreadIsolate()->DumpAndResetStats(); |
| 931 | |
haraken | bbfdd9f0 | 2017-01-12 07:14:04 | [diff] [blame] | 932 | // In a single-process mode, we cannot call _exit(0) in Shutdown() because |
| 933 | // it will exit the process before the browser side is ready to exit. |
| 934 | if (!base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 935 | switches::kSingleProcess)) |
haraken | 940efb9 | 2017-02-08 05:58:15 | [diff] [blame] | 936 | base::Process::TerminateCurrentProcessImmediately(0); |
haraken | bbfdd9f0 | 2017-01-12 07:14:04 | [diff] [blame] | 937 | } |
[email protected] | 1223d6ef | 2011-03-28 16:47:50 | [diff] [blame] | 938 | |
haraken | bbfdd9f0 | 2017-01-12 07:14:04 | [diff] [blame] | 939 | bool RenderThreadImpl::ShouldBeDestroyed() { |
| 940 | DCHECK(base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 941 | switches::kSingleProcess)); |
| 942 | // In a single-process mode, it is unsafe to destruct this renderer thread |
| 943 | // because we haven't run the shutdown sequence. Hence we leak the render |
| 944 | // thread. |
| 945 | // |
| 946 | // In this case, we also need to disable at-exit callbacks because some of |
| 947 | // the at-exit callbacks are expected to run after the renderer thread |
| 948 | // has been destructed. |
| 949 | base::AtExitManager::DisableAllAtExitManagers(); |
| 950 | return false; |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 951 | } |
| 952 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 953 | bool RenderThreadImpl::Send(IPC::Message* msg) { |
changwan | 6ed4d43 | 2016-05-19 22:03:54 | [diff] [blame] | 954 | // There are cases where we want to pump asynchronous messages while waiting |
| 955 | // synchronously for the replies to the message to be sent here. However, this |
| 956 | // may create an opportunity for re-entrancy into WebKit and other subsystems, |
| 957 | // so we need to take care to disable callbacks, timers, and pending network |
| 958 | // loads that could trigger such callbacks. |
[email protected] | 38b59290 | 2011-04-16 02:08:42 | [diff] [blame] | 959 | bool pumping_events = false; |
[email protected] | 80fc08c5 | 2010-03-09 07:43:50 | [diff] [blame] | 960 | if (msg->is_sync()) { |
| 961 | if (msg->is_caller_pumping_messages()) { |
| 962 | pumping_events = true; |
[email protected] | 80fc08c5 | 2010-03-09 07:43:50 | [diff] [blame] | 963 | } |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 964 | } |
| 965 | |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 966 | if (pumping_events) { |
jdduke | d73ae541 | 2015-05-11 20:07:16 | [diff] [blame] | 967 | renderer_scheduler_->SuspendTimerQueue(); |
changwan | 6ed4d43 | 2016-05-19 22:03:54 | [diff] [blame] | 968 | WebView::willEnterModalLoop(); |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 969 | } |
| 970 | |
jam | 8a021512a | 2015-02-03 18:16:08 | [diff] [blame] | 971 | bool rv = ChildThreadImpl::Send(msg); |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 972 | |
| 973 | if (pumping_events) { |
changwan | 6ed4d43 | 2016-05-19 22:03:54 | [diff] [blame] | 974 | WebView::didExitModalLoop(); |
jdduke | d73ae541 | 2015-05-11 20:07:16 | [diff] [blame] | 975 | renderer_scheduler_->ResumeTimerQueue(); |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 976 | } |
| 977 | |
| 978 | return rv; |
| 979 | } |
| 980 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 981 | IPC::SyncChannel* RenderThreadImpl::GetChannel() { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 982 | return channel(); |
| 983 | } |
| 984 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 985 | std::string RenderThreadImpl::GetLocale() { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 986 | // The browser process should have passed the locale to the renderer via the |
[email protected] | dfd5365 | 2012-10-25 00:20:02 | [diff] [blame] | 987 | // --lang command line flag. |
avi | 83883c8 | 2014-12-23 00:08:49 | [diff] [blame] | 988 | const base::CommandLine& parsed_command_line = |
| 989 | *base::CommandLine::ForCurrentProcess(); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 990 | const std::string& lang = |
| 991 | parsed_command_line.GetSwitchValueASCII(switches::kLang); |
[email protected] | dfd5365 | 2012-10-25 00:20:02 | [diff] [blame] | 992 | DCHECK(!lang.empty()); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 993 | return lang; |
| 994 | } |
| 995 | |
[email protected] | 07bb633 | 2012-01-21 01:07:57 | [diff] [blame] | 996 | IPC::SyncMessageFilter* RenderThreadImpl::GetSyncMessageFilter() { |
| 997 | return sync_message_filter(); |
| 998 | } |
| 999 | |
skyostil | 12262cf | 2015-05-21 14:49:31 | [diff] [blame] | 1000 | scoped_refptr<base::SingleThreadTaskRunner> |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 1001 | RenderThreadImpl::GetIOTaskRunner() { |
skyostil | 12262cf | 2015-05-21 14:49:31 | [diff] [blame] | 1002 | return ChildProcess::current()->io_task_runner(); |
[email protected] | 96191d5 | 2012-05-17 01:37:11 | [diff] [blame] | 1003 | } |
| 1004 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1005 | void RenderThreadImpl::AddRoute(int32_t routing_id, IPC::Listener* listener) { |
jam | 8a021512a | 2015-02-03 18:16:08 | [diff] [blame] | 1006 | ChildThreadImpl::GetRouter()->AddRoute(routing_id, listener); |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1007 | auto it = pending_frame_creates_.find(routing_id); |
| 1008 | if (it == pending_frame_creates_.end()) |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 1009 | return; |
| 1010 | |
| 1011 | RenderFrameImpl* frame = RenderFrameImpl::FromRoutingID(routing_id); |
| 1012 | if (!frame) |
| 1013 | return; |
| 1014 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1015 | scoped_refptr<PendingFrameCreate> create(it->second); |
dominickn | 6c1f1cf | 2016-12-20 06:13:33 | [diff] [blame] | 1016 | frame->BindFrame(it->second->TakeFrameRequest(), it->second->TakeFrameHost()); |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1017 | pending_frame_creates_.erase(it); |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 1018 | } |
| 1019 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1020 | void RenderThreadImpl::RemoveRoute(int32_t routing_id) { |
jam | 8a021512a | 2015-02-03 18:16:08 | [diff] [blame] | 1021 | ChildThreadImpl::GetRouter()->RemoveRoute(routing_id); |
[email protected] | c1f50aa | 2010-02-18 03:46:57 | [diff] [blame] | 1022 | } |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 1023 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1024 | void RenderThreadImpl::AddEmbeddedWorkerRoute(int32_t routing_id, |
[email protected] | a620b13 | 2014-04-30 22:39:17 | [diff] [blame] | 1025 | IPC::Listener* listener) { |
[email protected] | 48e52e4 | 2014-03-20 06:58:07 | [diff] [blame] | 1026 | AddRoute(routing_id, listener); |
| 1027 | if (devtools_agent_message_filter_.get()) { |
[email protected] | a620b13 | 2014-04-30 22:39:17 | [diff] [blame] | 1028 | devtools_agent_message_filter_->AddEmbeddedWorkerRouteOnMainThread( |
[email protected] | 48e52e4 | 2014-03-20 06:58:07 | [diff] [blame] | 1029 | routing_id); |
| 1030 | } |
| 1031 | } |
| 1032 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1033 | void RenderThreadImpl::RemoveEmbeddedWorkerRoute(int32_t routing_id) { |
[email protected] | 48e52e4 | 2014-03-20 06:58:07 | [diff] [blame] | 1034 | RemoveRoute(routing_id); |
| 1035 | if (devtools_agent_message_filter_.get()) { |
[email protected] | a620b13 | 2014-04-30 22:39:17 | [diff] [blame] | 1036 | devtools_agent_message_filter_->RemoveEmbeddedWorkerRouteOnMainThread( |
[email protected] | 48e52e4 | 2014-03-20 06:58:07 | [diff] [blame] | 1037 | routing_id); |
| 1038 | } |
| 1039 | } |
| 1040 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1041 | void RenderThreadImpl::RegisterPendingFrameCreate( |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 1042 | int routing_id, |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1043 | mojom::FrameRequest frame_request, |
| 1044 | mojom::FrameHostPtr frame_host) { |
| 1045 | std::pair<PendingFrameCreateMap::iterator, bool> result = |
| 1046 | pending_frame_creates_.insert(std::make_pair( |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 1047 | routing_id, |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 1048 | make_scoped_refptr(new PendingFrameCreate( |
| 1049 | routing_id, std::move(frame_request), std::move(frame_host))))); |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 1050 | CHECK(result.second) << "Inserting a duplicate item."; |
| 1051 | } |
| 1052 | |
leon.han | 06e5566 | 2016-03-26 17:19:42 | [diff] [blame] | 1053 | mojom::StoragePartitionService* RenderThreadImpl::GetStoragePartitionService() { |
jam | c912ca3 | 2016-02-24 20:17:31 | [diff] [blame] | 1054 | return storage_partition_service_.get(); |
| 1055 | } |
| 1056 | |
[email protected] | 77fc9b9 | 2011-10-15 16:20:37 | [diff] [blame] | 1057 | int RenderThreadImpl::GenerateRoutingID() { |
rockot | e261d211 | 2016-09-21 22:22:23 | [diff] [blame] | 1058 | int32_t routing_id = MSG_ROUTING_NONE; |
| 1059 | render_message_filter()->GenerateRoutingID(&routing_id); |
[email protected] | 77fc9b9 | 2011-10-15 16:20:37 | [diff] [blame] | 1060 | return routing_id; |
| 1061 | } |
| 1062 | |
[email protected] | 7412204 | 2014-04-25 00:07:30 | [diff] [blame] | 1063 | void RenderThreadImpl::AddFilter(IPC::MessageFilter* filter) { |
[email protected] | 42f1d782 | 2009-07-23 18:17:55 | [diff] [blame] | 1064 | channel()->AddFilter(filter); |
| 1065 | } |
| 1066 | |
[email protected] | 7412204 | 2014-04-25 00:07:30 | [diff] [blame] | 1067 | void RenderThreadImpl::RemoveFilter(IPC::MessageFilter* filter) { |
[email protected] | 42f1d782 | 2009-07-23 18:17:55 | [diff] [blame] | 1068 | channel()->RemoveFilter(filter); |
| 1069 | } |
| 1070 | |
tyoshino | 832a58a | 2016-04-18 08:14:08 | [diff] [blame] | 1071 | void RenderThreadImpl::AddObserver(RenderThreadObserver* observer) { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1072 | observers_.AddObserver(observer); |
nigeltao | 7cd8d558 | 2016-12-12 06:05:28 | [diff] [blame] | 1073 | observer->RegisterMojoInterfaces(&associated_interfaces_); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1074 | } |
| 1075 | |
tyoshino | 832a58a | 2016-04-18 08:14:08 | [diff] [blame] | 1076 | void RenderThreadImpl::RemoveObserver(RenderThreadObserver* observer) { |
nigeltao | 7cd8d558 | 2016-12-12 06:05:28 | [diff] [blame] | 1077 | observer->UnregisterMojoInterfaces(&associated_interfaces_); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1078 | observers_.RemoveObserver(observer); |
| 1079 | } |
| 1080 | |
[email protected] | 359dfa3 | 2011-10-12 01:10:15 | [diff] [blame] | 1081 | void RenderThreadImpl::SetResourceDispatcherDelegate( |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 1082 | ResourceDispatcherDelegate* delegate) { |
[email protected] | 359dfa3 | 2011-10-12 01:10:15 | [diff] [blame] | 1083 | resource_dispatcher()->set_delegate(delegate); |
| 1084 | } |
| 1085 | |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1086 | void RenderThreadImpl::InitializeCompositorThread() { |
boliu | 66024c6 | 2016-04-20 04:00:41 | [diff] [blame] | 1087 | base::Thread::Options options; |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1088 | #if defined(OS_ANDROID) |
boliu | 66024c6 | 2016-04-20 04:00:41 | [diff] [blame] | 1089 | options.priority = base::ThreadPriority::DISPLAY; |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1090 | #endif |
boliu | 66024c6 | 2016-04-20 04:00:41 | [diff] [blame] | 1091 | compositor_thread_.reset(new WebThreadForCompositor(options)); |
| 1092 | blink_platform_impl_->SetCompositorThread(compositor_thread_.get()); |
| 1093 | compositor_task_runner_ = compositor_thread_->GetTaskRunner(); |
| 1094 | compositor_task_runner_->PostTask( |
| 1095 | FROM_HERE, |
| 1096 | base::Bind(base::IgnoreResult(&ThreadRestrictions::SetIOAllowed), false)); |
reveman | 7b97c32 | 2016-09-20 02:10:58 | [diff] [blame] | 1097 | #if defined(OS_LINUX) |
| 1098 | ChildThreadImpl::current()->SetThreadPriority(compositor_thread_->threadId(), |
| 1099 | base::ThreadPriority::DISPLAY); |
| 1100 | #endif |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1101 | |
boliu | de5b75b | 2016-03-11 07:02:14 | [diff] [blame] | 1102 | SynchronousInputHandlerProxyClient* synchronous_input_handler_proxy_client = |
| 1103 | nullptr; |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1104 | #if defined(OS_ANDROID) |
boliu | 66024c6 | 2016-04-20 04:00:41 | [diff] [blame] | 1105 | if (GetContentClient()->UsingSynchronousCompositing()) { |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1106 | sync_compositor_message_filter_ = |
| 1107 | new SynchronousCompositorFilter(compositor_task_runner_); |
| 1108 | AddFilter(sync_compositor_message_filter_.get()); |
boliu | de5b75b | 2016-03-11 07:02:14 | [diff] [blame] | 1109 | synchronous_input_handler_proxy_client = |
| 1110 | sync_compositor_message_filter_.get(); |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1111 | } |
| 1112 | #endif |
boliu | b2768db | 2016-06-03 23:35:16 | [diff] [blame] | 1113 | scoped_refptr<InputEventFilter> compositor_input_event_filter( |
| 1114 | new InputEventFilter(main_input_callback_.callback(), |
| 1115 | main_thread_compositor_task_runner_, |
| 1116 | compositor_task_runner_)); |
| 1117 | InputHandlerManagerClient* input_handler_manager_client = |
| 1118 | compositor_input_event_filter.get(); |
| 1119 | input_event_filter_ = compositor_input_event_filter; |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1120 | input_handler_manager_.reset(new InputHandlerManager( |
| 1121 | compositor_task_runner_, input_handler_manager_client, |
boliu | de5b75b | 2016-03-11 07:02:14 | [diff] [blame] | 1122 | synchronous_input_handler_proxy_client, renderer_scheduler_.get())); |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1123 | } |
| 1124 | |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 1125 | void RenderThreadImpl::InitializeWebKit( |
rockot | 97a8683 | 2016-12-10 04:53:06 | [diff] [blame] | 1126 | const scoped_refptr<base::SingleThreadTaskRunner>& resource_task_queue) { |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 1127 | DCHECK(!blink_platform_impl_); |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 1128 | |
avi | 83883c8 | 2014-12-23 00:08:49 | [diff] [blame] | 1129 | const base::CommandLine& command_line = |
| 1130 | *base::CommandLine::ForCurrentProcess(); |
chunyang.dai | be874c5 | 2014-11-14 06:45:05 | [diff] [blame] | 1131 | |
| 1132 | #ifdef ENABLE_VTUNE_JIT_INTERFACE |
| 1133 | if (command_line.HasSwitch(switches::kEnableVtune)) |
| 1134 | gin::Debug::SetJitCodeEventHandler(vTune::GetVtuneCodeEventHandler()); |
| 1135 | #endif |
| 1136 | |
rmcilroy | 4073ae1 | 2015-01-08 13:08:10 | [diff] [blame] | 1137 | SetRuntimeFeaturesDefaultsAndUpdateFromArgs(command_line); |
hlopko | 852ffcf | 2016-09-16 16:50:59 | [diff] [blame] | 1138 | GetContentClient() |
| 1139 | ->renderer() |
| 1140 | ->SetRuntimeFeaturesDefaultsBeforeBlinkInitialization(); |
rmcilroy | 4073ae1 | 2015-01-08 13:08:10 | [diff] [blame] | 1141 | |
sammc | bebeb60 | 2016-04-06 06:42:55 | [diff] [blame] | 1142 | blink_platform_impl_.reset(new RendererBlinkPlatformImpl( |
bashi | dbaff8bb | 2017-02-16 05:16:15 | [diff] [blame] | 1143 | renderer_scheduler_.get(), GetRemoteInterfaces()->GetWeakPtr())); |
tfarina | 556a723 | 2014-10-05 01:02:09 | [diff] [blame] | 1144 | blink::initialize(blink_platform_impl_.get()); |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 1145 | |
[email protected] | 4b534028 | 2014-07-08 11:37:34 | [diff] [blame] | 1146 | v8::Isolate* isolate = blink::mainThreadIsolate(); |
[email protected] | 4b534028 | 2014-07-08 11:37:34 | [diff] [blame] | 1147 | isolate->SetCreateHistogramFunction(CreateHistogram); |
| 1148 | isolate->SetAddHistogramSampleFunction(AddHistogramSample); |
skyostil | a37c2a7 | 2016-06-29 17:30:07 | [diff] [blame] | 1149 | renderer_scheduler_->SetRAILModeObserver(this); |
[email protected] | 4b534028 | 2014-07-08 11:37:34 | [diff] [blame] | 1150 | |
rmcilroy | 321f924d | 2014-11-06 00:56:00 | [diff] [blame] | 1151 | main_thread_compositor_task_runner_ = |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1152 | renderer_scheduler_->CompositorTaskRunner(); |
skyostil | c30aa40 | 2014-10-10 13:49:09 | [diff] [blame] | 1153 | |
jdduke | 691dd57 | 2014-12-02 20:47:52 | [diff] [blame] | 1154 | main_input_callback_.Reset( |
| 1155 | base::Bind(base::IgnoreResult(&RenderThreadImpl::OnMessageReceived), |
| 1156 | base::Unretained(this))); |
| 1157 | |
jam | 75c4422 | 2016-03-23 05:34:24 | [diff] [blame] | 1158 | scoped_refptr<base::SingleThreadTaskRunner> resource_task_queue2; |
| 1159 | if (resource_task_queue) { |
| 1160 | resource_task_queue2 = resource_task_queue; |
| 1161 | } else { |
| 1162 | resource_task_queue2 = renderer_scheduler_->LoadingTaskRunner(); |
| 1163 | } |
| 1164 | // Add a filter that forces resource messages to be dispatched via a |
| 1165 | // particular task runner. |
| 1166 | scoped_refptr<ResourceSchedulingFilter> filter( |
| 1167 | new ResourceSchedulingFilter( |
| 1168 | resource_task_queue2, resource_dispatcher())); |
| 1169 | channel()->AddFilter(filter.get()); |
| 1170 | resource_dispatcher()->SetResourceSchedulingFilter(filter); |
| 1171 | |
| 1172 | // The ChildResourceMessageFilter and the ResourceDispatcher need to use the |
| 1173 | // same queue to ensure tasks are executed in the expected order. |
| 1174 | child_resource_message_filter()->SetMainThreadTaskRunner( |
| 1175 | resource_task_queue2); |
| 1176 | resource_dispatcher()->SetMainThreadTaskRunner(resource_task_queue2); |
| 1177 | |
khushalsagar | d7178e4 | 2017-01-20 01:31:49 | [diff] [blame] | 1178 | if (!command_line.HasSwitch(switches::kDisableThreadedCompositing)) |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1179 | InitializeCompositorThread(); |
[email protected] | a9fb30aa | 2011-10-06 06:58:46 | [diff] [blame] | 1180 | |
jdduke | 691dd57 | 2014-12-02 20:47:52 | [diff] [blame] | 1181 | if (!input_event_filter_.get()) { |
| 1182 | // Always provide an input event filter implementation to ensure consistent |
| 1183 | // input event scheduling and prioritization. |
| 1184 | // TODO(jdduke): Merge InputEventFilter, InputHandlerManager and |
| 1185 | // MainThreadInputEventFilter, crbug.com/436057. |
| 1186 | input_event_filter_ = new MainThreadInputEventFilter( |
| 1187 | main_input_callback_.callback(), main_thread_compositor_task_runner_); |
| 1188 | } |
| 1189 | AddFilter(input_event_filter_.get()); |
| 1190 | |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 1191 | scoped_refptr<base::SingleThreadTaskRunner> compositor_impl_side_task_runner; |
vollick | 1050cc6 | 2015-12-03 07:04:54 | [diff] [blame] | 1192 | if (compositor_task_runner_) |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 1193 | compositor_impl_side_task_runner = compositor_task_runner_; |
[email protected] | 7f1f63f | 2013-03-07 06:07:29 | [diff] [blame] | 1194 | else |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 1195 | compositor_impl_side_task_runner = base::ThreadTaskRunnerHandle::Get(); |
[email protected] | 1842fe2 | 2012-08-13 23:24:35 | [diff] [blame] | 1196 | |
simonhong | a7e3ac4 | 2014-11-11 20:50:22 | [diff] [blame] | 1197 | compositor_message_filter_ = new CompositorForwardingMessageFilter( |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 1198 | compositor_impl_side_task_runner.get()); |
simonhong | a7e3ac4 | 2014-11-11 20:50:22 | [diff] [blame] | 1199 | AddFilter(compositor_message_filter_.get()); |
[email protected] | 1842fe2 | 2012-08-13 23:24:35 | [diff] [blame] | 1200 | |
[email protected] | 58436a1 | 2012-03-21 17:10:26 | [diff] [blame] | 1201 | RenderThreadImpl::RegisterSchemes(); |
| 1202 | |
xhwang | 194acae | 2014-11-12 22:46:33 | [diff] [blame] | 1203 | RenderMediaClient::Initialize(); |
| 1204 | |
[email protected] | b146d6d | 2012-09-11 10:20:05 | [diff] [blame] | 1205 | devtools_agent_message_filter_ = new DevToolsAgentFilter(); |
| 1206 | AddFilter(devtools_agent_message_filter_.get()); |
| 1207 | |
ulan | 4a38519 | 2015-11-11 10:59:18 | [diff] [blame] | 1208 | if (GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 1209 | ScheduleIdleHandler(kLongIdleHandlerDelayMs); |
ulan | 4a38519 | 2015-11-11 10:59:18 | [diff] [blame] | 1210 | } else { |
| 1211 | // If we do not track widget visibility, then assume conservatively that |
| 1212 | // the isolate is in background. This reduces memory usage. |
| 1213 | isolate->IsolateInBackgroundNotification(); |
| 1214 | } |
[email protected] | 2541d1a | 2013-07-10 07:33:27 | [diff] [blame] | 1215 | |
jdduke | 73220f0 | 2015-09-04 17:03:51 | [diff] [blame] | 1216 | renderer_scheduler_->SetTimerQueueSuspensionWhenBackgroundedEnabled( |
| 1217 | GetContentClient() |
| 1218 | ->renderer() |
| 1219 | ->AllowTimerSuspensionWhenProcessBackgrounded()); |
| 1220 | |
reed | ccf98c5 | 2014-10-03 16:40:38 | [diff] [blame] | 1221 | SkGraphics::SetResourceCacheSingleAllocationByteLimit( |
[email protected] | dd2c102 | 2014-07-22 23:13:57 | [diff] [blame] | 1222 | kImageCacheSingleAllocationByteLimit); |
| 1223 | |
reed | 6e5a7222 | 2015-08-06 20:37:16 | [diff] [blame] | 1224 | // Hook up blink's codecs so skia can call them |
reed | 08cd1637 | 2017-02-21 22:11:41 | [diff] [blame] | 1225 | SkGraphics::SetImageGeneratorFromEncodedDataFactory( |
reed | 6e5a7222 | 2015-08-06 20:37:16 | [diff] [blame] | 1226 | blink::WebImageGenerator::create); |
| 1227 | |
[email protected] | fdeac26 | 2014-07-10 12:52:51 | [diff] [blame] | 1228 | if (command_line.HasSwitch(switches::kMemoryMetrics)) { |
| 1229 | memory_observer_.reset(new MemoryObserver()); |
| 1230 | message_loop()->AddTaskObserver(memory_observer_.get()); |
| 1231 | } |
paritosh.in | 7e30c90 | 2015-04-15 17:04:07 | [diff] [blame] | 1232 | |
| 1233 | if (command_line.HasSwitch(switches::kExplicitlyAllowedPorts)) { |
| 1234 | std::string allowed_ports = |
| 1235 | command_line.GetSwitchValueASCII(switches::kExplicitlyAllowedPorts); |
| 1236 | net::SetExplicitlyAllowedPorts(allowed_ports); |
| 1237 | } |
[email protected] | d1b8fccc | 2011-08-03 01:20:13 | [diff] [blame] | 1238 | } |
| 1239 | |
[email protected] | 58436a1 | 2012-03-21 17:10:26 | [diff] [blame] | 1240 | void RenderThreadImpl::RegisterSchemes() { |
mkwst | 8e94fb3 | 2015-05-20 05:05:14 | [diff] [blame] | 1241 | // chrome: |
kinuko | a0d5ac6 | 2016-11-04 08:49:59 | [diff] [blame] | 1242 | WebString chrome_scheme(WebString::fromASCII(kChromeUIScheme)); |
mkwst | 8e94fb3 | 2015-05-20 05:05:14 | [diff] [blame] | 1243 | WebSecurityPolicy::registerURLSchemeAsDisplayIsolated(chrome_scheme); |
| 1244 | WebSecurityPolicy::registerURLSchemeAsNotAllowingJavascriptURLs( |
| 1245 | chrome_scheme); |
mkwst | 8e94fb3 | 2015-05-20 05:05:14 | [diff] [blame] | 1246 | |
| 1247 | // chrome-devtools: |
kinuko | a0d5ac6 | 2016-11-04 08:49:59 | [diff] [blame] | 1248 | WebString devtools_scheme(WebString::fromASCII(kChromeDevToolsScheme)); |
mkwst | 8e94fb3 | 2015-05-20 05:05:14 | [diff] [blame] | 1249 | WebSecurityPolicy::registerURLSchemeAsDisplayIsolated(devtools_scheme); |
meacer | ce6b6603 | 2016-06-02 20:56:05 | [diff] [blame] | 1250 | |
| 1251 | // view-source: |
kinuko | a0d5ac6 | 2016-11-04 08:49:59 | [diff] [blame] | 1252 | WebString view_source_scheme(WebString::fromASCII(kViewSourceScheme)); |
meacer | ce6b6603 | 2016-06-02 20:56:05 | [diff] [blame] | 1253 | WebSecurityPolicy::registerURLSchemeAsDisplayIsolated(view_source_scheme); |
[email protected] | 58436a1 | 2012-03-21 17:10:26 | [diff] [blame] | 1254 | } |
| 1255 | |
[email protected] | e6e30ac | 2014-01-13 21:24:39 | [diff] [blame] | 1256 | void RenderThreadImpl::RecordAction(const base::UserMetricsAction& action) { |
[email protected] | 97880c8 | 2013-12-04 07:09:21 | [diff] [blame] | 1257 | Send(new ViewHostMsg_UserMetricsRecordAction(action.str_)); |
| 1258 | } |
| 1259 | |
| 1260 | void RenderThreadImpl::RecordComputedAction(const std::string& action) { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1261 | Send(new ViewHostMsg_UserMetricsRecordAction(action)); |
| 1262 | } |
| 1263 | |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 1264 | std::unique_ptr<base::SharedMemory> |
| 1265 | RenderThreadImpl::HostAllocateSharedMemoryBuffer(size_t size) { |
sadrul | ee3ff1f | 2016-12-09 04:22:01 | [diff] [blame] | 1266 | return ChildThreadImpl::AllocateSharedMemory(size); |
[email protected] | 00614a8 | 2011-10-07 22:39:31 | [diff] [blame] | 1267 | } |
| 1268 | |
jbauman | 2f5c194 | 2014-12-06 03:28:24 | [diff] [blame] | 1269 | cc::SharedBitmapManager* RenderThreadImpl::GetSharedBitmapManager() { |
| 1270 | return shared_bitmap_manager(); |
| 1271 | } |
| 1272 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 1273 | void RenderThreadImpl::RegisterExtension(v8::Extension* extension) { |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1274 | WebScriptController::registerExtension(extension); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1275 | } |
| 1276 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1277 | void RenderThreadImpl::ScheduleIdleHandler(int64_t initial_delay_ms) { |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1278 | idle_notification_delay_in_ms_ = initial_delay_ms; |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1279 | idle_timer_.Stop(); |
| 1280 | idle_timer_.Start(FROM_HERE, |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1281 | base::TimeDelta::FromMilliseconds(initial_delay_ms), |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 1282 | this, &RenderThreadImpl::IdleHandler); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1283 | } |
| 1284 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 1285 | void RenderThreadImpl::IdleHandler() { |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 1286 | bool run_in_foreground_tab = (widget_count_ > hidden_widget_count_) && |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 1287 | GetContentClient()->renderer()-> |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 1288 | RunIdleHandlerWhenWidgetsHidden(); |
| 1289 | if (run_in_foreground_tab) { |
jochen | 5a32aaf | 2014-09-26 20:37:43 | [diff] [blame] | 1290 | if (idle_notifications_to_skip_ > 0) { |
| 1291 | --idle_notifications_to_skip_; |
| 1292 | } else { |
ssid | 0603ca9f | 2015-06-09 16:48:08 | [diff] [blame] | 1293 | ReleaseFreeMemory(); |
jochen | 5a32aaf | 2014-09-26 20:37:43 | [diff] [blame] | 1294 | } |
| 1295 | ScheduleIdleHandler(kLongIdleHandlerDelayMs); |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 1296 | return; |
| 1297 | } |
[email protected] | 237a1485 | 2012-04-28 02:56:38 | [diff] [blame] | 1298 | |
ssid | 0603ca9f | 2015-06-09 16:48:08 | [diff] [blame] | 1299 | ReleaseFreeMemory(); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1300 | |
[email protected] | 26e8232 | 2014-01-20 14:18:22 | [diff] [blame] | 1301 | // Continue the idle timer if the webkit shared timer is not suspended or |
| 1302 | // something is left to do. |
| 1303 | bool continue_timer = !webkit_shared_timer_suspended_; |
| 1304 | |
sullivan | cd45a3e | 2014-09-19 14:39:18 | [diff] [blame] | 1305 | // Schedule next invocation. When the tab is originally hidden, an invocation |
| 1306 | // is scheduled for kInitialIdleHandlerDelayMs in |
| 1307 | // RenderThreadImpl::WidgetHidden in order to race to a minimal heap. |
| 1308 | // After that, idle calls can be much less frequent, so run at a maximum of |
| 1309 | // once every kLongIdleHandlerDelayMs. |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1310 | // Dampen the delay using the algorithm (if delay is in seconds): |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1311 | // delay = delay + 1 / (delay + 2) |
| 1312 | // Using floor(delay) has a dampening effect such as: |
sullivan | cd45a3e | 2014-09-19 14:39:18 | [diff] [blame] | 1313 | // 30s, 30, 30, 31, 31, 31, 31, 32, 32, ... |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1314 | // If the delay is in milliseconds, the above formula is equivalent to: |
| 1315 | // delay_ms / 1000 = delay_ms / 1000 + 1 / (delay_ms / 1000 + 2) |
| 1316 | // which is equivalent to |
| 1317 | // delay_ms = delay_ms + 1000*1000 / (delay_ms + 2000). |
[email protected] | 26e8232 | 2014-01-20 14:18:22 | [diff] [blame] | 1318 | if (continue_timer) { |
sullivan | cd45a3e | 2014-09-19 14:39:18 | [diff] [blame] | 1319 | ScheduleIdleHandler( |
| 1320 | std::max(kLongIdleHandlerDelayMs, |
| 1321 | idle_notification_delay_in_ms_ + |
| 1322 | 1000000 / (idle_notification_delay_in_ms_ + 2000))); |
[email protected] | 26e8232 | 2014-01-20 14:18:22 | [diff] [blame] | 1323 | |
| 1324 | } else { |
| 1325 | idle_timer_.Stop(); |
| 1326 | } |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1327 | |
ericwilligers | 88e6974 | 2016-10-17 19:29:55 | [diff] [blame] | 1328 | for (auto& observer : observers_) |
| 1329 | observer.IdleNotification(); |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1330 | } |
| 1331 | |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1332 | int64_t RenderThreadImpl::GetIdleNotificationDelayInMs() const { |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1333 | return idle_notification_delay_in_ms_; |
[email protected] | 52647690 | 2011-10-06 20:34:06 | [diff] [blame] | 1334 | } |
| 1335 | |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1336 | void RenderThreadImpl::SetIdleNotificationDelayInMs( |
avi | 1023d01 | 2015-12-25 02:39:14 | [diff] [blame] | 1337 | int64_t idle_notification_delay_in_ms) { |
[email protected] | 6593ae1 | 2011-11-14 12:09:44 | [diff] [blame] | 1338 | idle_notification_delay_in_ms_ = idle_notification_delay_in_ms; |
[email protected] | 4a7d639 | 2011-09-19 20:55:08 | [diff] [blame] | 1339 | } |
| 1340 | |
[email protected] | 5b1840636 | 2013-06-18 18:46:43 | [diff] [blame] | 1341 | int RenderThreadImpl::PostTaskToAllWebWorkers(const base::Closure& closure) { |
kinuko | ef64741 | 2015-12-23 06:10:43 | [diff] [blame] | 1342 | return WorkerThreadRegistry::Instance()->PostTaskToAllThreads(closure); |
[email protected] | a9bd323d | 2013-06-17 20:27:56 | [diff] [blame] | 1343 | } |
| 1344 | |
[email protected] | b02f590 | 2012-12-19 07:33:00 | [diff] [blame] | 1345 | bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { |
| 1346 | bool result = false; |
| 1347 | Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); |
| 1348 | return result; |
| 1349 | } |
| 1350 | |
[email protected] | 1784b2f | 2011-11-24 10:53:48 | [diff] [blame] | 1351 | void RenderThreadImpl::PostponeIdleNotification() { |
| 1352 | idle_notifications_to_skip_ = 2; |
| 1353 | } |
| 1354 | |
dcastagna | 7f45dada | 2015-10-19 20:17:35 | [diff] [blame] | 1355 | media::GpuVideoAcceleratorFactories* RenderThreadImpl::GetGpuFactories() { |
[email protected] | 3bb8bb3 | 2013-07-11 13:13:03 | [diff] [blame] | 1356 | DCHECK(IsMainThread()); |
| 1357 | |
dcastagna | 09bd6b3 | 2016-02-01 21:54:28 | [diff] [blame] | 1358 | if (!gpu_factories_.empty()) { |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1359 | scoped_refptr<ui::ContextProviderCommandBuffer> shared_context_provider = |
dcastagna | 09bd6b3 | 2016-02-01 21:54:28 | [diff] [blame] | 1360 | gpu_factories_.back()->ContextProviderMainThread(); |
| 1361 | if (shared_context_provider) { |
| 1362 | cc::ContextProvider::ScopedContextLock lock( |
| 1363 | shared_context_provider.get()); |
| 1364 | if (lock.ContextGL()->GetGraphicsResetStatusKHR() == GL_NO_ERROR) { |
leon.han | 21e0e48 | 2017-02-23 04:13:32 | [diff] [blame] | 1365 | return gpu_factories_.back().get(); |
dcastagna | 09bd6b3 | 2016-02-01 21:54:28 | [diff] [blame] | 1366 | } else { |
| 1367 | scoped_refptr<base::SingleThreadTaskRunner> media_task_runner = |
| 1368 | GetMediaThreadTaskRunner(); |
| 1369 | media_task_runner->PostTask( |
| 1370 | FROM_HERE, |
| 1371 | base::Bind( |
| 1372 | base::IgnoreResult( |
| 1373 | &RendererGpuVideoAcceleratorFactories::CheckContextLost), |
leon.han | 21e0e48 | 2017-02-23 04:13:32 | [diff] [blame] | 1374 | base::Unretained(gpu_factories_.back().get()))); |
dcastagna | 09bd6b3 | 2016-02-01 21:54:28 | [diff] [blame] | 1375 | } |
| 1376 | } |
| 1377 | } |
dcastagna | 7f45dada | 2015-10-19 20:17:35 | [diff] [blame] | 1378 | |
tobiasjs | ca238b3b | 2015-06-24 22:53:54 | [diff] [blame] | 1379 | const base::CommandLine* cmd_line = base::CommandLine::ForCurrentProcess(); |
| 1380 | |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1381 | scoped_refptr<gpu::GpuChannelHost> gpu_channel_host = |
sadrul | 6d310fa | 2016-08-04 02:12:16 | [diff] [blame] | 1382 | EstablishGpuChannelSync(); |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1383 | if (!gpu_channel_host) |
| 1384 | return nullptr; |
danakj | 0dd9e1e | 2016-05-11 22:15:09 | [diff] [blame] | 1385 | // This context is only used to create textures and mailbox them, so |
| 1386 | // use lower limits than the default. |
| 1387 | gpu::SharedMemoryLimits limits = gpu::SharedMemoryLimits::ForMailboxContext(); |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 1388 | bool support_locking = true; |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1389 | scoped_refptr<ui::ContextProviderCommandBuffer> media_context_provider = |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 1390 | CreateOffscreenContext(gpu_channel_host, limits, support_locking, |
ericrk | a20c100 | 2017-03-13 21:08:13 | [diff] [blame] | 1391 | ui::command_buffer_metrics::MEDIA_CONTEXT, |
danakj | 0dd9e1e | 2016-05-11 22:15:09 | [diff] [blame] | 1392 | gpu::GPU_STREAM_DEFAULT, |
| 1393 | gpu::GpuStreamPriority::NORMAL); |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1394 | if (!media_context_provider->BindToCurrentThread()) |
| 1395 | return nullptr; |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1396 | |
acolwell | b403494 | 2014-08-28 15:42:43 | [diff] [blame] | 1397 | scoped_refptr<base::SingleThreadTaskRunner> media_task_runner = |
| 1398 | GetMediaThreadTaskRunner(); |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1399 | const bool enable_video_accelerator = |
| 1400 | !cmd_line->HasSwitch(switches::kDisableAcceleratedVideoDecode); |
| 1401 | const bool enable_gpu_memory_buffer_video_frames = |
dcastagna | 43c3a86a | 2016-02-02 21:16:38 | [diff] [blame] | 1402 | #if defined(OS_MACOSX) || defined(OS_LINUX) |
dcastagna | a82ed96a | 2016-05-12 02:52:47 | [diff] [blame] | 1403 | !cmd_line->HasSwitch(switches::kDisableGpuMemoryBufferVideoFrames) && |
| 1404 | !cmd_line->HasSwitch(switches::kDisableGpuCompositing) && |
| 1405 | !gpu_channel_host->gpu_info().software_rendering; |
dcastagna | b65e607 | 2015-09-05 07:18:42 | [diff] [blame] | 1406 | #else |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1407 | cmd_line->HasSwitch(switches::kEnableGpuMemoryBufferVideoFrames); |
dcastagna | b65e607 | 2015-09-05 07:18:42 | [diff] [blame] | 1408 | #endif |
dcastagna | 5077d6d | 2016-01-27 00:07:05 | [diff] [blame] | 1409 | |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1410 | gpu_factories_.push_back(RendererGpuVideoAcceleratorFactories::Create( |
| 1411 | std::move(gpu_channel_host), base::ThreadTaskRunnerHandle::Get(), |
| 1412 | media_task_runner, std::move(media_context_provider), |
ericrk | 9151705c | 2016-07-26 19:53:16 | [diff] [blame] | 1413 | enable_gpu_memory_buffer_video_frames, buffer_to_texture_target_map_, |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 1414 | enable_video_accelerator)); |
leon.han | 21e0e48 | 2017-02-23 04:13:32 | [diff] [blame] | 1415 | return gpu_factories_.back().get(); |
[email protected] | 3bb8bb3 | 2013-07-11 13:13:03 | [diff] [blame] | 1416 | } |
| 1417 | |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1418 | scoped_refptr<ui::ContextProviderCommandBuffer> |
[email protected] | f10dc47 | 2013-09-27 03:31:59 | [diff] [blame] | 1419 | RenderThreadImpl::SharedMainThreadContextProvider() { |
[email protected] | e06e112 | 2013-03-15 17:12:38 | [diff] [blame] | 1420 | DCHECK(IsMainThread()); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 1421 | if (shared_main_thread_contexts_ && |
| 1422 | shared_main_thread_contexts_->ContextGL()->GetGraphicsResetStatusKHR() == |
| 1423 | GL_NO_ERROR) |
| 1424 | return shared_main_thread_contexts_; |
| 1425 | |
sadrul | 6d310fa | 2016-08-04 02:12:16 | [diff] [blame] | 1426 | scoped_refptr<gpu::GpuChannelHost> gpu_channel_host( |
| 1427 | EstablishGpuChannelSync()); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 1428 | if (!gpu_channel_host) { |
| 1429 | shared_main_thread_contexts_ = nullptr; |
| 1430 | return nullptr; |
[email protected] | c29b7ff | 2013-03-06 03:51:04 | [diff] [blame] | 1431 | } |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 1432 | |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 1433 | bool support_locking = false; |
danakj | c398355 | 2016-05-03 00:04:35 | [diff] [blame] | 1434 | shared_main_thread_contexts_ = CreateOffscreenContext( |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 1435 | std::move(gpu_channel_host), gpu::SharedMemoryLimits(), support_locking, |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1436 | ui::command_buffer_metrics::RENDERER_MAINTHREAD_CONTEXT, |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 1437 | gpu::GPU_STREAM_DEFAULT, gpu::GpuStreamPriority::NORMAL); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 1438 | if (!shared_main_thread_contexts_->BindToCurrentThread()) |
| 1439 | shared_main_thread_contexts_ = nullptr; |
[email protected] | f10dc47 | 2013-09-27 03:31:59 | [diff] [blame] | 1440 | return shared_main_thread_contexts_; |
[email protected] | c29b7ff | 2013-03-06 03:51:04 | [diff] [blame] | 1441 | } |
| 1442 | |
siva.gunturi | 5d4feb05 | 2015-11-15 16:15:31 | [diff] [blame] | 1443 | #if defined(OS_ANDROID) |
boliu | f8753bf6 | 2016-02-11 20:09:42 | [diff] [blame] | 1444 | |
siva.gunturi | 5d4feb05 | 2015-11-15 16:15:31 | [diff] [blame] | 1445 | scoped_refptr<StreamTextureFactory> RenderThreadImpl::GetStreamTexureFactory() { |
| 1446 | DCHECK(IsMainThread()); |
boliu | 30f1b26 | 2016-04-19 00:12:33 | [diff] [blame] | 1447 | if (!stream_texture_factory_.get() || |
| 1448 | stream_texture_factory_->ContextGL()->GetGraphicsResetStatusKHR() != |
| 1449 | GL_NO_ERROR) { |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1450 | scoped_refptr<ui::ContextProviderCommandBuffer> shared_context_provider = |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 1451 | SharedMainThreadContextProvider(); |
| 1452 | if (!shared_context_provider) { |
penghuang | e1d8651 | 2016-07-08 18:15:00 | [diff] [blame] | 1453 | stream_texture_factory_ = nullptr; |
| 1454 | return nullptr; |
siva.gunturi | 5d4feb05 | 2015-11-15 16:15:31 | [diff] [blame] | 1455 | } |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 1456 | DCHECK(shared_context_provider->GetCommandBufferProxy()); |
| 1457 | DCHECK(shared_context_provider->GetCommandBufferProxy()->channel()); |
| 1458 | stream_texture_factory_ = |
| 1459 | StreamTextureFactory::Create(std::move(shared_context_provider)); |
siva.gunturi | 5d4feb05 | 2015-11-15 16:15:31 | [diff] [blame] | 1460 | } |
| 1461 | return stream_texture_factory_; |
| 1462 | } |
boliu | f8753bf6 | 2016-02-11 20:09:42 | [diff] [blame] | 1463 | |
| 1464 | bool RenderThreadImpl::EnableStreamTextureCopy() { |
boliu | 30f1b26 | 2016-04-19 00:12:33 | [diff] [blame] | 1465 | return sync_compositor_message_filter_.get(); |
boliu | f8753bf6 | 2016-02-11 20:09:42 | [diff] [blame] | 1466 | } |
| 1467 | |
siva.gunturi | 5d4feb05 | 2015-11-15 16:15:31 | [diff] [blame] | 1468 | #endif |
| 1469 | |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 1470 | AudioRendererMixerManager* RenderThreadImpl::GetAudioRendererMixerManager() { |
[email protected] | 59383c78 | 2013-04-17 16:43:27 | [diff] [blame] | 1471 | if (!audio_renderer_mixer_manager_) { |
olka | 7a467939 | 2016-05-27 15:32:58 | [diff] [blame] | 1472 | audio_renderer_mixer_manager_ = AudioRendererMixerManager::Create(); |
[email protected] | 3958e97 | 2012-07-17 00:25:41 | [diff] [blame] | 1473 | } |
| 1474 | |
| 1475 | return audio_renderer_mixer_manager_.get(); |
| 1476 | } |
| 1477 | |
[email protected] | 73429ca | 2014-03-06 06:07:47 | [diff] [blame] | 1478 | base::WaitableEvent* RenderThreadImpl::GetShutdownEvent() { |
| 1479 | return ChildProcess::current()->GetShutDownEvent(); |
| 1480 | } |
| 1481 | |
staraz | 067f5824 | 2016-11-07 21:06:41 | [diff] [blame] | 1482 | int32_t RenderThreadImpl::GetClientId() { |
| 1483 | return client_id_; |
| 1484 | } |
| 1485 | |
altimin | c8885e8 | 2017-01-18 13:11:14 | [diff] [blame] | 1486 | scoped_refptr<base::SingleThreadTaskRunner> |
| 1487 | RenderThreadImpl::GetTimerTaskRunner() { |
| 1488 | return renderer_scheduler_->TimerTaskRunner(); |
| 1489 | } |
| 1490 | |
| 1491 | scoped_refptr<base::SingleThreadTaskRunner> |
| 1492 | RenderThreadImpl::GetLoadingTaskRunner() { |
| 1493 | return renderer_scheduler_->LoadingTaskRunner(); |
| 1494 | } |
| 1495 | |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 1496 | void RenderThreadImpl::SetFieldTrialGroup(const std::string& trial_name, |
| 1497 | const std::string& group_name) { |
| 1498 | field_trial_syncer_.OnSetFieldTrialGroup(trial_name, group_name); |
| 1499 | } |
| 1500 | |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 1501 | void RenderThreadImpl::OnAssociatedInterfaceRequest( |
| 1502 | const std::string& name, |
| 1503 | mojo::ScopedInterfaceEndpointHandle handle) { |
rockot | 70bbb5949 | 2017-01-25 00:56:51 | [diff] [blame] | 1504 | if (associated_interfaces_.CanBindRequest(name)) |
| 1505 | associated_interfaces_.BindRequest(name, std::move(handle)); |
| 1506 | else |
| 1507 | ChildThreadImpl::OnAssociatedInterfaceRequest(name, std::move(handle)); |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 1508 | } |
| 1509 | |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1510 | bool RenderThreadImpl::IsGpuRasterizationForced() { |
| 1511 | return is_gpu_rasterization_forced_; |
| 1512 | } |
| 1513 | |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 1514 | bool RenderThreadImpl::IsAsyncWorkerContextEnabled() { |
| 1515 | return is_async_worker_context_enabled_; |
| 1516 | } |
| 1517 | |
senorblanco | b60ba95 | 2015-01-27 19:12:36 | [diff] [blame] | 1518 | int RenderThreadImpl::GetGpuRasterizationMSAASampleCount() { |
| 1519 | return gpu_rasterization_msaa_sample_count_; |
| 1520 | } |
| 1521 | |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1522 | bool RenderThreadImpl::IsLcdTextEnabled() { |
| 1523 | return is_lcd_text_enabled_; |
| 1524 | } |
| 1525 | |
| 1526 | bool RenderThreadImpl::IsDistanceFieldTextEnabled() { |
| 1527 | return is_distance_field_text_enabled_; |
| 1528 | } |
| 1529 | |
| 1530 | bool RenderThreadImpl::IsZeroCopyEnabled() { |
| 1531 | return is_zero_copy_enabled_; |
| 1532 | } |
| 1533 | |
ericrk | 1d17f75 | 2015-10-20 03:03:07 | [diff] [blame] | 1534 | bool RenderThreadImpl::IsPartialRasterEnabled() { |
| 1535 | return is_partial_raster_enabled_; |
jbroman | 5f7f7193 | 2015-08-18 16:24:46 | [diff] [blame] | 1536 | } |
| 1537 | |
ccameron | c7fcd13 | 2015-11-03 20:14:31 | [diff] [blame] | 1538 | bool RenderThreadImpl::IsGpuMemoryBufferCompositorResourcesEnabled() { |
| 1539 | return is_gpu_memory_buffer_compositor_resources_enabled_; |
| 1540 | } |
| 1541 | |
ccameron | a764475 | 2014-12-30 01:16:31 | [diff] [blame] | 1542 | bool RenderThreadImpl::IsElasticOverscrollEnabled() { |
| 1543 | return is_elastic_overscroll_enabled_; |
| 1544 | } |
| 1545 | |
ericrk | 9151705c | 2016-07-26 19:53:16 | [diff] [blame] | 1546 | const cc::BufferToTextureTargetMap& |
| 1547 | RenderThreadImpl::GetBufferToTextureTargetMap() { |
| 1548 | return buffer_to_texture_target_map_; |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1549 | } |
vmiura | 9084b34 | 2015-02-03 22:19:57 | [diff] [blame] | 1550 | |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1551 | scoped_refptr<base::SingleThreadTaskRunner> |
| 1552 | RenderThreadImpl::GetCompositorMainThreadTaskRunner() { |
| 1553 | return main_thread_compositor_task_runner_; |
| 1554 | } |
| 1555 | |
| 1556 | scoped_refptr<base::SingleThreadTaskRunner> |
| 1557 | RenderThreadImpl::GetCompositorImplThreadTaskRunner() { |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 1558 | return compositor_task_runner_; |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1559 | } |
| 1560 | |
| 1561 | gpu::GpuMemoryBufferManager* RenderThreadImpl::GetGpuMemoryBufferManager() { |
sadrul | 5354659 | 2016-12-17 01:44:21 | [diff] [blame] | 1562 | return gpu_->gpu_memory_buffer_manager(); |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1563 | } |
| 1564 | |
skyostil | 529caa29 | 2016-08-10 17:44:51 | [diff] [blame] | 1565 | blink::scheduler::RendererScheduler* RenderThreadImpl::GetRendererScheduler() { |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1566 | return renderer_scheduler_.get(); |
| 1567 | } |
| 1568 | |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 1569 | std::unique_ptr<cc::BeginFrameSource> |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1570 | RenderThreadImpl::CreateExternalBeginFrameSource(int routing_id) { |
enne | e292bdc | 2016-09-15 19:57:15 | [diff] [blame] | 1571 | const base::CommandLine* cmd = base::CommandLine::ForCurrentProcess(); |
| 1572 | if (cmd->HasSwitch(switches::kDisableGpuVsync)) { |
| 1573 | std::string display_vsync_string = |
| 1574 | cmd->GetSwitchValueASCII(switches::kDisableGpuVsync); |
| 1575 | if (display_vsync_string != "gpu") { |
| 1576 | // In disable gpu vsync mode, also let the renderer tick as fast as it |
| 1577 | // can. The top level begin frame source will also be running as a back |
| 1578 | // to back begin frame source, but using a synthetic begin frame source |
| 1579 | // here reduces latency when in this mode (at least for frames |
| 1580 | // starting--it potentially increases it for input on the other hand.) |
| 1581 | base::SingleThreadTaskRunner* compositor_impl_side_task_runner = |
| 1582 | compositor_task_runner_ ? compositor_task_runner_.get() |
| 1583 | : base::ThreadTaskRunnerHandle::Get().get(); |
| 1584 | return base::MakeUnique<cc::BackToBackBeginFrameSource>( |
| 1585 | base::MakeUnique<cc::DelayBasedTimeSource>( |
| 1586 | compositor_impl_side_task_runner)); |
| 1587 | } |
| 1588 | } |
| 1589 | |
ricea | 29649b9 | 2016-08-31 09:30:21 | [diff] [blame] | 1590 | return base::MakeUnique<CompositorExternalBeginFrameSource>( |
| 1591 | compositor_message_filter_.get(), sync_message_filter(), routing_id); |
danakj | 6e3bf801 | 2014-12-16 18:27:53 | [diff] [blame] | 1592 | } |
| 1593 | |
reveman | 34b7a152 | 2015-03-23 20:27:47 | [diff] [blame] | 1594 | cc::TaskGraphRunner* RenderThreadImpl::GetTaskGraphRunner() { |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 1595 | return categorized_worker_pool_->GetTaskGraphRunner(); |
reveman | 34b7a152 | 2015-03-23 20:27:47 | [diff] [blame] | 1596 | } |
| 1597 | |
vmpstr | dfd2286 | 2015-09-25 17:42:41 | [diff] [blame] | 1598 | bool RenderThreadImpl::AreImageDecodeTasksEnabled() { |
| 1599 | return are_image_decode_tasks_enabled_; |
reveman | 34b7a152 | 2015-03-23 20:27:47 | [diff] [blame] | 1600 | } |
| 1601 | |
loyso | 65c93c60 | 2015-08-11 05:15:57 | [diff] [blame] | 1602 | bool RenderThreadImpl::IsThreadedAnimationEnabled() { |
| 1603 | return is_threaded_animation_enabled_; |
| 1604 | } |
| 1605 | |
wjmaclean | 1d97062 | 2017-01-21 22:28:24 | [diff] [blame] | 1606 | bool RenderThreadImpl::IsScrollAnimatorEnabled() { |
| 1607 | return is_scroll_animator_enabled_; |
| 1608 | } |
| 1609 | |
fsamuel | 4c5c8714 | 2017-03-14 03:14:26 | [diff] [blame] | 1610 | bool RenderThreadImpl::IsSurfaceSynchronizationEnabled() { |
| 1611 | return is_surface_synchronization_enabled_; |
| 1612 | } |
| 1613 | |
skyostil | a37c2a7 | 2016-06-29 17:30:07 | [diff] [blame] | 1614 | void RenderThreadImpl::OnRAILModeChanged(v8::RAILMode rail_mode) { |
| 1615 | blink::mainThreadIsolate()->SetRAILMode(rail_mode); |
| 1616 | blink::setRAILModeOnWorkerThreadIsolates(rail_mode); |
| 1617 | } |
| 1618 | |
[email protected] | b3e83de | 2012-02-07 03:33:28 | [diff] [blame] | 1619 | bool RenderThreadImpl::IsMainThread() { |
| 1620 | return !!current(); |
| 1621 | } |
| 1622 | |
torne | 88b6645 | 2016-05-03 13:22:14 | [diff] [blame] | 1623 | void RenderThreadImpl::OnChannelError() { |
| 1624 | // In single-process mode, the renderer can't be restarted after shutdown. |
| 1625 | // So, if we get a channel error, crash the whole process right now to get a |
| 1626 | // more informative stack, since we will otherwise just crash later when we |
| 1627 | // try to restart it. |
| 1628 | CHECK(!base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 1629 | switches::kSingleProcess)); |
| 1630 | ChildThreadImpl::OnChannelError(); |
| 1631 | } |
| 1632 | |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 1633 | bool RenderThreadImpl::OnControlMessageReceived(const IPC::Message& msg) { |
dcheng | a2d442c2 | 2016-10-13 15:39:21 | [diff] [blame] | 1634 | for (auto& observer : observers_) { |
| 1635 | if (observer.OnControlMessageReceived(msg)) |
[email protected] | 1223d6ef | 2011-03-28 16:47:50 | [diff] [blame] | 1636 | return true; |
| 1637 | } |
| 1638 | |
[email protected] | 70c19a93 | 2010-05-14 12:59:11 | [diff] [blame] | 1639 | // Some messages are handled by delegates. |
[email protected] | 1910fe8 | 2012-05-10 00:04:10 | [diff] [blame] | 1640 | if (appcache_dispatcher_->OnMessageReceived(msg) || |
[email protected] | 7670d433 | 2013-11-29 04:35:00 | [diff] [blame] | 1641 | dom_storage_dispatcher_->OnMessageReceived(msg) || |
| 1642 | embedded_worker_dispatcher_->OnMessageReceived(msg)) { |
[email protected] | a95986a8 | 2010-12-24 06:19:28 | [diff] [blame] | 1643 | return true; |
[email protected] | 1910fe8 | 2012-05-10 00:04:10 | [diff] [blame] | 1644 | } |
[email protected] | 1edc16b8 | 2009-04-07 17:45:54 | [diff] [blame] | 1645 | |
[email protected] | a95986a8 | 2010-12-24 06:19:28 | [diff] [blame] | 1646 | bool handled = true; |
[email protected] | f1a29a0 | 2011-10-06 23:08:44 | [diff] [blame] | 1647 | IPC_BEGIN_MESSAGE_MAP(RenderThreadImpl, msg) |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 1648 | IPC_MESSAGE_HANDLER(WorkerProcessMsg_CreateWorker, OnCreateNewSharedWorker) |
[email protected] | a95986a8 | 2010-12-24 06:19:28 | [diff] [blame] | 1649 | IPC_MESSAGE_UNHANDLED(handled = false) |
[email protected] | 8930d47 | 2009-02-21 08:05:28 | [diff] [blame] | 1650 | IPC_END_MESSAGE_MAP() |
[email protected] | a95986a8 | 2010-12-24 06:19:28 | [diff] [blame] | 1651 | return handled; |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 1652 | } |
| 1653 | |
jdduke | 73220f0 | 2015-09-04 17:03:51 | [diff] [blame] | 1654 | void RenderThreadImpl::OnProcessBackgrounded(bool backgrounded) { |
| 1655 | ChildThreadImpl::OnProcessBackgrounded(backgrounded); |
| 1656 | |
hajimehoshi | 6909327 | 2016-05-13 08:30:58 | [diff] [blame] | 1657 | if (backgrounded) { |
jdduke | 73220f0 | 2015-09-04 17:03:51 | [diff] [blame] | 1658 | renderer_scheduler_->OnRendererBackgrounded(); |
tasak | b95dbb50c | 2017-02-08 18:07:50 | [diff] [blame] | 1659 | needs_to_record_first_active_paint_ = false; |
hajimehoshi | 6909327 | 2016-05-13 08:30:58 | [diff] [blame] | 1660 | } else { |
jdduke | 73220f0 | 2015-09-04 17:03:51 | [diff] [blame] | 1661 | renderer_scheduler_->OnRendererForegrounded(); |
tasak | 6ff4403 | 2016-11-07 06:45:25 | [diff] [blame] | 1662 | |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1663 | record_purge_suspend_metric_closure_.Cancel(); |
tasak | 07465a7 | 2016-10-21 06:38:52 | [diff] [blame] | 1664 | record_purge_suspend_metric_closure_.Reset( |
| 1665 | base::Bind(&RenderThreadImpl::RecordPurgeAndSuspendMetrics, |
| 1666 | base::Unretained(this))); |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1667 | record_purge_suspend_growth_metric_closure_.Cancel(); |
| 1668 | record_purge_suspend_growth_metric_closure_.Reset( |
| 1669 | base::Bind(&RenderThreadImpl::RecordPurgeAndSuspendMemoryGrowthMetrics, |
| 1670 | base::Unretained(this))); |
hajimehoshi | 6909327 | 2016-05-13 08:30:58 | [diff] [blame] | 1671 | } |
| 1672 | } |
| 1673 | |
| 1674 | void RenderThreadImpl::OnProcessPurgeAndSuspend() { |
| 1675 | ChildThreadImpl::OnProcessPurgeAndSuspend(); |
tasak | 6ff4403 | 2016-11-07 06:45:25 | [diff] [blame] | 1676 | if (!RendererIsHidden()) |
hajimehoshi | 6909327 | 2016-05-13 08:30:58 | [diff] [blame] | 1677 | return; |
tasak | ff1e6242 | 2016-12-22 04:53:55 | [diff] [blame] | 1678 | |
tasak | 6ff4403 | 2016-11-07 06:45:25 | [diff] [blame] | 1679 | if (base::FeatureList::IsEnabled(features::kPurgeAndSuspend)) { |
wez | c80d2d2b0 | 2017-02-16 03:28:19 | [diff] [blame] | 1680 | base::MemoryCoordinatorClientRegistry::GetInstance()->PurgeMemory(); |
tasak | 6ff4403 | 2016-11-07 06:45:25 | [diff] [blame] | 1681 | } |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1682 | // Since purging is not a synchronous task (e.g. v8 GC, oilpan GC, ...), |
| 1683 | // we need to wait until the task is finished. So wait 15 seconds and |
| 1684 | // update purge+suspend UMA histogram. |
| 1685 | // TODO(tasak): use MemoryCoordinator's callback to report purge+suspend |
| 1686 | // UMA when MemoryCoordinator is available. |
| 1687 | GetRendererScheduler()->DefaultTaskRunner()->PostDelayedTask( |
| 1688 | FROM_HERE, record_purge_suspend_metric_closure_.callback(), |
| 1689 | base::TimeDelta::FromSeconds(15)); |
tasak | b95dbb50c | 2017-02-08 18:07:50 | [diff] [blame] | 1690 | needs_to_record_first_active_paint_ = true; |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1691 | } |
| 1692 | |
| 1693 | // TODO(tasak): Replace the following GetMallocUsage() with memory-infra |
| 1694 | // when it is possible to run memory-infra without tracing. |
| 1695 | #if defined(OS_WIN) |
| 1696 | namespace { |
| 1697 | |
| 1698 | static size_t GetMallocUsage() { |
siggi | 7fb93a5 | 2016-12-12 22:22:15 | [diff] [blame] | 1699 | // Iterate through whichever heap the CRT is using. |
| 1700 | HANDLE crt_heap = reinterpret_cast<HANDLE>(_get_heap_handle()); |
| 1701 | if (crt_heap == NULL) |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1702 | return 0; |
siggi | 7fb93a5 | 2016-12-12 22:22:15 | [diff] [blame] | 1703 | if (!::HeapLock(crt_heap)) |
tasak | 7415a3db | 2016-12-12 04:17:14 | [diff] [blame] | 1704 | return 0 ; |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1705 | size_t malloc_usage = 0; |
tasak | 7415a3db | 2016-12-12 04:17:14 | [diff] [blame] | 1706 | PROCESS_HEAP_ENTRY heap_entry; |
| 1707 | heap_entry.lpData = NULL; |
siggi | 7fb93a5 | 2016-12-12 22:22:15 | [diff] [blame] | 1708 | while (::HeapWalk(crt_heap, &heap_entry) != 0) { |
tasak | 7415a3db | 2016-12-12 04:17:14 | [diff] [blame] | 1709 | if ((heap_entry.wFlags & PROCESS_HEAP_ENTRY_BUSY) != 0) |
| 1710 | malloc_usage += heap_entry.cbData; |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1711 | } |
siggi | 7fb93a5 | 2016-12-12 22:22:15 | [diff] [blame] | 1712 | ::HeapUnlock(crt_heap); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1713 | return malloc_usage; |
| 1714 | } |
| 1715 | |
| 1716 | } // namespace |
| 1717 | #elif defined(OS_MACOSX) || defined(OS_IOS) |
| 1718 | namespace { |
| 1719 | |
| 1720 | static size_t GetMallocUsage() { |
| 1721 | malloc_statistics_t stats = {0}; |
| 1722 | malloc_zone_statistics(nullptr, &stats); |
| 1723 | return stats.size_in_use; |
| 1724 | } |
| 1725 | |
| 1726 | } // namespace |
| 1727 | #endif |
| 1728 | |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1729 | void RenderThreadImpl::GetRendererMemoryMetrics( |
| 1730 | RendererMemoryMetrics* memory_metrics) const { |
| 1731 | DCHECK(memory_metrics); |
| 1732 | |
| 1733 | blink::WebMemoryStatistics blink_stats = blink::WebMemoryStatistics::Get(); |
| 1734 | memory_metrics->partition_alloc_kb = |
| 1735 | blink_stats.partitionAllocTotalAllocatedBytes / 1024; |
| 1736 | memory_metrics->blink_gc_kb = blink_stats.blinkGCTotalAllocatedBytes / 1024; |
| 1737 | #if defined(OS_LINUX) || defined(OS_ANDROID) |
| 1738 | struct mallinfo minfo = mallinfo(); |
| 1739 | #if defined(USE_TCMALLOC) |
| 1740 | size_t malloc_usage = minfo.uordblks; |
| 1741 | #else |
| 1742 | size_t malloc_usage = minfo.hblkhd + minfo.arena; |
| 1743 | #endif |
| 1744 | #else |
| 1745 | size_t malloc_usage = GetMallocUsage(); |
| 1746 | #endif |
| 1747 | memory_metrics->malloc_mb = malloc_usage / 1024 / 1024; |
| 1748 | |
| 1749 | discardable_memory::ClientDiscardableSharedMemoryManager::Statistics |
| 1750 | discardable_stats = discardable_shared_memory_manager_->GetStatistics(); |
| 1751 | size_t discardable_usage = |
| 1752 | discardable_stats.total_size - discardable_stats.freelist_size; |
| 1753 | memory_metrics->discardable_kb = discardable_usage / 1024; |
| 1754 | |
| 1755 | size_t v8_usage = 0; |
| 1756 | if (v8::Isolate* isolate = blink::mainThreadIsolate()) { |
| 1757 | v8::HeapStatistics v8_heap_statistics; |
| 1758 | isolate->GetHeapStatistics(&v8_heap_statistics); |
| 1759 | v8_usage = v8_heap_statistics.total_heap_size(); |
| 1760 | } |
| 1761 | // TODO(tasak): Currently only memory usage of mainThreadIsolate() is |
| 1762 | // reported. We should collect memory usages of all isolates using |
| 1763 | // memory-infra. |
| 1764 | memory_metrics->v8_main_thread_isolate_mb = v8_usage / 1024 / 1024; |
| 1765 | size_t total_allocated = blink_stats.partitionAllocTotalAllocatedBytes + |
| 1766 | blink_stats.blinkGCTotalAllocatedBytes + |
| 1767 | malloc_usage + v8_usage + discardable_usage; |
| 1768 | memory_metrics->total_allocated_mb = total_allocated / 1024 / 1024; |
| 1769 | memory_metrics->non_discardable_total_allocated_mb = |
| 1770 | (total_allocated - discardable_usage) / 1024 / 1024; |
| 1771 | memory_metrics->total_allocated_per_render_view_mb = |
| 1772 | total_allocated / RenderView::GetRenderViewCount() / 1024 / 1024; |
| 1773 | } |
| 1774 | |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1775 | // TODO(tasak): Once it is possible to use memory-infra without tracing, |
| 1776 | // we should collect the metrics using memory-infra. |
| 1777 | // TODO(tasak): We should also report a difference between the memory usages |
| 1778 | // before and after purging by using memory-infra. |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1779 | void RenderThreadImpl::RecordPurgeAndSuspendMetrics() { |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1780 | // If this renderer is resumed, we should not update UMA. |
tasak | 7e65dad | 2016-12-16 10:18:25 | [diff] [blame] | 1781 | if (!RendererIsHidden()) |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1782 | return; |
| 1783 | |
| 1784 | // TODO(tasak): Compare memory metrics between purge-enabled renderers and |
| 1785 | // purge-disabled renderers (A/B testing). |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1786 | RendererMemoryMetrics memory_metrics; |
| 1787 | GetRendererMemoryMetrics(&memory_metrics); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1788 | UMA_HISTOGRAM_MEMORY_KB("PurgeAndSuspend.Memory.PartitionAllocKB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1789 | memory_metrics.partition_alloc_kb); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1790 | UMA_HISTOGRAM_MEMORY_KB("PurgeAndSuspend.Memory.BlinkGCKB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1791 | memory_metrics.blink_gc_kb); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1792 | UMA_HISTOGRAM_MEMORY_MB("PurgeAndSuspend.Memory.MallocMB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1793 | memory_metrics.malloc_mb); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1794 | UMA_HISTOGRAM_MEMORY_KB("PurgeAndSuspend.Memory.DiscardableKB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1795 | memory_metrics.discardable_kb); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1796 | UMA_HISTOGRAM_MEMORY_MB("PurgeAndSuspend.Memory.V8MainThreadIsolateMB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1797 | memory_metrics.v8_main_thread_isolate_mb); |
tasak | b46626a | 2016-10-18 05:54:44 | [diff] [blame] | 1798 | UMA_HISTOGRAM_MEMORY_MB("PurgeAndSuspend.Memory.TotalAllocatedMB", |
keishi | 51ed0d5 | 2017-01-12 10:04:46 | [diff] [blame] | 1799 | memory_metrics.total_allocated_mb); |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1800 | purge_and_suspend_memory_metrics_ = memory_metrics; |
| 1801 | |
| 1802 | // record how many memory usage increases after purged. |
| 1803 | GetRendererScheduler()->DefaultTaskRunner()->PostDelayedTask( |
| 1804 | FROM_HERE, record_purge_suspend_growth_metric_closure_.callback(), |
| 1805 | base::TimeDelta::FromMinutes(5)); |
| 1806 | GetRendererScheduler()->DefaultTaskRunner()->PostDelayedTask( |
| 1807 | FROM_HERE, record_purge_suspend_growth_metric_closure_.callback(), |
| 1808 | base::TimeDelta::FromMinutes(10)); |
| 1809 | GetRendererScheduler()->DefaultTaskRunner()->PostDelayedTask( |
| 1810 | FROM_HERE, record_purge_suspend_growth_metric_closure_.callback(), |
| 1811 | base::TimeDelta::FromMinutes(15)); |
| 1812 | } |
| 1813 | |
| 1814 | #define GET_MEMORY_GROWTH(current, previous, allocator) \ |
| 1815 | (current.allocator > previous.allocator \ |
| 1816 | ? current.allocator - previous.allocator \ |
| 1817 | : 0) |
| 1818 | |
| 1819 | void RenderThreadImpl::RecordPurgeAndSuspendMemoryGrowthMetrics() const { |
| 1820 | // If this renderer is resumed, we should not update UMA. |
| 1821 | if (!RendererIsHidden()) |
| 1822 | return; |
| 1823 | |
| 1824 | RendererMemoryMetrics memory_metrics; |
| 1825 | GetRendererMemoryMetrics(&memory_metrics); |
| 1826 | UMA_HISTOGRAM_MEMORY_KB( |
| 1827 | "PurgeAndSuspend.Experimental.MemoryGrowth.PartitionAllocKB", |
| 1828 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1829 | partition_alloc_kb)); |
| 1830 | UMA_HISTOGRAM_MEMORY_KB( |
| 1831 | "PurgeAndSuspend.Experimental.MemoryGrowth.BlinkGCKB", |
| 1832 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1833 | blink_gc_kb)); |
tasak | 9b2c7fe | 2017-01-31 19:40:34 | [diff] [blame] | 1834 | UMA_HISTOGRAM_MEMORY_KB( |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1835 | "PurgeAndSuspend.Experimental.MemoryGrowth.MallocKB", |
| 1836 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1837 | malloc_mb) * 1024); |
| 1838 | UMA_HISTOGRAM_MEMORY_KB( |
| 1839 | "PurgeAndSuspend.Experimental.MemoryGrowth.DiscardableKB", |
| 1840 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1841 | discardable_kb)); |
tasak | 9b2c7fe | 2017-01-31 19:40:34 | [diff] [blame] | 1842 | UMA_HISTOGRAM_MEMORY_KB( |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1843 | "PurgeAndSuspend.Experimental.MemoryGrowth.V8MainThreadIsolateKB", |
| 1844 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1845 | v8_main_thread_isolate_mb) * 1024); |
tasak | 9b2c7fe | 2017-01-31 19:40:34 | [diff] [blame] | 1846 | UMA_HISTOGRAM_MEMORY_KB( |
tasak | 72f6404 | 2017-01-19 14:02:53 | [diff] [blame] | 1847 | "PurgeAndSuspend.Experimental.MemoryGrowth.TotalAllocatedKB", |
| 1848 | GET_MEMORY_GROWTH(memory_metrics, purge_and_suspend_memory_metrics_, |
| 1849 | total_allocated_mb) * 1024); |
jdduke | 73220f0 | 2015-09-04 17:03:51 | [diff] [blame] | 1850 | } |
| 1851 | |
sadrul | 6d310fa | 2016-08-04 02:12:16 | [diff] [blame] | 1852 | scoped_refptr<gpu::GpuChannelHost> RenderThreadImpl::EstablishGpuChannelSync() { |
[email protected] | d13f35d | 2012-05-18 02:28:15 | [diff] [blame] | 1853 | TRACE_EVENT0("gpu", "RenderThreadImpl::EstablishGpuChannelSync"); |
| 1854 | |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 1855 | if (gpu_channel_) { |
[email protected] | 1082b1d | 2010-03-30 00:31:22 | [diff] [blame] | 1856 | // Do nothing if we already have a GPU channel or are already |
| 1857 | // establishing one. |
[email protected] | 7951bfe | 2013-06-13 01:43:34 | [diff] [blame] | 1858 | if (!gpu_channel_->IsLost()) |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 1859 | return gpu_channel_; |
[email protected] | 6217d39 | 2010-03-25 22:08:35 | [diff] [blame] | 1860 | |
| 1861 | // Recreate the channel if it has been lost. |
piman | 765e528 | 2015-05-08 03:43:01 | [diff] [blame] | 1862 | gpu_channel_->DestroyChannel(); |
penghuang | e1d8651 | 2016-07-08 18:15:00 | [diff] [blame] | 1863 | gpu_channel_ = nullptr; |
[email protected] | 6217d39 | 2010-03-25 22:08:35 | [diff] [blame] | 1864 | } |
| 1865 | |
sadrul | 5354659 | 2016-12-17 01:44:21 | [diff] [blame] | 1866 | gpu_channel_ = gpu_->EstablishGpuChannelSync(); |
| 1867 | if (gpu_channel_) |
| 1868 | GetContentClient()->SetGpuInfo(gpu_channel_->gpu_info()); |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 1869 | return gpu_channel_; |
[email protected] | 3bf4d53 | 2010-03-27 00:23:34 | [diff] [blame] | 1870 | } |
| 1871 | |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1872 | void RenderThreadImpl::RequestNewCompositorFrameSink( |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1873 | bool use_software, |
| 1874 | int routing_id, |
| 1875 | scoped_refptr<FrameSwapMessageQueue> frame_swap_message_queue, |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1876 | const GURL& url, |
| 1877 | const CompositorFrameSinkCallback& callback) { |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1878 | const base::CommandLine& command_line = |
| 1879 | *base::CommandLine::ForCurrentProcess(); |
| 1880 | if (command_line.HasSwitch(switches::kDisableGpuCompositing)) |
| 1881 | use_software = true; |
| 1882 | |
sadrul | 943e3b3 | 2016-08-04 18:22:59 | [diff] [blame] | 1883 | #if defined(USE_AURA) |
fsamuel | 098eade | 2017-03-21 18:06:14 | [diff] [blame] | 1884 | if (!use_software && IsRunningInMash()) { |
sadrul | be22c4f | 2017-03-14 06:59:25 | [diff] [blame] | 1885 | scoped_refptr<gpu::GpuChannelHost> channel = EstablishGpuChannelSync(); |
| 1886 | // If the channel could not be established correctly, then return null. This |
| 1887 | // would cause the compositor to wait and try again at a later time. |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1888 | if (!channel) { |
| 1889 | callback.Run(nullptr); |
| 1890 | return; |
| 1891 | } |
fsamuel | 95c974eb | 2017-03-22 10:00:25 | [diff] [blame^] | 1892 | RendererWindowTreeClient::Get(routing_id) |
| 1893 | ->RequestCompositorFrameSink( |
| 1894 | gpu_->CreateContextProvider(std::move(channel)), |
| 1895 | GetGpuMemoryBufferManager(), callback); |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1896 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1897 | } |
| 1898 | #endif |
| 1899 | |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 1900 | uint32_t compositor_frame_sink_id = g_next_compositor_frame_sink_id++; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1901 | |
| 1902 | if (command_line.HasSwitch(switches::kEnableVulkan)) { |
| 1903 | scoped_refptr<cc::VulkanContextProvider> vulkan_context_provider = |
| 1904 | cc::VulkanInProcessContextProvider::Create(); |
| 1905 | if (vulkan_context_provider) { |
| 1906 | DCHECK(!layout_test_mode()); |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1907 | callback.Run(base::MakeUnique<RendererCompositorFrameSink>( |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 1908 | routing_id, compositor_frame_sink_id, |
enne | 077ba486 | 2016-09-12 20:59:53 | [diff] [blame] | 1909 | CreateExternalBeginFrameSource(routing_id), |
| 1910 | std::move(vulkan_context_provider), |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1911 | std::move(frame_swap_message_queue))); |
| 1912 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1913 | } |
| 1914 | } |
| 1915 | |
| 1916 | // Create a gpu process channel and verify we want to use GPU compositing |
| 1917 | // before creating any context providers. |
| 1918 | scoped_refptr<gpu::GpuChannelHost> gpu_channel_host; |
| 1919 | if (!use_software) { |
sadrul | 6d310fa | 2016-08-04 02:12:16 | [diff] [blame] | 1920 | gpu_channel_host = EstablishGpuChannelSync(); |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1921 | if (!gpu_channel_host) { |
| 1922 | // Cause the compositor to wait and try again. |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1923 | callback.Run(nullptr); |
| 1924 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1925 | } |
| 1926 | // We may get a valid channel, but with a software renderer. In that case, |
| 1927 | // disable GPU compositing. |
| 1928 | if (gpu_channel_host->gpu_info().software_rendering) |
| 1929 | use_software = true; |
| 1930 | } |
| 1931 | |
| 1932 | if (use_software) { |
| 1933 | DCHECK(!layout_test_mode()); |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1934 | callback.Run(base::MakeUnique<RendererCompositorFrameSink>( |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 1935 | routing_id, compositor_frame_sink_id, |
piman | c44437a2 | 2016-10-29 00:09:22 | [diff] [blame] | 1936 | CreateExternalBeginFrameSource(routing_id), nullptr, nullptr, nullptr, |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1937 | shared_bitmap_manager(), std::move(frame_swap_message_queue))); |
| 1938 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1939 | } |
| 1940 | |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1941 | scoped_refptr<ui::ContextProviderCommandBuffer> worker_context_provider = |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1942 | SharedCompositorWorkerContextProvider(); |
| 1943 | if (!worker_context_provider) { |
| 1944 | // Cause the compositor to wait and try again. |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1945 | callback.Run(nullptr); |
| 1946 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1947 | } |
| 1948 | |
| 1949 | // The renderer compositor context doesn't do a lot of stuff, so we don't |
| 1950 | // expect it to need a lot of space for commands or transfer. Raster and |
| 1951 | // uploads happen on the worker context instead. |
| 1952 | gpu::SharedMemoryLimits limits = gpu::SharedMemoryLimits::ForMailboxContext(); |
| 1953 | |
| 1954 | // This is for an offscreen context for the compositor. So the default |
| 1955 | // framebuffer doesn't need alpha, depth, stencil, antialiasing. |
| 1956 | gpu::gles2::ContextCreationAttribHelper attributes; |
| 1957 | attributes.alpha_size = -1; |
| 1958 | attributes.depth_size = 0; |
| 1959 | attributes.stencil_size = 0; |
| 1960 | attributes.samples = 0; |
| 1961 | attributes.sample_buffers = 0; |
| 1962 | attributes.bind_generates_resource = false; |
| 1963 | attributes.lose_context_when_out_of_memory = true; |
| 1964 | |
| 1965 | constexpr bool automatic_flushes = false; |
| 1966 | constexpr bool support_locking = false; |
| 1967 | |
| 1968 | // The compositor context shares resources with the worker context unless |
| 1969 | // the worker is async. |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1970 | ui::ContextProviderCommandBuffer* share_context = |
| 1971 | worker_context_provider.get(); |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1972 | if (IsAsyncWorkerContextEnabled()) |
| 1973 | share_context = nullptr; |
| 1974 | |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1975 | scoped_refptr<ui::ContextProviderCommandBuffer> context_provider( |
| 1976 | new ui::ContextProviderCommandBuffer( |
danakj | a40dd448 | 2016-06-28 01:14:10 | [diff] [blame] | 1977 | gpu_channel_host, gpu::GPU_STREAM_DEFAULT, |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1978 | gpu::GpuStreamPriority::NORMAL, gpu::kNullSurfaceHandle, url, |
piman | d488e8b4 | 2016-06-30 19:06:59 | [diff] [blame] | 1979 | automatic_flushes, support_locking, limits, attributes, share_context, |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 1980 | ui::command_buffer_metrics::RENDER_COMPOSITOR_CONTEXT)); |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1981 | |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1982 | if (layout_test_deps_) { |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1983 | callback.Run(layout_test_deps_->CreateCompositorFrameSink( |
jbroman | 6ccbc7d47 | 2016-07-27 04:45:41 | [diff] [blame] | 1984 | routing_id, std::move(gpu_channel_host), std::move(context_provider), |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1985 | std::move(worker_context_provider), GetGpuMemoryBufferManager(), this)); |
| 1986 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1987 | } |
| 1988 | |
| 1989 | #if defined(OS_ANDROID) |
| 1990 | if (sync_compositor_message_filter_) { |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1991 | callback.Run(base::MakeUnique<SynchronousCompositorFrameSink>( |
danakj | a40dd448 | 2016-06-28 01:14:10 | [diff] [blame] | 1992 | std::move(context_provider), std::move(worker_context_provider), |
danakj | e9cf581 | 2017-02-16 22:22:55 | [diff] [blame] | 1993 | GetGpuMemoryBufferManager(), shared_bitmap_manager(), routing_id, |
| 1994 | compositor_frame_sink_id, CreateExternalBeginFrameSource(routing_id), |
enne | 077ba486 | 2016-09-12 20:59:53 | [diff] [blame] | 1995 | sync_compositor_message_filter_.get(), |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 1996 | std::move(frame_swap_message_queue))); |
| 1997 | return; |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 1998 | } |
| 1999 | #endif |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 2000 | callback.Run(base::WrapUnique(new RendererCompositorFrameSink( |
danakj | 1120f4c | 2016-09-15 02:05:32 | [diff] [blame] | 2001 | routing_id, compositor_frame_sink_id, |
| 2002 | CreateExternalBeginFrameSource(routing_id), std::move(context_provider), |
fsamuel | cf3002e | 2017-03-20 23:13:47 | [diff] [blame] | 2003 | std::move(worker_context_provider), GetGpuMemoryBufferManager(), nullptr, |
| 2004 | std::move(frame_swap_message_queue)))); |
danakj | 83066a3 | 2016-06-21 02:34:49 | [diff] [blame] | 2005 | } |
| 2006 | |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 2007 | AssociatedInterfaceRegistry* |
| 2008 | RenderThreadImpl::GetAssociatedInterfaceRegistry() { |
| 2009 | return &associated_interfaces_; |
| 2010 | } |
| 2011 | |
jbroman | 6ccbc7d47 | 2016-07-27 04:45:41 | [diff] [blame] | 2012 | std::unique_ptr<cc::SwapPromise> |
| 2013 | RenderThreadImpl::RequestCopyOfOutputForLayoutTest( |
| 2014 | int32_t routing_id, |
| 2015 | std::unique_ptr<cc::CopyOutputRequest> request) { |
| 2016 | DCHECK(layout_test_deps_); |
| 2017 | return layout_test_deps_->RequestCopyOfOutput(routing_id, std::move(request)); |
| 2018 | } |
| 2019 | |
[email protected] | 180ef24 | 2013-11-07 06:50:46 | [diff] [blame] | 2020 | blink::WebMediaStreamCenter* RenderThreadImpl::CreateMediaStreamCenter( |
| 2021 | blink::WebMediaStreamCenterClient* client) { |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 2022 | #if BUILDFLAG(ENABLE_WEBRTC) |
[email protected] | 68e5fee | 2013-02-18 10:04:22 | [diff] [blame] | 2023 | if (!media_stream_center_) { |
| 2024 | media_stream_center_ = GetContentClient()->renderer() |
| 2025 | ->OverrideCreateWebMediaStreamCenter(client); |
| 2026 | if (!media_stream_center_) { |
dcheng | cedca561 | 2016-04-09 01:40:15 | [diff] [blame] | 2027 | std::unique_ptr<MediaStreamCenter> media_stream_center( |
[email protected] | 0107d8a | 2014-05-16 10:20:34 | [diff] [blame] | 2028 | new MediaStreamCenter(client, GetPeerConnectionDependencyFactory())); |
[email protected] | c129874 | 2013-07-17 04:06:32 | [diff] [blame] | 2029 | media_stream_center_ = media_stream_center.release(); |
[email protected] | 68e5fee | 2013-02-18 10:04:22 | [diff] [blame] | 2030 | } |
| 2031 | } |
[email protected] | d8cd837 | 2012-03-09 10:49:51 | [diff] [blame] | 2032 | #endif |
| 2033 | return media_stream_center_; |
| 2034 | } |
| 2035 | |
Brett Wilson | 0748bf41 | 2016-11-22 17:55:46 | [diff] [blame] | 2036 | #if BUILDFLAG(ENABLE_WEBRTC) |
[email protected] | 0107d8a | 2014-05-16 10:20:34 | [diff] [blame] | 2037 | PeerConnectionDependencyFactory* |
| 2038 | RenderThreadImpl::GetPeerConnectionDependencyFactory() { |
[email protected] | 83e0a48 | 2014-05-22 18:07:18 | [diff] [blame] | 2039 | return peer_connection_factory_.get(); |
[email protected] | 6ee10bd | 2012-09-13 09:01:53 | [diff] [blame] | 2040 | } |
[email protected] | 22fe91d | 2014-08-12 17:07:12 | [diff] [blame] | 2041 | #endif |
[email protected] | 6ee10bd | 2012-09-13 09:01:53 | [diff] [blame] | 2042 | |
rockot | 1587e33 | 2016-07-27 17:44:14 | [diff] [blame] | 2043 | mojom::RenderFrameMessageFilter* |
| 2044 | RenderThreadImpl::render_frame_message_filter() { |
| 2045 | if (!render_frame_message_filter_) |
| 2046 | GetChannel()->GetRemoteAssociatedInterface(&render_frame_message_filter_); |
| 2047 | return render_frame_message_filter_.get(); |
| 2048 | } |
| 2049 | |
rockot | e261d211 | 2016-09-21 22:22:23 | [diff] [blame] | 2050 | mojom::RenderMessageFilter* RenderThreadImpl::render_message_filter() { |
| 2051 | if (!render_message_filter_) |
| 2052 | GetChannel()->GetRemoteAssociatedInterface(&render_message_filter_); |
| 2053 | return render_message_filter_.get(); |
| 2054 | } |
| 2055 | |
jcivelli | 315d17f | 2016-11-29 16:15:05 | [diff] [blame] | 2056 | const scoped_refptr<mojom::ThreadSafeRenderMessageFilterAssociatedPtr>& |
| 2057 | RenderThreadImpl::thread_safe_render_message_filter() { |
| 2058 | return thread_safe_render_message_filter_; |
| 2059 | } |
| 2060 | |
penghuang | 346a46f9 | 2016-03-31 21:37:52 | [diff] [blame] | 2061 | gpu::GpuChannelHost* RenderThreadImpl::GetGpuChannel() { |
piman | 9fc22f3 | 2016-05-02 22:21:22 | [diff] [blame] | 2062 | if (!gpu_channel_) |
danakj | 3873e85 | 2016-05-05 00:46:07 | [diff] [blame] | 2063 | return nullptr; |
[email protected] | 7951bfe | 2013-06-13 01:43:34 | [diff] [blame] | 2064 | if (gpu_channel_->IsLost()) |
danakj | 3873e85 | 2016-05-05 00:46:07 | [diff] [blame] | 2065 | return nullptr; |
[email protected] | 6217d39 | 2010-03-25 22:08:35 | [diff] [blame] | 2066 | return gpu_channel_.get(); |
| 2067 | } |
| 2068 | |
chiniforooshan | 614d70a | 2017-03-17 01:19:33 | [diff] [blame] | 2069 | void RenderThreadImpl::OnFieldTrialGroupFinalized( |
| 2070 | const std::string& trial_name, |
| 2071 | const std::string& group_name) { |
| 2072 | mojom::FieldTrialRecorderPtr field_trial_recorder; |
| 2073 | GetRemoteInterfaces()->GetInterface(&field_trial_recorder); |
| 2074 | field_trial_recorder->FieldTrialActivated(trial_name); |
| 2075 | } |
| 2076 | |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 2077 | void RenderThreadImpl::CreateView(mojom::CreateViewParamsPtr params) { |
| 2078 | CompositorDependencies* compositor_deps = this; |
wjmaclean | 1d97062 | 2017-01-21 22:28:24 | [diff] [blame] | 2079 | is_scroll_animator_enabled_ = params->web_preferences.enable_scroll_animator; |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 2080 | // When bringing in render_view, also bring in webkit's glue and jsbindings. |
nick | f7b3822 | 2016-11-22 21:59:35 | [diff] [blame] | 2081 | RenderViewImpl::Create(compositor_deps, *params, |
| 2082 | RenderWidget::ShowCallback()); |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 2083 | } |
| 2084 | |
rockot | 53be7caf | 2016-10-04 20:17:08 | [diff] [blame] | 2085 | void RenderThreadImpl::CreateFrame(mojom::CreateFrameParamsPtr params) { |
| 2086 | // Debug cases of https://crbug.com/626802. |
| 2087 | base::debug::SetCrashKeyValue("newframe_routing_id", |
| 2088 | base::IntToString(params->routing_id)); |
| 2089 | base::debug::SetCrashKeyValue("newframe_proxy_id", |
| 2090 | base::IntToString(params->proxy_routing_id)); |
| 2091 | base::debug::SetCrashKeyValue("newframe_opener_id", |
| 2092 | base::IntToString(params->opener_routing_id)); |
| 2093 | base::debug::SetCrashKeyValue("newframe_parent_id", |
| 2094 | base::IntToString(params->parent_routing_id)); |
| 2095 | base::debug::SetCrashKeyValue("newframe_widget_id", |
| 2096 | base::IntToString( |
| 2097 | params->widget_params->routing_id)); |
| 2098 | base::debug::SetCrashKeyValue("newframe_widget_hidden", |
| 2099 | params->widget_params->hidden ? "yes" : "no"); |
| 2100 | base::debug::SetCrashKeyValue("newframe_replicated_origin", |
| 2101 | params->replication_state.origin.Serialize()); |
| 2102 | base::debug::SetCrashKeyValue("newframe_oopifs_possible", |
| 2103 | SiteIsolationPolicy::AreCrossProcessFramesPossible() ? "yes" : "no"); |
| 2104 | CompositorDependencies* compositor_deps = this; |
| 2105 | RenderFrameImpl::CreateFrame( |
| 2106 | params->routing_id, params->proxy_routing_id, params->opener_routing_id, |
| 2107 | params->parent_routing_id, params->previous_sibling_routing_id, |
| 2108 | params->replication_state, compositor_deps, *params->widget_params, |
| 2109 | params->frame_owner_properties); |
| 2110 | } |
| 2111 | |
| 2112 | void RenderThreadImpl::CreateFrameProxy( |
| 2113 | int32_t routing_id, |
| 2114 | int32_t render_view_routing_id, |
| 2115 | int32_t opener_routing_id, |
| 2116 | int32_t parent_routing_id, |
| 2117 | const FrameReplicationState& replicated_state) { |
| 2118 | // Debug cases of https://crbug.com/575245. |
| 2119 | base::debug::SetCrashKeyValue("newproxy_proxy_id", |
| 2120 | base::IntToString(routing_id)); |
| 2121 | base::debug::SetCrashKeyValue("newproxy_view_id", |
| 2122 | base::IntToString(render_view_routing_id)); |
| 2123 | base::debug::SetCrashKeyValue("newproxy_opener_id", |
| 2124 | base::IntToString(opener_routing_id)); |
| 2125 | base::debug::SetCrashKeyValue("newproxy_parent_id", |
| 2126 | base::IntToString(parent_routing_id)); |
nick | 3b5a21f | 2016-11-22 23:07:11 | [diff] [blame] | 2127 | RenderFrameProxy::CreateFrameProxy( |
| 2128 | routing_id, render_view_routing_id, |
| 2129 | RenderFrameImpl::ResolveOpener(opener_routing_id), parent_routing_id, |
| 2130 | replicated_state); |
rockot | 53be7caf | 2016-10-04 20:17:08 | [diff] [blame] | 2131 | } |
| 2132 | |
rockot | a2db0da | 2016-10-18 17:39:11 | [diff] [blame] | 2133 | void RenderThreadImpl::OnNetworkConnectionChanged( |
| 2134 | net::NetworkChangeNotifier::ConnectionType type, |
| 2135 | double max_bandwidth_mbps) { |
| 2136 | bool online = type != net::NetworkChangeNotifier::CONNECTION_NONE; |
| 2137 | WebNetworkStateNotifier::setOnLine(online); |
| 2138 | for (auto& observer : observers_) |
| 2139 | observer.NetworkStateChanged(online); |
| 2140 | WebNetworkStateNotifier::setWebConnection( |
| 2141 | NetConnectionTypeToWebConnectionType(type), max_bandwidth_mbps); |
| 2142 | } |
| 2143 | |
| 2144 | void RenderThreadImpl::SetWebKitSharedTimersSuspended(bool suspend) { |
| 2145 | #if defined(OS_ANDROID) |
| 2146 | if (suspend) { |
| 2147 | renderer_scheduler_->SuspendTimerQueue(); |
| 2148 | } else { |
| 2149 | renderer_scheduler_->ResumeTimerQueue(); |
| 2150 | } |
| 2151 | webkit_shared_timer_suspended_ = suspend; |
| 2152 | #else |
| 2153 | NOTREACHED(); |
| 2154 | #endif |
| 2155 | } |
| 2156 | |
| 2157 | void RenderThreadImpl::UpdateScrollbarTheme( |
| 2158 | mojom::UpdateScrollbarThemeParamsPtr params) { |
| 2159 | #if defined(OS_MACOSX) |
| 2160 | static_cast<WebScrollbarBehaviorImpl*>( |
| 2161 | blink_platform_impl_->scrollbarBehavior()) |
| 2162 | ->set_jump_on_track_click(params->jump_on_track_click); |
| 2163 | |
| 2164 | blink::WebScrollbarTheme::updateScrollbarsWithNSDefaults( |
| 2165 | params->initial_button_delay, params->autoscroll_button_delay, |
| 2166 | params->preferred_scroller_style, params->redraw, |
| 2167 | params->button_placement); |
| 2168 | #else |
| 2169 | NOTREACHED(); |
| 2170 | #endif |
| 2171 | } |
| 2172 | |
| 2173 | void RenderThreadImpl::OnSystemColorsChanged( |
| 2174 | int32_t aqua_color_variant, |
| 2175 | const std::string& highlight_text_color, |
| 2176 | const std::string& highlight_color) { |
| 2177 | #if defined(OS_MACOSX) |
| 2178 | SystemColorsDidChange(aqua_color_variant, highlight_text_color, |
| 2179 | highlight_color); |
| 2180 | #else |
| 2181 | NOTREACHED(); |
| 2182 | #endif |
| 2183 | } |
| 2184 | |
| 2185 | void RenderThreadImpl::PurgePluginListCache(bool reload_pages) { |
brettw | 4b46108 | 2016-11-19 18:55:16 | [diff] [blame] | 2186 | #if BUILDFLAG(ENABLE_PLUGINS) |
rockot | a2db0da | 2016-10-18 17:39:11 | [diff] [blame] | 2187 | // The call below will cause a GetPlugins call with refresh=true, but at this |
| 2188 | // point we already know that the browser has refreshed its list, so disable |
| 2189 | // refresh temporarily to prevent each renderer process causing the list to be |
| 2190 | // regenerated. |
| 2191 | blink_platform_impl_->set_plugin_refresh_allowed(false); |
| 2192 | blink::resetPluginCache(reload_pages); |
| 2193 | blink_platform_impl_->set_plugin_refresh_allowed(true); |
| 2194 | |
| 2195 | for (auto& observer : observers_) |
| 2196 | observer.PluginListChanged(); |
| 2197 | #else |
| 2198 | NOTREACHED(); |
| 2199 | #endif |
| 2200 | } |
| 2201 | |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 2202 | void RenderThreadImpl::OnCreateNewSharedWorker( |
| 2203 | const WorkerProcessMsg_CreateWorker_Params& params) { |
| 2204 | // EmbeddedSharedWorkerStub will self-destruct. |
mkwst | cfa9893 | 2016-03-09 13:06:19 | [diff] [blame] | 2205 | new EmbeddedSharedWorkerStub( |
| 2206 | params.url, params.name, params.content_security_policy, |
| 2207 | params.security_policy_type, params.creation_address_space, |
| 2208 | params.pause_on_start, params.route_id); |
[email protected] | 0ec90d52 | 2014-03-12 16:28:19 | [diff] [blame] | 2209 | } |
| 2210 | |
[email protected] | 5071cb2 | 2013-07-10 02:19:06 | [diff] [blame] | 2211 | void RenderThreadImpl::OnMemoryPressure( |
| 2212 | base::MemoryPressureListener::MemoryPressureLevel memory_pressure_level) { |
hong.zheng | b28b533 | 2016-05-11 02:33:39 | [diff] [blame] | 2213 | TRACE_EVENT0("memory","RenderThreadImpl::OnMemoryPressure"); |
rmcilroy | 7fbb3bd5 | 2015-02-17 19:02:14 | [diff] [blame] | 2214 | if (blink_platform_impl_) { |
bashi | 5e843ac | 2016-06-17 07:44:35 | [diff] [blame] | 2215 | blink::WebMemoryCoordinator::onMemoryPressure( |
bashi | c577bfc | 2016-01-08 03:42:35 | [diff] [blame] | 2216 | static_cast<blink::WebMemoryPressureLevel>(memory_pressure_level)); |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 2217 | } |
| 2218 | if (memory_pressure_level == |
| 2219 | base::MemoryPressureListener::MEMORY_PRESSURE_LEVEL_CRITICAL) { |
| 2220 | ReleaseFreeMemory(); |
| 2221 | ClearMemory(); |
| 2222 | } |
| 2223 | } |
rmcilroy | ab967c97 | 2015-02-17 23:15:00 | [diff] [blame] | 2224 | |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 2225 | void RenderThreadImpl::OnMemoryStateChange(base::MemoryState state) { |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 2226 | if (blink_platform_impl_) { |
| 2227 | blink::WebMemoryCoordinator::onMemoryStateChange( |
| 2228 | static_cast<blink::MemoryState>(state)); |
| 2229 | } |
bashi | 233f65e | 2017-02-09 08:36:03 | [diff] [blame] | 2230 | } |
| 2231 | |
| 2232 | void RenderThreadImpl::OnPurgeMemory() { |
| 2233 | OnTrimMemoryImmediately(); |
| 2234 | ReleaseFreeMemory(); |
| 2235 | ClearMemory(); |
| 2236 | if (blink_platform_impl_) |
| 2237 | blink::WebMemoryCoordinator::onPurgeMemory(); |
hajimehoshi | 7bb3958 | 2016-10-12 04:30:57 | [diff] [blame] | 2238 | } |
| 2239 | |
| 2240 | void RenderThreadImpl::ClearMemory() { |
| 2241 | // Do not call into blink if it is not initialized. |
| 2242 | if (blink_platform_impl_) { |
| 2243 | // Purge Skia font cache, by setting it to 0 and then again to the |
| 2244 | // previous limit. |
| 2245 | size_t font_cache_limit = SkGraphics::SetFontCacheLimit(0); |
| 2246 | SkGraphics::SetFontCacheLimit(font_cache_limit); |
rmcilroy | 7fbb3bd5 | 2015-02-17 19:02:14 | [diff] [blame] | 2247 | } |
[email protected] | 5071cb2 | 2013-07-10 02:19:06 | [diff] [blame] | 2248 | } |
| 2249 | |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 2250 | scoped_refptr<base::SingleThreadTaskRunner> |
thestig | 529ad8a | 2016-07-08 20:30:12 | [diff] [blame] | 2251 | RenderThreadImpl::GetFileThreadTaskRunner() { |
fdoray | e94d864 | 2016-07-07 19:19:01 | [diff] [blame] | 2252 | DCHECK(message_loop()->task_runner()->BelongsToCurrentThread()); |
[email protected] | 59383c78 | 2013-04-17 16:43:27 | [diff] [blame] | 2253 | if (!file_thread_) { |
[email protected] | c6a7b86 | 2010-08-20 22:19:38 | [diff] [blame] | 2254 | file_thread_.reset(new base::Thread("Renderer::FILE")); |
| 2255 | file_thread_->Start(); |
| 2256 | } |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 2257 | return file_thread_->task_runner(); |
[email protected] | c6a7b86 | 2010-08-20 22:19:38 | [diff] [blame] | 2258 | } |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 2259 | |
acolwell | b403494 | 2014-08-28 15:42:43 | [diff] [blame] | 2260 | scoped_refptr<base::SingleThreadTaskRunner> |
| 2261 | RenderThreadImpl::GetMediaThreadTaskRunner() { |
fdoray | e94d864 | 2016-07-07 19:19:01 | [diff] [blame] | 2262 | DCHECK(message_loop()->task_runner()->BelongsToCurrentThread()); |
[email protected] | c1330c8 | 2013-06-06 02:23:25 | [diff] [blame] | 2263 | if (!media_thread_) { |
| 2264 | media_thread_.reset(new base::Thread("Media")); |
| 2265 | media_thread_->Start(); |
| 2266 | } |
skyostil | 2d3b5bd | 2015-05-27 15:40:59 | [diff] [blame] | 2267 | return media_thread_->task_runner(); |
[email protected] | c1330c8 | 2013-06-06 02:23:25 | [diff] [blame] | 2268 | } |
| 2269 | |
dcastagna | 4517a18 | 2015-08-05 19:51:03 | [diff] [blame] | 2270 | base::TaskRunner* RenderThreadImpl::GetWorkerTaskRunner() { |
prashant.n | fad657e | 2016-06-01 07:52:17 | [diff] [blame] | 2271 | return categorized_worker_pool_.get(); |
dcastagna | b880e8f | 2015-06-30 20:16:06 | [diff] [blame] | 2272 | } |
| 2273 | |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 2274 | scoped_refptr<ui::ContextProviderCommandBuffer> |
danakj | 0b4b94e3 | 2016-05-10 22:33:01 | [diff] [blame] | 2275 | RenderThreadImpl::SharedCompositorWorkerContextProvider() { |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2276 | DCHECK(IsMainThread()); |
| 2277 | // Try to reuse existing shared worker context provider. |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2278 | if (shared_worker_context_provider_) { |
| 2279 | // Note: If context is lost, delete reference after releasing the lock. |
boliu | 11afa7e | 2016-04-18 18:04:14 | [diff] [blame] | 2280 | cc::ContextProvider::ScopedContextLock lock( |
| 2281 | shared_worker_context_provider_.get()); |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2282 | if (shared_worker_context_provider_->ContextGL() |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 2283 | ->GetGraphicsResetStatusKHR() == GL_NO_ERROR) |
| 2284 | return shared_worker_context_provider_; |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2285 | } |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 2286 | |
sadrul | 6d310fa | 2016-08-04 02:12:16 | [diff] [blame] | 2287 | scoped_refptr<gpu::GpuChannelHost> gpu_channel_host( |
| 2288 | EstablishGpuChannelSync()); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 2289 | if (!gpu_channel_host) { |
| 2290 | shared_worker_context_provider_ = nullptr; |
| 2291 | return shared_worker_context_provider_; |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2292 | } |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 2293 | |
sunnyps | d8ce1c2 | 2016-05-10 18:02:40 | [diff] [blame] | 2294 | int32_t stream_id = gpu::GPU_STREAM_DEFAULT; |
| 2295 | gpu::GpuStreamPriority stream_priority = gpu::GpuStreamPriority::NORMAL; |
| 2296 | if (is_async_worker_context_enabled_) { |
| 2297 | stream_id = gpu_channel_host->GenerateStreamID(); |
| 2298 | stream_priority = gpu::GpuStreamPriority::LOW; |
| 2299 | } |
| 2300 | |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 2301 | bool support_locking = true; |
danakj | 0dd9e1e | 2016-05-11 22:15:09 | [diff] [blame] | 2302 | shared_worker_context_provider_ = CreateOffscreenContext( |
danakj | 9a04adc | 2016-05-16 22:45:07 | [diff] [blame] | 2303 | std::move(gpu_channel_host), gpu::SharedMemoryLimits(), support_locking, |
sadrul | 85cc5d8 | 2016-12-20 03:37:41 | [diff] [blame] | 2304 | ui::command_buffer_metrics::RENDER_WORKER_CONTEXT, stream_id, |
danakj | 0dd9e1e | 2016-05-11 22:15:09 | [diff] [blame] | 2305 | stream_priority); |
danakj | e8ec797e | 2016-04-19 04:08:43 | [diff] [blame] | 2306 | if (!shared_worker_context_provider_->BindToCurrentThread()) |
| 2307 | shared_worker_context_provider_ = nullptr; |
reveman | d180dfc3 | 2015-09-24 00:19:43 | [diff] [blame] | 2308 | return shared_worker_context_provider_; |
| 2309 | } |
| 2310 | |
[email protected] | 180ef24 | 2013-11-07 06:50:46 | [diff] [blame] | 2311 | void RenderThreadImpl::SampleGamepads(blink::WebGamepads* data) { |
tfarina | 556a723 | 2014-10-05 01:02:09 | [diff] [blame] | 2312 | blink_platform_impl_->sampleGamepads(*data); |
[email protected] | 0ff73656 | 2014-05-09 09:09:47 | [diff] [blame] | 2313 | } |
| 2314 | |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2315 | bool RenderThreadImpl::RendererIsHidden() const { |
| 2316 | return widget_count_ > 0 && hidden_widget_count_ == widget_count_; |
| 2317 | } |
| 2318 | |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2319 | void RenderThreadImpl::WidgetCreated() { |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2320 | bool renderer_was_hidden = RendererIsHidden(); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2321 | widget_count_++; |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2322 | if (renderer_was_hidden) |
| 2323 | OnRendererVisible(); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2324 | } |
| 2325 | |
| 2326 | void RenderThreadImpl::WidgetDestroyed() { |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2327 | // TODO(rmcilroy): Remove the restriction that destroyed widgets must be |
| 2328 | // unhidden before WidgetDestroyed is called. |
| 2329 | DCHECK_GT(widget_count_, 0); |
| 2330 | DCHECK_GT(widget_count_, hidden_widget_count_); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2331 | widget_count_--; |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2332 | if (RendererIsHidden()) |
| 2333 | OnRendererHidden(); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2334 | } |
| 2335 | |
| 2336 | void RenderThreadImpl::WidgetHidden() { |
| 2337 | DCHECK_LT(hidden_widget_count_, widget_count_); |
| 2338 | hidden_widget_count_++; |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2339 | if (RendererIsHidden()) |
| 2340 | OnRendererHidden(); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2341 | } |
| 2342 | |
| 2343 | void RenderThreadImpl::WidgetRestored() { |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2344 | bool renderer_was_hidden = RendererIsHidden(); |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2345 | DCHECK_GT(hidden_widget_count_, 0); |
| 2346 | hidden_widget_count_--; |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2347 | if (renderer_was_hidden) |
| 2348 | OnRendererVisible(); |
| 2349 | } |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2350 | |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2351 | void RenderThreadImpl::OnRendererHidden() { |
ulan | 432cd6e4 | 2016-03-01 15:59:14 | [diff] [blame] | 2352 | blink::mainThreadIsolate()->IsolateInBackgroundNotification(); |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2353 | // TODO(rmcilroy): Remove IdleHandler and replace it with an IdleTask |
| 2354 | // scheduled by the RendererScheduler - http://crbug.com/469210. |
ulan | 4a38519 | 2015-11-11 10:59:18 | [diff] [blame] | 2355 | if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) |
| 2356 | return; |
| 2357 | ScheduleIdleHandler(kInitialIdleHandlerDelayMs); |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2358 | } |
| 2359 | |
| 2360 | void RenderThreadImpl::OnRendererVisible() { |
ulan | 432cd6e4 | 2016-03-01 15:59:14 | [diff] [blame] | 2361 | blink::mainThreadIsolate()->IsolateInForegroundNotification(); |
rmcilroy | aa29605 | 2015-04-14 15:35:27 | [diff] [blame] | 2362 | if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2363 | return; |
[email protected] | b2db927 | 2014-01-10 17:42:00 | [diff] [blame] | 2364 | ScheduleIdleHandler(kLongIdleHandlerDelayMs); |
| 2365 | } |
| 2366 | |
ssid | 0603ca9f | 2015-06-09 16:48:08 | [diff] [blame] | 2367 | void RenderThreadImpl::ReleaseFreeMemory() { |
| 2368 | base::allocator::ReleaseFreeMemory(); |
penghuang | 342762b | 2016-12-02 21:04:58 | [diff] [blame] | 2369 | discardable_shared_memory_manager_->ReleaseFreeMemory(); |
ssid | 0603ca9f | 2015-06-09 16:48:08 | [diff] [blame] | 2370 | |
| 2371 | if (blink_platform_impl_) |
| 2372 | blink::decommitFreeableMemory(); |
| 2373 | } |
| 2374 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2375 | RenderThreadImpl::PendingFrameCreate::PendingFrameCreate( |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2376 | int routing_id, |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2377 | mojom::FrameRequest frame_request, |
| 2378 | mojom::FrameHostPtr frame_host) |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2379 | : routing_id_(routing_id), |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2380 | frame_request_(std::move(frame_request)), |
| 2381 | frame_host_(std::move(frame_host)) { |
| 2382 | // The RenderFrame may be deleted before the CreateFrame message is received. |
| 2383 | // In that case, the RenderFrameHost should cancel the create, which is |
| 2384 | // detected by setting an error handler on |frame_host_|. |
| 2385 | frame_host_.set_connection_error_handler(base::Bind( |
| 2386 | &RenderThreadImpl::PendingFrameCreate::OnConnectionError, |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2387 | base::Unretained(this))); |
| 2388 | } |
| 2389 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2390 | RenderThreadImpl::PendingFrameCreate::~PendingFrameCreate() { |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2391 | } |
| 2392 | |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2393 | void RenderThreadImpl::PendingFrameCreate::OnConnectionError() { |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2394 | size_t erased = |
ben | 76f52b24 | 2016-06-18 05:42:48 | [diff] [blame] | 2395 | RenderThreadImpl::current()->pending_frame_creates_.erase(routing_id_); |
rockot | f8fdd9b | 2015-12-16 22:22:35 | [diff] [blame] | 2396 | DCHECK_EQ(1u, erased); |
| 2397 | } |
| 2398 | |
hong.zheng | b28b533 | 2016-05-11 02:33:39 | [diff] [blame] | 2399 | void RenderThreadImpl::OnSyncMemoryPressure( |
| 2400 | base::MemoryPressureListener::MemoryPressureLevel memory_pressure_level) { |
| 2401 | if (!blink::mainThreadIsolate()) |
| 2402 | return; |
| 2403 | |
| 2404 | v8::MemoryPressureLevel v8_memory_pressure_level = |
| 2405 | static_cast<v8::MemoryPressureLevel>(memory_pressure_level); |
| 2406 | |
| 2407 | // In order to reduce performance impact, translate critical level to |
| 2408 | // moderate level for foregroud renderer. |
| 2409 | if (!RendererIsHidden() && |
| 2410 | v8_memory_pressure_level == v8::MemoryPressureLevel::kCritical) |
| 2411 | v8_memory_pressure_level = v8::MemoryPressureLevel::kModerate; |
| 2412 | |
| 2413 | blink::mainThreadIsolate()->MemoryPressureNotification( |
| 2414 | v8_memory_pressure_level); |
| 2415 | blink::MemoryPressureNotificationToWorkerThreadIsolates( |
| 2416 | v8_memory_pressure_level); |
| 2417 | } |
| 2418 | |
bashi | c4b4afcb | 2016-08-23 06:37:52 | [diff] [blame] | 2419 | // Note that this would be called only when memory_coordinator is enabled. |
| 2420 | // OnSyncMemoryPressure() is never called in that case. |
| 2421 | void RenderThreadImpl::OnTrimMemoryImmediately() { |
| 2422 | if (blink::mainThreadIsolate()) { |
| 2423 | blink::mainThreadIsolate()->MemoryPressureNotification( |
| 2424 | v8::MemoryPressureLevel::kCritical); |
| 2425 | blink::MemoryPressureNotificationToWorkerThreadIsolates( |
| 2426 | v8::MemoryPressureLevel::kCritical); |
| 2427 | } |
| 2428 | } |
| 2429 | |
rockot | 067ca55f | 2016-09-30 22:00:15 | [diff] [blame] | 2430 | void RenderThreadImpl::OnRendererInterfaceRequest( |
| 2431 | mojom::RendererAssociatedRequest request) { |
| 2432 | DCHECK(!renderer_binding_.is_bound()); |
| 2433 | renderer_binding_.Bind(std::move(request)); |
| 2434 | } |
bashi | c4b4afcb | 2016-08-23 06:37:52 | [diff] [blame] | 2435 | |
[email protected] | e9ff79c | 2012-10-19 21:31:26 | [diff] [blame] | 2436 | } // namespace content |