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

Side by Side Diff: cc/resources/resource_provider.cc

Issue 874353007: cc: Remove SkSurface cache from Resource (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: merge and move surface creation into constructor Created 5 years, 10 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
« no previous file with comments | « cc/resources/resource_provider.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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/resources/resource_provider.h" 5 #include "cc/resources/resource_provider.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <limits> 8 #include <limits>
9 9
10 #include "base/containers/hash_tables.h" 10 #include "base/containers/hash_tables.h"
(...skipping 1069 matching lines...) Expand 10 before | Expand all | Expand 10 after
1080 gpu_memory_buffer_manager_->AllocateGpuMemoryBuffer( 1080 gpu_memory_buffer_manager_->AllocateGpuMemoryBuffer(
1081 size_, ToGpuMemoryBufferFormat(format_), gfx::GpuMemoryBuffer::MAP); 1081 size_, ToGpuMemoryBufferFormat(format_), gfx::GpuMemoryBuffer::MAP);
1082 gpu_memory_buffer_ = gpu_memory_buffer.release(); 1082 gpu_memory_buffer_ = gpu_memory_buffer.release();
1083 } 1083 }
1084 1084
1085 return gpu_memory_buffer_; 1085 return gpu_memory_buffer_;
1086 } 1086 }
1087 1087
1088 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr( 1088 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr(
1089 ResourceProvider* resource_provider, 1089 ResourceProvider* resource_provider,
1090 ResourceProvider::ResourceId resource_id) 1090 ResourceProvider::ResourceId resource_id,
1091 bool use_distance_field_text,
1092 bool can_use_lcd_text,
1093 int msaa_sample_count)
1091 : resource_provider_(resource_provider), 1094 : resource_provider_(resource_provider),
1092 resource_(resource_provider->LockForWrite(resource_id)) { 1095 resource_(resource_provider->LockForWrite(resource_id)) {
1093 } 1096 // Create the sk_surface.
1094
1095 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() {
1096 DCHECK(thread_checker_.CalledOnValidThread());
1097 resource_provider_->UnlockForWrite(resource_);
1098 }
1099
1100 SkSurface* ResourceProvider::ScopedWriteLockGr::GetSkSurface(
1101 bool use_distance_field_text,
1102 bool can_use_lcd_text,
1103 int msaa_sample_count) {
1104 DCHECK(thread_checker_.CalledOnValidThread()); 1097 DCHECK(thread_checker_.CalledOnValidThread());
1105 DCHECK(resource_->locked_for_write); 1098 DCHECK(resource_->locked_for_write);
1106 1099
1107 bool create_surface = 1100 resource_provider_->LazyAllocate(resource_);
1108 !resource_->sk_surface.get() ||
1109 !SurfaceHasMatchingProperties(use_distance_field_text, can_use_lcd_text);
1110 if (create_surface) {
1111 resource_provider_->LazyAllocate(resource_);
1112 1101
1113 GrBackendTextureDesc desc; 1102 GrBackendTextureDesc desc;
1114 desc.fFlags = kRenderTarget_GrBackendTextureFlag; 1103 desc.fFlags = kRenderTarget_GrBackendTextureFlag;
1115 desc.fWidth = resource_->size.width(); 1104 desc.fWidth = resource_->size.width();
1116 desc.fHeight = resource_->size.height(); 1105 desc.fHeight = resource_->size.height();
1117 desc.fConfig = ToGrPixelConfig(resource_->format); 1106 desc.fConfig = ToGrPixelConfig(resource_->format);
1118 desc.fOrigin = kTopLeft_GrSurfaceOrigin; 1107 desc.fOrigin = kTopLeft_GrSurfaceOrigin;
1119 desc.fTextureHandle = resource_->gl_id; 1108 desc.fTextureHandle = resource_->gl_id;
1120 desc.fSampleCnt = msaa_sample_count; 1109 desc.fSampleCnt = msaa_sample_count;
1121 1110
1122 class GrContext* gr_context = resource_provider_->GrContext(); 1111 class GrContext* gr_context = resource_provider_->GrContext();
1123 skia::RefPtr<GrTexture> gr_texture = 1112 skia::RefPtr<GrTexture> gr_texture =
1124 skia::AdoptRef(gr_context->wrapBackendTexture(desc)); 1113 skia::AdoptRef(gr_context->wrapBackendTexture(desc));
1125 if (!gr_texture) 1114 if (gr_texture) {
1126 return nullptr;
1127 uint32_t flags = use_distance_field_text 1115 uint32_t flags = use_distance_field_text
1128 ? SkSurfaceProps::kUseDistanceFieldFonts_Flag 1116 ? SkSurfaceProps::kUseDistanceFieldFonts_Flag
1129 : 0; 1117 : 0;
1130 // Use unknown pixel geometry to disable LCD text. 1118 // Use unknown pixel geometry to disable LCD text.
1131 SkSurfaceProps surface_props(flags, kUnknown_SkPixelGeometry); 1119 SkSurfaceProps surface_props(flags, kUnknown_SkPixelGeometry);
1132 if (can_use_lcd_text) { 1120 if (can_use_lcd_text) {
1133 // LegacyFontHost will get LCD text and skia figures out what type to use. 1121 // LegacyFontHost will get LCD text and skia figures out what type to use.
1134 surface_props = 1122 surface_props =
1135 SkSurfaceProps(flags, SkSurfaceProps::kLegacyFontHost_InitType); 1123 SkSurfaceProps(flags, SkSurfaceProps::kLegacyFontHost_InitType);
1136 } 1124 }
1137 resource_->sk_surface = skia::AdoptRef(SkSurface::NewRenderTargetDirect( 1125 sk_surface_ = skia::AdoptRef(SkSurface::NewRenderTargetDirect(
1138 gr_texture->asRenderTarget(), &surface_props)); 1126 gr_texture->asRenderTarget(), &surface_props));
1139 } 1127 }
1140 return resource_->sk_surface.get();
1141 } 1128 }
1142 1129
1143 bool ResourceProvider::ScopedWriteLockGr::SurfaceHasMatchingProperties( 1130 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() {
1144 bool use_distance_field_text, 1131 DCHECK(thread_checker_.CalledOnValidThread());
1145 bool can_use_lcd_text) const { 1132 resource_provider_->UnlockForWrite(resource_);
1146 const SkSurface* surface = resource_->sk_surface.get();
1147 bool surface_uses_distance_field_text =
1148 surface->props().isUseDistanceFieldFonts();
1149 bool surface_can_use_lcd_text =
1150 surface->props().pixelGeometry() != kUnknown_SkPixelGeometry;
1151 return use_distance_field_text == surface_uses_distance_field_text &&
1152 can_use_lcd_text == surface_can_use_lcd_text;
1153 } 1133 }
1154 1134
1155 ResourceProvider::SynchronousFence::SynchronousFence( 1135 ResourceProvider::SynchronousFence::SynchronousFence(
1156 gpu::gles2::GLES2Interface* gl) 1136 gpu::gles2::GLES2Interface* gl)
1157 : gl_(gl), has_synchronized_(true) { 1137 : gl_(gl), has_synchronized_(true) {
1158 } 1138 }
1159 1139
1160 ResourceProvider::SynchronousFence::~SynchronousFence() { 1140 ResourceProvider::SynchronousFence::~SynchronousFence() {
1161 } 1141 }
1162 1142
(...skipping 991 matching lines...) Expand 10 before | Expand all | Expand 10 after
2154 ContextProvider* context_provider = output_surface_->context_provider(); 2134 ContextProvider* context_provider = output_surface_->context_provider();
2155 return context_provider ? context_provider->ContextGL() : NULL; 2135 return context_provider ? context_provider->ContextGL() : NULL;
2156 } 2136 }
2157 2137
2158 class GrContext* ResourceProvider::GrContext() const { 2138 class GrContext* ResourceProvider::GrContext() const {
2159 ContextProvider* context_provider = output_surface_->context_provider(); 2139 ContextProvider* context_provider = output_surface_->context_provider();
2160 return context_provider ? context_provider->GrContext() : NULL; 2140 return context_provider ? context_provider->GrContext() : NULL;
2161 } 2141 }
2162 2142
2163 } // namespace cc 2143 } // namespace cc
OLDNEW
« no previous file with comments | « cc/resources/resource_provider.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698