Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(120)

Side by Side Diff: cc/trees/layer_tree_host_impl.cc

Issue 1910213005: cc: Refactor TileTaskWorkerPool. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@task_states
Patch Set: nits Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2011 The Chromium Authors. All rights reserved. 1 // Copyright 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "cc/trees/layer_tree_host_impl.h" 5 #include "cc/trees/layer_tree_host_impl.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <algorithm> 10 #include <algorithm>
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
72 #include "cc/raster/zero_copy_tile_task_worker_pool.h" 72 #include "cc/raster/zero_copy_tile_task_worker_pool.h"
73 #include "cc/resources/memory_history.h" 73 #include "cc/resources/memory_history.h"
74 #include "cc/resources/resource_pool.h" 74 #include "cc/resources/resource_pool.h"
75 #include "cc/resources/ui_resource_bitmap.h" 75 #include "cc/resources/ui_resource_bitmap.h"
76 #include "cc/scheduler/delay_based_time_source.h" 76 #include "cc/scheduler/delay_based_time_source.h"
77 #include "cc/tiles/eviction_tile_priority_queue.h" 77 #include "cc/tiles/eviction_tile_priority_queue.h"
78 #include "cc/tiles/gpu_image_decode_controller.h" 78 #include "cc/tiles/gpu_image_decode_controller.h"
79 #include "cc/tiles/picture_layer_tiling.h" 79 #include "cc/tiles/picture_layer_tiling.h"
80 #include "cc/tiles/raster_tile_priority_queue.h" 80 #include "cc/tiles/raster_tile_priority_queue.h"
81 #include "cc/tiles/software_image_decode_controller.h" 81 #include "cc/tiles/software_image_decode_controller.h"
82 #include "cc/tiles/tile_task_manager.h"
82 #include "cc/trees/damage_tracker.h" 83 #include "cc/trees/damage_tracker.h"
83 #include "cc/trees/draw_property_utils.h" 84 #include "cc/trees/draw_property_utils.h"
84 #include "cc/trees/latency_info_swap_promise_monitor.h" 85 #include "cc/trees/latency_info_swap_promise_monitor.h"
85 #include "cc/trees/layer_tree_host.h" 86 #include "cc/trees/layer_tree_host.h"
86 #include "cc/trees/layer_tree_host_common.h" 87 #include "cc/trees/layer_tree_host_common.h"
87 #include "cc/trees/layer_tree_impl.h" 88 #include "cc/trees/layer_tree_impl.h"
88 #include "cc/trees/single_thread_proxy.h" 89 #include "cc/trees/single_thread_proxy.h"
89 #include "cc/trees/tree_synchronizer.h" 90 #include "cc/trees/tree_synchronizer.h"
90 #include "gpu/GLES2/gl2extchromium.h" 91 #include "gpu/GLES2/gl2extchromium.h"
91 #include "gpu/command_buffer/client/gles2_interface.h" 92 #include "gpu/command_buffer/client/gles2_interface.h"
(...skipping 2052 matching lines...) Expand 10 before | Expand all | Expand 10 after
2144 // See note in LayerTreeImpl::UpdateDrawProperties. Renderer needs to be 2145 // See note in LayerTreeImpl::UpdateDrawProperties. Renderer needs to be
2145 // initialized to get max texture size. Also, after releasing resources, 2146 // initialized to get max texture size. Also, after releasing resources,
2146 // trees need another update to generate new ones. 2147 // trees need another update to generate new ones.
2147 active_tree_->set_needs_update_draw_properties(); 2148 active_tree_->set_needs_update_draw_properties();
2148 if (pending_tree_) 2149 if (pending_tree_)
2149 pending_tree_->set_needs_update_draw_properties(); 2150 pending_tree_->set_needs_update_draw_properties();
2150 client_->UpdateRendererCapabilitiesOnImplThread(); 2151 client_->UpdateRendererCapabilitiesOnImplThread();
2151 } 2152 }
2152 2153
2153 void LayerTreeHostImpl::CreateTileManagerResources() { 2154 void LayerTreeHostImpl::CreateTileManagerResources() {
2154 CreateResourceAndTileTaskWorkerPool(&tile_task_worker_pool_, &resource_pool_); 2155 std::unique_ptr<TileTaskWorkerPool> tile_task_worker_pool;
2156 CreateResourceAndTileTaskWorkerPool(&tile_task_worker_pool, &resource_pool_);
2155 2157
2156 if (use_gpu_rasterization_) { 2158 if (use_gpu_rasterization_) {
2157 image_decode_controller_ = base::WrapUnique(new GpuImageDecodeController( 2159 image_decode_controller_ = base::WrapUnique(new GpuImageDecodeController(
2158 output_surface_->worker_context_provider(), 2160 output_surface_->worker_context_provider(),
2159 settings_.renderer_settings.preferred_tile_format)); 2161 settings_.renderer_settings.preferred_tile_format));
2160 } else { 2162 } else {
2161 image_decode_controller_ = 2163 image_decode_controller_ =
2162 base::WrapUnique(new SoftwareImageDecodeController( 2164 base::WrapUnique(new SoftwareImageDecodeController(
2163 settings_.renderer_settings.preferred_tile_format)); 2165 settings_.renderer_settings.preferred_tile_format));
2164 } 2166 }
2165 2167
2168 // Pass the single-threaded synchronous task graph runner to the worker pool
2169 // if we're in synchronous single-threaded mode.
2170 TaskGraphRunner* task_graph_runner = task_graph_runner_;
2171 if (is_synchronous_single_threaded_) {
2172 DCHECK(!single_thread_synchronous_task_graph_runner_);
2173 single_thread_synchronous_task_graph_runner_.reset(
2174 new SynchronousTaskGraphRunner);
2175 task_graph_runner = single_thread_synchronous_task_graph_runner_.get();
2176 }
2177
2178 tile_task_manager_ = TileTaskManager::Create(std::move(tile_task_worker_pool),
2179 task_graph_runner);
2180
2166 // TODO(vmpstr): Initialize tile task limit at ctor time. 2181 // TODO(vmpstr): Initialize tile task limit at ctor time.
2167 tile_manager_->SetResources( 2182 tile_manager_->SetResources(
2168 resource_pool_.get(), tile_task_worker_pool_.get(), 2183 resource_pool_.get(), image_decode_controller_.get(),
2169 image_decode_controller_.get(), 2184 tile_task_manager_.get(),
2170 is_synchronous_single_threaded_ ? std::numeric_limits<size_t>::max() 2185 is_synchronous_single_threaded_ ? std::numeric_limits<size_t>::max()
2171 : settings_.scheduled_raster_task_limit, 2186 : settings_.scheduled_raster_task_limit,
2172 use_gpu_rasterization_); 2187 use_gpu_rasterization_);
2173 UpdateTileManagerMemoryPolicy(ActualManagedMemoryPolicy()); 2188 UpdateTileManagerMemoryPolicy(ActualManagedMemoryPolicy());
2174 } 2189 }
2175 2190
2176 void LayerTreeHostImpl::CreateResourceAndTileTaskWorkerPool( 2191 void LayerTreeHostImpl::CreateResourceAndTileTaskWorkerPool(
2177 std::unique_ptr<TileTaskWorkerPool>* tile_task_worker_pool, 2192 std::unique_ptr<TileTaskWorkerPool>* tile_task_worker_pool,
2178 std::unique_ptr<ResourcePool>* resource_pool) { 2193 std::unique_ptr<ResourcePool>* resource_pool) {
2179 DCHECK(GetTaskRunner()); 2194 DCHECK(GetTaskRunner());
2180 // TODO(vmpstr): Make this a DCHECK (or remove) when crbug.com/419086 is 2195 // TODO(vmpstr): Make this a DCHECK (or remove) when crbug.com/419086 is
2181 // resolved. 2196 // resolved.
2182 CHECK(resource_provider_); 2197 CHECK(resource_provider_);
2183 2198
2184 // Pass the single-threaded synchronous task graph runner to the worker pool
2185 // if we're in synchronous single-threaded mode.
2186 TaskGraphRunner* task_graph_runner = task_graph_runner_;
2187 if (is_synchronous_single_threaded_) {
2188 DCHECK(!single_thread_synchronous_task_graph_runner_);
2189 single_thread_synchronous_task_graph_runner_.reset(
2190 new SynchronousTaskGraphRunner);
2191 task_graph_runner = single_thread_synchronous_task_graph_runner_.get();
2192 }
2193
2194 ContextProvider* context_provider = output_surface_->context_provider(); 2199 ContextProvider* context_provider = output_surface_->context_provider();
2195 if (!context_provider) { 2200 if (!context_provider) {
2196 *resource_pool = 2201 *resource_pool =
2197 ResourcePool::Create(resource_provider_.get(), GetTaskRunner()); 2202 ResourcePool::Create(resource_provider_.get(), GetTaskRunner());
2198 2203
2199 *tile_task_worker_pool = BitmapTileTaskWorkerPool::Create( 2204 *tile_task_worker_pool =
2200 GetTaskRunner(), task_graph_runner, resource_provider_.get()); 2205 BitmapTileTaskWorkerPool::Create(resource_provider_.get());
2201 return; 2206 return;
2202 } 2207 }
2203 2208
2204 if (use_gpu_rasterization_) { 2209 if (use_gpu_rasterization_) {
2205 DCHECK(resource_provider_->output_surface()->worker_context_provider()); 2210 DCHECK(resource_provider_->output_surface()->worker_context_provider());
2206 2211
2207 *resource_pool = 2212 *resource_pool =
2208 ResourcePool::Create(resource_provider_.get(), GetTaskRunner()); 2213 ResourcePool::Create(resource_provider_.get(), GetTaskRunner());
2209 2214
2210 int msaa_sample_count = use_msaa_ ? RequestedMSAASampleCount() : 0; 2215 int msaa_sample_count = use_msaa_ ? RequestedMSAASampleCount() : 0;
2211 2216
2212 *tile_task_worker_pool = GpuTileTaskWorkerPool::Create( 2217 *tile_task_worker_pool = GpuTileTaskWorkerPool::Create(
2213 GetTaskRunner(), task_graph_runner, context_provider, 2218 context_provider, resource_provider_.get(),
2214 resource_provider_.get(), settings_.use_distance_field_text, 2219 settings_.use_distance_field_text, msaa_sample_count);
2215 msaa_sample_count);
2216 return; 2220 return;
2217 } 2221 }
2218 2222
2219 DCHECK(GetRendererCapabilities().using_image); 2223 DCHECK(GetRendererCapabilities().using_image);
2220 2224
2221 bool use_zero_copy = settings_.use_zero_copy; 2225 bool use_zero_copy = settings_.use_zero_copy;
2222 // TODO(reveman): Remove this when mojo supports worker contexts. 2226 // TODO(reveman): Remove this when mojo supports worker contexts.
2223 // crbug.com/522440 2227 // crbug.com/522440
2224 if (!resource_provider_->output_surface()->worker_context_provider()) { 2228 if (!resource_provider_->output_surface()->worker_context_provider()) {
2225 LOG(ERROR) 2229 LOG(ERROR)
2226 << "Forcing zero-copy tile initialization as worker context is missing"; 2230 << "Forcing zero-copy tile initialization as worker context is missing";
2227 use_zero_copy = true; 2231 use_zero_copy = true;
2228 } 2232 }
2229 2233
2230 if (use_zero_copy) { 2234 if (use_zero_copy) {
2231 *resource_pool = ResourcePool::CreateForGpuMemoryBufferResources( 2235 *resource_pool = ResourcePool::CreateForGpuMemoryBufferResources(
2232 resource_provider_.get(), GetTaskRunner()); 2236 resource_provider_.get(), GetTaskRunner());
2233 2237
2234 *tile_task_worker_pool = ZeroCopyTileTaskWorkerPool::Create( 2238 *tile_task_worker_pool = ZeroCopyTileTaskWorkerPool::Create(
2235 GetTaskRunner(), task_graph_runner, resource_provider_.get(), 2239 resource_provider_.get(),
2236 settings_.renderer_settings.preferred_tile_format); 2240 settings_.renderer_settings.preferred_tile_format);
2237 return; 2241 return;
2238 } 2242 }
2239 2243
2240 *resource_pool = 2244 *resource_pool =
2241 ResourcePool::Create(resource_provider_.get(), GetTaskRunner()); 2245 ResourcePool::Create(resource_provider_.get(), GetTaskRunner());
2242 2246
2243 int max_copy_texture_chromium_size = context_provider->ContextCapabilities() 2247 int max_copy_texture_chromium_size = context_provider->ContextCapabilities()
2244 .gpu.max_copy_texture_chromium_size; 2248 .gpu.max_copy_texture_chromium_size;
2245 2249
2246 *tile_task_worker_pool = OneCopyTileTaskWorkerPool::Create( 2250 *tile_task_worker_pool = OneCopyTileTaskWorkerPool::Create(
2247 GetTaskRunner(), task_graph_runner, context_provider, 2251 GetTaskRunner(), context_provider, resource_provider_.get(),
2248 resource_provider_.get(), max_copy_texture_chromium_size, 2252 max_copy_texture_chromium_size, settings_.use_partial_raster,
2249 settings_.use_partial_raster, settings_.max_staging_buffer_usage_in_bytes, 2253 settings_.max_staging_buffer_usage_in_bytes,
2250 settings_.renderer_settings.preferred_tile_format); 2254 settings_.renderer_settings.preferred_tile_format);
2251 } 2255 }
2252 2256
2253 void LayerTreeHostImpl::RecordMainFrameTiming( 2257 void LayerTreeHostImpl::RecordMainFrameTiming(
2254 const BeginFrameArgs& start_of_main_frame_args, 2258 const BeginFrameArgs& start_of_main_frame_args,
2255 const BeginFrameArgs& expected_next_main_frame_args) { 2259 const BeginFrameArgs& expected_next_main_frame_args) {
2256 std::vector<int64_t> request_ids; 2260 std::vector<int64_t> request_ids;
2257 active_tree_->GatherFrameTimingRequestIds(&request_ids); 2261 active_tree_->GatherFrameTimingRequestIds(&request_ids);
2258 if (request_ids.empty()) 2262 if (request_ids.empty())
2259 return; 2263 return;
(...skipping 14 matching lines...) Expand all
2274 void LayerTreeHostImpl::SetLayerTreeMutator(LayerTreeMutator* mutator) { 2278 void LayerTreeHostImpl::SetLayerTreeMutator(LayerTreeMutator* mutator) {
2275 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"), 2279 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("compositor-worker"),
2276 "LayerTreeHostImpl::SetLayerTreeMutator"); 2280 "LayerTreeHostImpl::SetLayerTreeMutator");
2277 mutator_ = mutator; 2281 mutator_ = mutator;
2278 } 2282 }
2279 2283
2280 void LayerTreeHostImpl::CleanUpTileManagerAndUIResources() { 2284 void LayerTreeHostImpl::CleanUpTileManagerAndUIResources() {
2281 ClearUIResources(); 2285 ClearUIResources();
2282 tile_manager_->FinishTasksAndCleanUp(); 2286 tile_manager_->FinishTasksAndCleanUp();
2283 resource_pool_ = nullptr; 2287 resource_pool_ = nullptr;
2284 tile_task_worker_pool_ = nullptr; 2288 tile_task_manager_ = nullptr;
2285 single_thread_synchronous_task_graph_runner_ = nullptr; 2289 single_thread_synchronous_task_graph_runner_ = nullptr;
2286 image_decode_controller_ = nullptr; 2290 image_decode_controller_ = nullptr;
2287 } 2291 }
2288 2292
2289 void LayerTreeHostImpl::ReleaseOutputSurface() { 2293 void LayerTreeHostImpl::ReleaseOutputSurface() {
2290 TRACE_EVENT0("cc", "LayerTreeHostImpl::ReleaseOutputSurface"); 2294 TRACE_EVENT0("cc", "LayerTreeHostImpl::ReleaseOutputSurface");
2291 2295
2292 // Since we will create a new resource provider, we cannot continue to use 2296 // Since we will create a new resource provider, we cannot continue to use
2293 // the old resources (i.e. render_surfaces and texture IDs). Clear them 2297 // the old resources (i.e. render_surfaces and texture IDs). Clear them
2294 // before we destroy the old resource provider. 2298 // before we destroy the old resource provider.
(...skipping 1685 matching lines...) Expand 10 before | Expand all | Expand 10 after
3980 return task_runner_provider_->HasImplThread(); 3984 return task_runner_provider_->HasImplThread();
3981 } 3985 }
3982 3986
3983 bool LayerTreeHostImpl::CommitToActiveTree() const { 3987 bool LayerTreeHostImpl::CommitToActiveTree() const {
3984 // In single threaded mode we skip the pending tree and commit directly to the 3988 // In single threaded mode we skip the pending tree and commit directly to the
3985 // active tree. 3989 // active tree.
3986 return !task_runner_provider_->HasImplThread(); 3990 return !task_runner_provider_->HasImplThread();
3987 } 3991 }
3988 3992
3989 } // namespace cc 3993 } // namespace cc
OLDNEW
« cc/tiles/tile_task_manager.cc ('K') | « cc/trees/layer_tree_host_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698