Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 <algorithm> | 7 #include <algorithm> |
| 8 #include <limits> | 8 #include <limits> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 39 #include "cc/layers/scrollbar_layer_impl_base.h" | 39 #include "cc/layers/scrollbar_layer_impl_base.h" |
| 40 #include "cc/output/compositor_frame_metadata.h" | 40 #include "cc/output/compositor_frame_metadata.h" |
| 41 #include "cc/output/copy_output_request.h" | 41 #include "cc/output/copy_output_request.h" |
| 42 #include "cc/output/delegating_renderer.h" | 42 #include "cc/output/delegating_renderer.h" |
| 43 #include "cc/output/gl_renderer.h" | 43 #include "cc/output/gl_renderer.h" |
| 44 #include "cc/output/software_renderer.h" | 44 #include "cc/output/software_renderer.h" |
| 45 #include "cc/quads/render_pass_draw_quad.h" | 45 #include "cc/quads/render_pass_draw_quad.h" |
| 46 #include "cc/quads/shared_quad_state.h" | 46 #include "cc/quads/shared_quad_state.h" |
| 47 #include "cc/quads/solid_color_draw_quad.h" | 47 #include "cc/quads/solid_color_draw_quad.h" |
| 48 #include "cc/quads/texture_draw_quad.h" | 48 #include "cc/quads/texture_draw_quad.h" |
| 49 #include "cc/resources/bitmap_raster_worker_pool.h" | |
| 49 #include "cc/resources/eviction_tile_priority_queue.h" | 50 #include "cc/resources/eviction_tile_priority_queue.h" |
| 50 #include "cc/resources/gpu_raster_worker_pool.h" | 51 #include "cc/resources/gpu_raster_worker_pool.h" |
| 51 #include "cc/resources/memory_history.h" | 52 #include "cc/resources/memory_history.h" |
| 52 #include "cc/resources/one_copy_raster_worker_pool.h" | 53 #include "cc/resources/one_copy_raster_worker_pool.h" |
| 53 #include "cc/resources/picture_layer_tiling.h" | 54 #include "cc/resources/picture_layer_tiling.h" |
| 54 #include "cc/resources/pixel_buffer_raster_worker_pool.h" | 55 #include "cc/resources/pixel_buffer_raster_worker_pool.h" |
| 55 #include "cc/resources/prioritized_resource_manager.h" | 56 #include "cc/resources/prioritized_resource_manager.h" |
| 56 #include "cc/resources/raster_tile_priority_queue.h" | 57 #include "cc/resources/raster_tile_priority_queue.h" |
| 57 #include "cc/resources/raster_worker_pool.h" | 58 #include "cc/resources/raster_worker_pool.h" |
| 58 #include "cc/resources/resource_pool.h" | 59 #include "cc/resources/resource_pool.h" |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 84 "LayerTreeHostImpl", | 85 "LayerTreeHostImpl", |
| 85 id); | 86 id); |
| 86 return; | 87 return; |
| 87 } | 88 } |
| 88 | 89 |
| 89 TRACE_EVENT_ASYNC_END0("webkit", "LayerTreeHostImpl::SetVisible", id); | 90 TRACE_EVENT_ASYNC_END0("webkit", "LayerTreeHostImpl::SetVisible", id); |
| 90 } | 91 } |
| 91 | 92 |
| 92 size_t GetMaxTransferBufferUsageBytes(cc::ContextProvider* context_provider, | 93 size_t GetMaxTransferBufferUsageBytes(cc::ContextProvider* context_provider, |
| 93 double refresh_rate) { | 94 double refresh_rate) { |
| 94 // Software compositing should not use this value in production. Just use a | |
| 95 // default value when testing uploads with the software compositor. | |
| 96 if (!context_provider) | |
|
vmpstr
2014/09/24 16:31:51
Can you instead DCHECK(context_provider)
reveman
2014/09/24 17:25:27
I think it was always awkward that we could pass N
| |
| 97 return std::numeric_limits<size_t>::max(); | |
| 98 | |
| 99 // We want to make sure the default transfer buffer size is equal to the | 95 // We want to make sure the default transfer buffer size is equal to the |
| 100 // amount of data that can be uploaded by the compositor to avoid stalling | 96 // amount of data that can be uploaded by the compositor to avoid stalling |
| 101 // the pipeline. | 97 // the pipeline. |
| 102 // For reference Chromebook Pixel can upload 1MB in about 0.5ms. | 98 // For reference Chromebook Pixel can upload 1MB in about 0.5ms. |
| 103 const size_t kMaxBytesUploadedPerMs = 1024 * 1024 * 2; | 99 const size_t kMaxBytesUploadedPerMs = 1024 * 1024 * 2; |
| 104 | 100 |
| 105 // We need to upload at least enough work to keep the GPU process busy until | 101 // We need to upload at least enough work to keep the GPU process busy until |
| 106 // the next time it can handle a request to start more uploads from the | 102 // the next time it can handle a request to start more uploads from the |
| 107 // compositor. We assume that it will pick up any sent upload requests within | 103 // compositor. We assume that it will pick up any sent upload requests within |
| 108 // the time of a vsync, since the browser will want to swap a frame within | 104 // the time of a vsync, since the browser will want to swap a frame within |
| 109 // that time interval, and then uploads should have a chance to be processed. | 105 // that time interval, and then uploads should have a chance to be processed. |
| 110 size_t ms_per_frame = std::floor(1000.0 / refresh_rate); | 106 size_t ms_per_frame = std::floor(1000.0 / refresh_rate); |
| 111 size_t max_transfer_buffer_usage_bytes = | 107 size_t max_transfer_buffer_usage_bytes = |
| 112 ms_per_frame * kMaxBytesUploadedPerMs; | 108 ms_per_frame * kMaxBytesUploadedPerMs; |
| 113 | 109 |
| 114 // The context may request a lower limit based on the device capabilities. | 110 // The context may request a lower limit based on the device capabilities. |
| 115 return std::min( | 111 return std::min( |
| 116 context_provider->ContextCapabilities().max_transfer_buffer_usage_bytes, | 112 context_provider->ContextCapabilities().max_transfer_buffer_usage_bytes, |
| 117 max_transfer_buffer_usage_bytes); | 113 max_transfer_buffer_usage_bytes); |
| 118 } | 114 } |
| 119 | 115 |
| 120 unsigned GetMapImageTextureTarget(cc::ContextProvider* context_provider) { | 116 unsigned GetMapImageTextureTarget(cc::ContextProvider* context_provider) { |
| 121 if (!context_provider) | |
|
vmpstr
2014/09/24 16:31:51
Same here.
reveman
2014/09/24 17:25:27
Same reply as above.
| |
| 122 return GL_TEXTURE_2D; | |
| 123 | |
| 124 if (context_provider->ContextCapabilities().gpu.egl_image_external) | 117 if (context_provider->ContextCapabilities().gpu.egl_image_external) |
| 125 return GL_TEXTURE_EXTERNAL_OES; | 118 return GL_TEXTURE_EXTERNAL_OES; |
| 126 if (context_provider->ContextCapabilities().gpu.texture_rectangle) | 119 if (context_provider->ContextCapabilities().gpu.texture_rectangle) |
| 127 return GL_TEXTURE_RECTANGLE_ARB; | 120 return GL_TEXTURE_RECTANGLE_ARB; |
| 128 | 121 |
| 129 return GL_TEXTURE_2D; | 122 return GL_TEXTURE_2D; |
| 130 } | 123 } |
| 131 | 124 |
| 132 size_t GetMaxStagingResourceCount() { | 125 size_t GetMaxStagingResourceCount() { |
| 133 // Upper bound for number of staging resource to allow. | 126 // Upper bound for number of staging resource to allow. |
| (...skipping 1852 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1986 ResourcePool::Create(resource_provider_.get(), | 1979 ResourcePool::Create(resource_provider_.get(), |
| 1987 GL_TEXTURE_2D, | 1980 GL_TEXTURE_2D, |
| 1988 resource_provider_->best_texture_format()); | 1981 resource_provider_->best_texture_format()); |
| 1989 | 1982 |
| 1990 raster_worker_pool_ = | 1983 raster_worker_pool_ = |
| 1991 OneCopyRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), | 1984 OneCopyRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), |
| 1992 RasterWorkerPool::GetTaskGraphRunner(), | 1985 RasterWorkerPool::GetTaskGraphRunner(), |
| 1993 context_provider, | 1986 context_provider, |
| 1994 resource_provider_.get(), | 1987 resource_provider_.get(), |
| 1995 staging_resource_pool_.get()); | 1988 staging_resource_pool_.get()); |
| 1996 } else if (!UseZeroCopyRasterizer() && context_provider) { | 1989 } else if (UseZeroCopyRasterizer() && context_provider) { |
|
vmpstr
2014/09/24 16:31:51
I think this whole if/else if sequence is better w
reveman
2014/09/24 17:25:27
Yes, much better. Done.
| |
| 1990 resource_pool_ = | |
| 1991 ResourcePool::Create(resource_provider_.get(), | |
| 1992 GetMapImageTextureTarget(context_provider), | |
| 1993 resource_provider_->best_texture_format()); | |
| 1994 | |
| 1995 raster_worker_pool_ = | |
| 1996 ZeroCopyRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), | |
| 1997 RasterWorkerPool::GetTaskGraphRunner(), | |
| 1998 resource_provider_.get()); | |
| 1999 } else if (context_provider) { | |
| 1997 resource_pool_ = ResourcePool::Create( | 2000 resource_pool_ = ResourcePool::Create( |
| 1998 resource_provider_.get(), | 2001 resource_provider_.get(), |
| 1999 GL_TEXTURE_2D, | 2002 GL_TEXTURE_2D, |
| 2000 resource_provider_->memory_efficient_texture_format()); | 2003 resource_provider_->memory_efficient_texture_format()); |
| 2001 | 2004 |
| 2002 raster_worker_pool_ = PixelBufferRasterWorkerPool::Create( | 2005 raster_worker_pool_ = PixelBufferRasterWorkerPool::Create( |
| 2003 proxy_->ImplThreadTaskRunner(), | 2006 proxy_->ImplThreadTaskRunner(), |
| 2004 RasterWorkerPool::GetTaskGraphRunner(), | 2007 RasterWorkerPool::GetTaskGraphRunner(), |
| 2005 context_provider, | 2008 context_provider, |
| 2006 resource_provider_.get(), | 2009 resource_provider_.get(), |
| 2007 GetMaxTransferBufferUsageBytes(context_provider, | 2010 GetMaxTransferBufferUsageBytes(context_provider, |
| 2008 settings_.refresh_rate)); | 2011 settings_.refresh_rate)); |
| 2009 } else { | 2012 } else { |
| 2010 resource_pool_ = | 2013 resource_pool_ = |
| 2011 ResourcePool::Create(resource_provider_.get(), | 2014 ResourcePool::Create(resource_provider_.get(), |
| 2012 GetMapImageTextureTarget(context_provider), | 2015 GL_TEXTURE_2D, |
| 2013 resource_provider_->best_texture_format()); | 2016 resource_provider_->best_texture_format()); |
| 2014 | 2017 |
| 2015 raster_worker_pool_ = | 2018 raster_worker_pool_ = |
| 2016 ZeroCopyRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), | 2019 BitmapRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), |
| 2017 RasterWorkerPool::GetTaskGraphRunner(), | 2020 RasterWorkerPool::GetTaskGraphRunner(), |
| 2018 resource_provider_.get()); | 2021 resource_provider_.get()); |
| 2019 } | 2022 } |
| 2020 | 2023 |
| 2021 tile_manager_ = | 2024 tile_manager_ = |
| 2022 TileManager::Create(this, | 2025 TileManager::Create(this, |
| 2023 proxy_->ImplThreadTaskRunner(), | 2026 proxy_->ImplThreadTaskRunner(), |
| 2024 resource_pool_.get(), | 2027 resource_pool_.get(), |
| 2025 raster_worker_pool_->AsRasterizer(), | 2028 raster_worker_pool_->AsRasterizer(), |
| 2026 rendering_stats_instrumentation_); | 2029 rendering_stats_instrumentation_); |
| 2027 | 2030 |
| 2028 UpdateTileManagerMemoryPolicy(ActualManagedMemoryPolicy()); | 2031 UpdateTileManagerMemoryPolicy(ActualManagedMemoryPolicy()); |
| 2029 need_to_update_visible_tiles_before_draw_ = false; | 2032 need_to_update_visible_tiles_before_draw_ = false; |
| 2030 } | 2033 } |
| 2031 | 2034 |
| 2032 void LayerTreeHostImpl::DestroyTileManager() { | 2035 void LayerTreeHostImpl::DestroyTileManager() { |
| 2033 tile_manager_.reset(); | 2036 tile_manager_.reset(); |
| 2034 resource_pool_.reset(); | 2037 resource_pool_.reset(); |
| 2035 staging_resource_pool_.reset(); | 2038 staging_resource_pool_.reset(); |
| 2036 raster_worker_pool_.reset(); | 2039 raster_worker_pool_.reset(); |
| 2037 } | 2040 } |
| 2038 | 2041 |
| 2039 bool LayerTreeHostImpl::UsePendingTreeForSync() const { | 2042 bool LayerTreeHostImpl::UsePendingTreeForSync() const { |
| 2040 // In impl-side painting, synchronize to the pending tree so that it has | 2043 // In impl-side painting, synchronize to the pending tree so that it has |
| 2041 // time to raster before being displayed. | 2044 // time to raster before being displayed. |
| 2042 return settings_.impl_side_painting; | 2045 return settings_.impl_side_painting; |
| 2043 } | 2046 } |
| 2044 | 2047 |
| 2045 bool LayerTreeHostImpl::UseZeroCopyRasterizer() const { | 2048 bool LayerTreeHostImpl::UseZeroCopyRasterizer() const { |
| 2046 // Note: we use zero-copy by default when the renderer is using | 2049 return settings_.use_zero_copy && GetRendererCapabilities().using_map_image; |
| 2047 // shared memory resources. | |
| 2048 return (settings_.use_zero_copy || | |
| 2049 GetRendererCapabilities().using_shared_memory_resources) && | |
| 2050 GetRendererCapabilities().using_map_image; | |
| 2051 } | 2050 } |
| 2052 | 2051 |
| 2053 bool LayerTreeHostImpl::UseOneCopyRasterizer() const { | 2052 bool LayerTreeHostImpl::UseOneCopyRasterizer() const { |
| 2054 // Sync query support is required by one-copy rasterizer. | 2053 // Sync query support is required by one-copy rasterizer. |
| 2055 return settings_.use_one_copy && GetRendererCapabilities().using_map_image && | 2054 return settings_.use_one_copy && GetRendererCapabilities().using_map_image && |
| 2056 resource_provider_->use_sync_query(); | 2055 resource_provider_->use_sync_query(); |
| 2057 } | 2056 } |
| 2058 | 2057 |
| 2059 void LayerTreeHostImpl::EnforceZeroBudget(bool zero_budget) { | 2058 void LayerTreeHostImpl::EnforceZeroBudget(bool zero_budget) { |
| 2060 SetManagedMemoryPolicy(cached_managed_memory_policy_, zero_budget); | 2059 SetManagedMemoryPolicy(cached_managed_memory_policy_, zero_budget); |
| (...skipping 1323 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3384 } | 3383 } |
| 3385 | 3384 |
| 3386 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { | 3385 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { |
| 3387 std::vector<PictureLayerImpl*>::iterator it = | 3386 std::vector<PictureLayerImpl*>::iterator it = |
| 3388 std::find(picture_layers_.begin(), picture_layers_.end(), layer); | 3387 std::find(picture_layers_.begin(), picture_layers_.end(), layer); |
| 3389 DCHECK(it != picture_layers_.end()); | 3388 DCHECK(it != picture_layers_.end()); |
| 3390 picture_layers_.erase(it); | 3389 picture_layers_.erase(it); |
| 3391 } | 3390 } |
| 3392 | 3391 |
| 3393 } // namespace cc | 3392 } // namespace cc |
| OLD | NEW |