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

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

Issue 286953008: cc: Allow DeferredInitialize to use DelegatingRenderer (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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 | Annotate | Revision Log
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 <algorithm> 7 #include <algorithm>
8 #include <limits> 8 #include <limits>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
(...skipping 1795 matching lines...) Expand 10 before | Expand all | Expand 10 after
1806 pending_tree_->ReleaseResources(); 1806 pending_tree_->ReleaseResources();
1807 if (recycle_tree_) 1807 if (recycle_tree_)
1808 recycle_tree_->ReleaseResources(); 1808 recycle_tree_->ReleaseResources();
1809 1809
1810 EvictAllUIResources(); 1810 EvictAllUIResources();
1811 } 1811 }
1812 1812
1813 void LayerTreeHostImpl::CreateAndSetRenderer( 1813 void LayerTreeHostImpl::CreateAndSetRenderer(
1814 OutputSurface* output_surface, 1814 OutputSurface* output_surface,
1815 ResourceProvider* resource_provider, 1815 ResourceProvider* resource_provider,
1816 bool skip_gl_renderer) { 1816 bool force_software_renderer) {
1817 DCHECK(!renderer_); 1817 DCHECK(!renderer_);
1818 if (output_surface->capabilities().delegated_rendering) { 1818 if (output_surface->capabilities().delegated_rendering &&
1819 !force_software_renderer) {
1819 renderer_ = DelegatingRenderer::Create( 1820 renderer_ = DelegatingRenderer::Create(
1820 this, &settings_, output_surface, resource_provider); 1821 this, &settings_, output_surface, resource_provider);
1821 } else if (output_surface->context_provider() && !skip_gl_renderer) { 1822 } else if (output_surface->context_provider() && !force_software_renderer) {
1822 renderer_ = GLRenderer::Create(this, 1823 renderer_ = GLRenderer::Create(this,
1823 &settings_, 1824 &settings_,
1824 output_surface, 1825 output_surface,
1825 resource_provider, 1826 resource_provider,
1826 texture_mailbox_deleter_.get(), 1827 texture_mailbox_deleter_.get(),
1827 settings_.highp_threshold_min); 1828 settings_.highp_threshold_min);
1828 } else if (output_surface->software_device()) { 1829 } else if (output_surface->software_device()) {
1829 renderer_ = SoftwareRenderer::Create( 1830 renderer_ = SoftwareRenderer::Create(
1830 this, &settings_, output_surface, resource_provider); 1831 this, &settings_, output_surface, resource_provider);
1831 } 1832 }
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after
1938 ResourceProvider::Create(output_surface.get(), 1939 ResourceProvider::Create(output_surface.get(),
1939 shared_bitmap_manager_, 1940 shared_bitmap_manager_,
1940 settings_.highp_threshold_min, 1941 settings_.highp_threshold_min,
1941 settings_.use_rgba_4444_textures, 1942 settings_.use_rgba_4444_textures,
1942 settings_.texture_id_allocation_chunk_size, 1943 settings_.texture_id_allocation_chunk_size,
1943 settings_.use_distance_field_text); 1944 settings_.use_distance_field_text);
1944 1945
1945 if (output_surface->capabilities().deferred_gl_initialization) 1946 if (output_surface->capabilities().deferred_gl_initialization)
1946 EnforceZeroBudget(true); 1947 EnforceZeroBudget(true);
1947 1948
1948 bool skip_gl_renderer = false; 1949 bool force_software_renderer =
1950 output_surface->capabilities().deferred_gl_initialization;
1949 CreateAndSetRenderer( 1951 CreateAndSetRenderer(
1950 output_surface.get(), resource_provider.get(), skip_gl_renderer); 1952 output_surface.get(), resource_provider.get(), force_software_renderer);
1951 1953
1952 transfer_buffer_memory_limit_ = 1954 transfer_buffer_memory_limit_ =
1953 GetMaxTransferBufferUsageBytes(output_surface->context_provider().get()); 1955 GetMaxTransferBufferUsageBytes(output_surface->context_provider().get());
1954 1956
1955 if (settings_.impl_side_painting) { 1957 if (settings_.impl_side_painting) {
1956 // Note: we use zero-copy rasterizer by default when the renderer is using 1958 // Note: we use zero-copy rasterizer by default when the renderer is using
1957 // shared memory resources. 1959 // shared memory resources.
1958 bool use_zero_copy = 1960 bool use_zero_copy =
1959 (settings_.use_zero_copy || 1961 (settings_.use_zero_copy ||
1960 GetRendererCapabilities().using_shared_memory_resources) && 1962 GetRendererCapabilities().using_shared_memory_resources) &&
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
2008 void LayerTreeHostImpl::DeferredInitialize() { 2010 void LayerTreeHostImpl::DeferredInitialize() {
2009 DCHECK(output_surface_->capabilities().deferred_gl_initialization); 2011 DCHECK(output_surface_->capabilities().deferred_gl_initialization);
2010 DCHECK(settings_.impl_side_painting); 2012 DCHECK(settings_.impl_side_painting);
2011 DCHECK(output_surface_->context_provider()); 2013 DCHECK(output_surface_->context_provider());
2012 2014
2013 ReleaseTreeResources(); 2015 ReleaseTreeResources();
2014 renderer_.reset(); 2016 renderer_.reset();
2015 2017
2016 resource_provider_->InitializeGL(); 2018 resource_provider_->InitializeGL();
2017 2019
2018 bool skip_gl_renderer = false; 2020 bool force_software_renderer = false;
2019 CreateAndSetRenderer( 2021 CreateAndSetRenderer(
2020 output_surface_.get(), resource_provider_.get(), skip_gl_renderer); 2022 output_surface_.get(), resource_provider_.get(), force_software_renderer);
2021 2023
2022 EnforceZeroBudget(false); 2024 EnforceZeroBudget(false);
2023 client_->SetNeedsCommitOnImplThread(); 2025 client_->SetNeedsCommitOnImplThread();
2024 } 2026 }
2025 2027
2026 void LayerTreeHostImpl::ReleaseGL() { 2028 void LayerTreeHostImpl::ReleaseGL() {
2027 DCHECK(output_surface_->capabilities().deferred_gl_initialization); 2029 DCHECK(output_surface_->capabilities().deferred_gl_initialization);
2028 DCHECK(settings_.impl_side_painting); 2030 DCHECK(settings_.impl_side_painting);
2029 DCHECK(output_surface_->context_provider()); 2031 DCHECK(output_surface_->context_provider());
2030 2032
2031 ReleaseTreeResources(); 2033 ReleaseTreeResources();
2032 renderer_.reset(); 2034 renderer_.reset();
2033 tile_manager_.reset(); 2035 tile_manager_.reset();
2034 resource_pool_.reset(); 2036 resource_pool_.reset();
2035 raster_worker_pool_.reset(); 2037 raster_worker_pool_.reset();
2036 direct_raster_worker_pool_.reset(); 2038 direct_raster_worker_pool_.reset();
2037 staging_resource_pool_.reset(); 2039 staging_resource_pool_.reset();
2038 resource_provider_->InitializeSoftware(); 2040 resource_provider_->InitializeSoftware();
2039 2041
2040 bool skip_gl_renderer = true; 2042 bool force_software_renderer = true;
2041 CreateAndSetRenderer( 2043 CreateAndSetRenderer(
2042 output_surface_.get(), resource_provider_.get(), skip_gl_renderer); 2044 output_surface_.get(), resource_provider_.get(), force_software_renderer);
2043 2045
2044 EnforceZeroBudget(true); 2046 EnforceZeroBudget(true);
2045 DCHECK(GetRendererCapabilities().using_map_image); 2047 DCHECK(GetRendererCapabilities().using_map_image);
2046 CreateAndSetTileManager(resource_provider_.get(), 2048 CreateAndSetTileManager(resource_provider_.get(),
2047 NULL, 2049 NULL,
2048 true, 2050 true,
2049 false, 2051 false,
2050 GetRendererCapabilities().allow_rasterize_on_demand); 2052 GetRendererCapabilities().allow_rasterize_on_demand);
2051 DCHECK(tile_manager_); 2053 DCHECK(tile_manager_);
2052 2054
(...skipping 1070 matching lines...) Expand 10 before | Expand all | Expand 10 after
3123 swap_promise_monitor_.erase(monitor); 3125 swap_promise_monitor_.erase(monitor);
3124 } 3126 }
3125 3127
3126 void LayerTreeHostImpl::NotifySwapPromiseMonitorsOfSetNeedsRedraw() { 3128 void LayerTreeHostImpl::NotifySwapPromiseMonitorsOfSetNeedsRedraw() {
3127 std::set<SwapPromiseMonitor*>::iterator it = swap_promise_monitor_.begin(); 3129 std::set<SwapPromiseMonitor*>::iterator it = swap_promise_monitor_.begin();
3128 for (; it != swap_promise_monitor_.end(); it++) 3130 for (; it != swap_promise_monitor_.end(); it++)
3129 (*it)->OnSetNeedsRedrawOnImpl(); 3131 (*it)->OnSetNeedsRedrawOnImpl();
3130 } 3132 }
3131 3133
3132 } // namespace cc 3134 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698