| 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 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 57 #include "cc/resources/texture_mailbox_deleter.h" | 57 #include "cc/resources/texture_mailbox_deleter.h" |
| 58 #include "cc/resources/ui_resource_bitmap.h" | 58 #include "cc/resources/ui_resource_bitmap.h" |
| 59 #include "cc/scheduler/delay_based_time_source.h" | 59 #include "cc/scheduler/delay_based_time_source.h" |
| 60 #include "cc/trees/damage_tracker.h" | 60 #include "cc/trees/damage_tracker.h" |
| 61 #include "cc/trees/layer_tree_host.h" | 61 #include "cc/trees/layer_tree_host.h" |
| 62 #include "cc/trees/layer_tree_host_common.h" | 62 #include "cc/trees/layer_tree_host_common.h" |
| 63 #include "cc/trees/layer_tree_impl.h" | 63 #include "cc/trees/layer_tree_impl.h" |
| 64 #include "cc/trees/occlusion_tracker.h" | 64 #include "cc/trees/occlusion_tracker.h" |
| 65 #include "cc/trees/single_thread_proxy.h" | 65 #include "cc/trees/single_thread_proxy.h" |
| 66 #include "cc/trees/tree_synchronizer.h" | 66 #include "cc/trees/tree_synchronizer.h" |
| 67 #include "gpu/command_buffer/client/gles2_interface.h" |
| 67 #include "gpu/GLES2/gl2extchromium.h" | 68 #include "gpu/GLES2/gl2extchromium.h" |
| 68 #include "ui/gfx/frame_time.h" | 69 #include "ui/gfx/frame_time.h" |
| 69 #include "ui/gfx/size_conversions.h" | 70 #include "ui/gfx/size_conversions.h" |
| 70 #include "ui/gfx/vector2d_conversions.h" | 71 #include "ui/gfx/vector2d_conversions.h" |
| 71 | 72 |
| 72 namespace { | 73 namespace { |
| 73 | 74 |
| 74 void DidVisibilityChange(cc::LayerTreeHostImpl* id, bool visible) { | 75 void DidVisibilityChange(cc::LayerTreeHostImpl* id, bool visible) { |
| 75 if (visible) { | 76 if (visible) { |
| 76 TRACE_EVENT_ASYNC_BEGIN1("webkit", | 77 TRACE_EVENT_ASYNC_BEGIN1("webkit", |
| (...skipping 1290 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1367 // because they were exported. | 1368 // because they were exported. |
| 1368 if (tile_manager_) { | 1369 if (tile_manager_) { |
| 1369 DCHECK(resource_pool_); | 1370 DCHECK(resource_pool_); |
| 1370 | 1371 |
| 1371 resource_pool_->CheckBusyResources(); | 1372 resource_pool_->CheckBusyResources(); |
| 1372 resource_pool_->ReduceResourceUsage(); | 1373 resource_pool_->ReduceResourceUsage(); |
| 1373 } | 1374 } |
| 1374 // If we're not visible, we likely released resources, so we want to | 1375 // If we're not visible, we likely released resources, so we want to |
| 1375 // aggressively flush here to make sure those DeleteTextures make it to the | 1376 // aggressively flush here to make sure those DeleteTextures make it to the |
| 1376 // GPU process to free up the memory. | 1377 // GPU process to free up the memory. |
| 1377 if (resource_provider_ && !visible_) | 1378 if (output_surface_->context_provider() && !visible_) { |
| 1378 resource_provider_->ShallowFlushIfSupported(); | 1379 output_surface_->context_provider()->ContextGL()->ShallowFlushCHROMIUM(); |
| 1380 } |
| 1379 } | 1381 } |
| 1380 | 1382 |
| 1381 void LayerTreeHostImpl::OnCanDrawStateChangedForTree() { | 1383 void LayerTreeHostImpl::OnCanDrawStateChangedForTree() { |
| 1382 client_->OnCanDrawStateChanged(CanDraw()); | 1384 client_->OnCanDrawStateChanged(CanDraw()); |
| 1383 } | 1385 } |
| 1384 | 1386 |
| 1385 CompositorFrameMetadata LayerTreeHostImpl::MakeCompositorFrameMetadata() const { | 1387 CompositorFrameMetadata LayerTreeHostImpl::MakeCompositorFrameMetadata() const { |
| 1386 CompositorFrameMetadata metadata; | 1388 CompositorFrameMetadata metadata; |
| 1387 metadata.device_scale_factor = device_scale_factor_; | 1389 metadata.device_scale_factor = device_scale_factor_; |
| 1388 metadata.page_scale_factor = active_tree_->total_page_scale_factor(); | 1390 metadata.page_scale_factor = active_tree_->total_page_scale_factor(); |
| (...skipping 513 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1902 ContextProvider* context_provider = output_surface_->context_provider(); | 1904 ContextProvider* context_provider = output_surface_->context_provider(); |
| 1903 transfer_buffer_memory_limit_ = | 1905 transfer_buffer_memory_limit_ = |
| 1904 GetMaxTransferBufferUsageBytes(context_provider); | 1906 GetMaxTransferBufferUsageBytes(context_provider); |
| 1905 | 1907 |
| 1906 if (use_gpu_rasterization_) { | 1908 if (use_gpu_rasterization_) { |
| 1907 resource_pool_ = | 1909 resource_pool_ = |
| 1908 ResourcePool::Create(resource_provider_.get(), | 1910 ResourcePool::Create(resource_provider_.get(), |
| 1909 GL_TEXTURE_2D, | 1911 GL_TEXTURE_2D, |
| 1910 resource_provider_->best_texture_format()); | 1912 resource_provider_->best_texture_format()); |
| 1911 | 1913 |
| 1912 raster_worker_pool_ = GpuRasterWorkerPool::Create( | 1914 raster_worker_pool_ = |
| 1913 proxy_->ImplThreadTaskRunner(), resource_provider_.get()); | 1915 GpuRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), |
| 1916 context_provider, |
| 1917 resource_provider_.get()); |
| 1914 on_demand_task_graph_runner_ = &synchronous_task_graph_runner_; | 1918 on_demand_task_graph_runner_ = &synchronous_task_graph_runner_; |
| 1915 } else if (UseZeroCopyTextureUpload()) { | 1919 } else if (UseZeroCopyTextureUpload()) { |
| 1916 resource_pool_ = | 1920 resource_pool_ = |
| 1917 ResourcePool::Create(resource_provider_.get(), | 1921 ResourcePool::Create(resource_provider_.get(), |
| 1918 GetMapImageTextureTarget(context_provider), | 1922 GetMapImageTextureTarget(context_provider), |
| 1919 resource_provider_->best_texture_format()); | 1923 resource_provider_->best_texture_format()); |
| 1920 | 1924 |
| 1921 raster_worker_pool_ = | 1925 raster_worker_pool_ = |
| 1922 ImageRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), | 1926 ImageRasterWorkerPool::Create(proxy_->ImplThreadTaskRunner(), |
| 1923 RasterWorkerPool::GetTaskGraphRunner(), | 1927 RasterWorkerPool::GetTaskGraphRunner(), |
| 1924 resource_provider_.get()); | 1928 resource_provider_.get()); |
| 1925 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); | 1929 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); |
| 1926 } else if (UseOneCopyTextureUpload()) { | 1930 } else if (UseOneCopyTextureUpload()) { |
| 1927 // We need to create a staging resource pool when using copy rasterizer. | 1931 // We need to create a staging resource pool when using copy rasterizer. |
| 1928 staging_resource_pool_ = | 1932 staging_resource_pool_ = |
| 1929 ResourcePool::Create(resource_provider_.get(), | 1933 ResourcePool::Create(resource_provider_.get(), |
| 1930 GetMapImageTextureTarget(context_provider), | 1934 GetMapImageTextureTarget(context_provider), |
| 1931 resource_provider_->best_texture_format()); | 1935 resource_provider_->best_texture_format()); |
| 1932 resource_pool_ = | 1936 resource_pool_ = |
| 1933 ResourcePool::Create(resource_provider_.get(), | 1937 ResourcePool::Create(resource_provider_.get(), |
| 1934 GL_TEXTURE_2D, | 1938 GL_TEXTURE_2D, |
| 1935 resource_provider_->best_texture_format()); | 1939 resource_provider_->best_texture_format()); |
| 1936 | 1940 |
| 1937 raster_worker_pool_ = ImageCopyRasterWorkerPool::Create( | 1941 raster_worker_pool_ = ImageCopyRasterWorkerPool::Create( |
| 1938 proxy_->ImplThreadTaskRunner(), | 1942 proxy_->ImplThreadTaskRunner(), |
| 1939 RasterWorkerPool::GetTaskGraphRunner(), | 1943 RasterWorkerPool::GetTaskGraphRunner(), |
| 1944 context_provider, |
| 1940 resource_provider_.get(), | 1945 resource_provider_.get(), |
| 1941 staging_resource_pool_.get()); | 1946 staging_resource_pool_.get()); |
| 1942 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); | 1947 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); |
| 1943 } else { | 1948 } else { |
| 1944 resource_pool_ = ResourcePool::Create( | 1949 resource_pool_ = ResourcePool::Create( |
| 1945 resource_provider_.get(), | 1950 resource_provider_.get(), |
| 1946 GL_TEXTURE_2D, | 1951 GL_TEXTURE_2D, |
| 1947 resource_provider_->memory_efficient_texture_format()); | 1952 resource_provider_->memory_efficient_texture_format()); |
| 1948 | 1953 |
| 1949 raster_worker_pool_ = PixelBufferRasterWorkerPool::Create( | 1954 raster_worker_pool_ = PixelBufferRasterWorkerPool::Create( |
| 1950 proxy_->ImplThreadTaskRunner(), | 1955 proxy_->ImplThreadTaskRunner(), |
| 1951 RasterWorkerPool::GetTaskGraphRunner(), | 1956 RasterWorkerPool::GetTaskGraphRunner(), |
| 1957 context_provider, |
| 1952 resource_provider_.get(), | 1958 resource_provider_.get(), |
| 1953 transfer_buffer_memory_limit_); | 1959 transfer_buffer_memory_limit_); |
| 1954 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); | 1960 on_demand_task_graph_runner_ = RasterWorkerPool::GetTaskGraphRunner(); |
| 1955 } | 1961 } |
| 1956 | 1962 |
| 1957 tile_manager_ = | 1963 tile_manager_ = |
| 1958 TileManager::Create(this, | 1964 TileManager::Create(this, |
| 1959 proxy_->ImplThreadTaskRunner(), | 1965 proxy_->ImplThreadTaskRunner(), |
| 1960 resource_pool_.get(), | 1966 resource_pool_.get(), |
| 1961 raster_worker_pool_->AsRasterizer(), | 1967 raster_worker_pool_->AsRasterizer(), |
| (...skipping 1284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3246 } | 3252 } |
| 3247 | 3253 |
| 3248 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { | 3254 void LayerTreeHostImpl::UnregisterPictureLayerImpl(PictureLayerImpl* layer) { |
| 3249 std::vector<PictureLayerImpl*>::iterator it = | 3255 std::vector<PictureLayerImpl*>::iterator it = |
| 3250 std::find(picture_layers_.begin(), picture_layers_.end(), layer); | 3256 std::find(picture_layers_.begin(), picture_layers_.end(), layer); |
| 3251 DCHECK(it != picture_layers_.end()); | 3257 DCHECK(it != picture_layers_.end()); |
| 3252 picture_layers_.erase(it); | 3258 picture_layers_.erase(it); |
| 3253 } | 3259 } |
| 3254 | 3260 |
| 3255 } // namespace cc | 3261 } // namespace cc |
| OLD | NEW |