OLD | NEW |
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 977 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
988 | 988 |
989 resource->locked_for_write = false; | 989 resource->locked_for_write = false; |
990 resource->dirty_image = true; | 990 resource->dirty_image = true; |
991 | 991 |
992 // GpuMemoryBuffer provides direct access to the memory used by the GPU. | 992 // GpuMemoryBuffer provides direct access to the memory used by the GPU. |
993 // Read lock fences are required to ensure that we're not trying to map a | 993 // Read lock fences are required to ensure that we're not trying to map a |
994 // buffer that is currently in-use by the GPU. | 994 // buffer that is currently in-use by the GPU. |
995 resource->read_lock_fences_enabled = true; | 995 resource->read_lock_fences_enabled = true; |
996 } | 996 } |
997 | 997 |
998 const ResourceProvider::Resource* ResourceProvider::LockForWriteToSkSurface( | 998 void ResourceProvider::LockForWriteToSkSurface(ResourceId id) { |
999 ResourceId id) { | |
1000 Resource* resource = GetResource(id); | 999 Resource* resource = GetResource(id); |
1001 DCHECK_EQ(GLTexture, resource->type); | 1000 DCHECK_EQ(GLTexture, resource->type); |
1002 DCHECK(CanLockForWrite(id)); | 1001 DCHECK(CanLockForWrite(id)); |
1003 | 1002 |
| 1003 class GrContext* gr_context = GrContext(); |
| 1004 // TODO(alokp): Implement TestContextProvider::GrContext(). |
| 1005 if (!gr_context) |
| 1006 return; |
| 1007 |
| 1008 LazyAllocate(resource); |
| 1009 |
1004 resource->locked_for_write = true; | 1010 resource->locked_for_write = true; |
1005 if (!resource->sk_surface) { | |
1006 class GrContext* gr_context = GrContext(); | |
1007 // TODO(alokp): Implement TestContextProvider::GrContext(). | |
1008 if (!gr_context) | |
1009 return resource; | |
1010 | |
1011 LazyAllocate(resource); | |
1012 | |
1013 GrBackendTextureDesc desc; | |
1014 desc.fFlags = kRenderTarget_GrBackendTextureFlag; | |
1015 desc.fWidth = resource->size.width(); | |
1016 desc.fHeight = resource->size.height(); | |
1017 desc.fConfig = ToGrPixelConfig(resource->format); | |
1018 desc.fOrigin = kTopLeft_GrSurfaceOrigin; | |
1019 desc.fTextureHandle = resource->gl_id; | |
1020 skia::RefPtr<GrTexture> gr_texture = | |
1021 skia::AdoptRef(gr_context->wrapBackendTexture(desc)); | |
1022 SkSurface::TextRenderMode text_render_mode = | |
1023 use_distance_field_text_ ? SkSurface::kDistanceField_TextRenderMode | |
1024 : SkSurface::kStandard_TextRenderMode; | |
1025 resource->sk_surface = skia::AdoptRef(SkSurface::NewRenderTargetDirect( | |
1026 gr_texture->asRenderTarget(), text_render_mode)); | |
1027 } | |
1028 | |
1029 return resource; | |
1030 } | 1011 } |
1031 | 1012 |
1032 void ResourceProvider::UnlockForWriteToSkSurface(ResourceId id) { | 1013 void ResourceProvider::UnlockForWriteToSkSurface(ResourceId id) { |
1033 Resource* resource = GetResource(id); | 1014 Resource* resource = GetResource(id); |
1034 DCHECK(resource->locked_for_write); | 1015 DCHECK(resource->locked_for_write); |
1035 DCHECK_EQ(resource->exported_count, 0); | 1016 DCHECK_EQ(resource->exported_count, 0); |
1036 DCHECK(resource->origin == Resource::Internal); | 1017 DCHECK(resource->origin == Resource::Internal); |
1037 DCHECK_EQ(GLTexture, resource->type); | 1018 DCHECK_EQ(GLTexture, resource->type); |
1038 resource->locked_for_write = false; | 1019 resource->locked_for_write = false; |
1039 } | 1020 } |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1134 } | 1115 } |
1135 | 1116 |
1136 ResourceProvider::ScopedWriteLockGpuMemoryBuffer:: | 1117 ResourceProvider::ScopedWriteLockGpuMemoryBuffer:: |
1137 ~ScopedWriteLockGpuMemoryBuffer() { | 1118 ~ScopedWriteLockGpuMemoryBuffer() { |
1138 resource_provider_->UnlockForWriteToGpuMemoryBuffer(resource_id_); | 1119 resource_provider_->UnlockForWriteToGpuMemoryBuffer(resource_id_); |
1139 } | 1120 } |
1140 | 1121 |
1141 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr( | 1122 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr( |
1142 ResourceProvider* resource_provider, | 1123 ResourceProvider* resource_provider, |
1143 ResourceProvider::ResourceId resource_id) | 1124 ResourceProvider::ResourceId resource_id) |
1144 : resource_provider_(resource_provider), | 1125 : resource_provider_(resource_provider), resource_id_(resource_id) { |
1145 resource_id_(resource_id), | 1126 resource_provider->LockForWriteToSkSurface(resource_id); |
1146 sk_surface_(resource_provider->LockForWriteToSkSurface(resource_id) | |
1147 ->sk_surface.get()) { | |
1148 } | 1127 } |
1149 | 1128 |
1150 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() { | 1129 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() { |
1151 resource_provider_->UnlockForWriteToSkSurface(resource_id_); | 1130 resource_provider_->UnlockForWriteToSkSurface(resource_id_); |
1152 } | 1131 } |
1153 | 1132 |
| 1133 SkSurface* ResourceProvider::ScopedWriteLockGr::GetSkSurface( |
| 1134 bool use_distance_field_text) { |
| 1135 Resource* resource = resource_provider_->GetResource(resource_id_); |
| 1136 DCHECK(resource->locked_for_write); |
| 1137 |
| 1138 bool surface_uses_distance_field = |
| 1139 resource_provider_->use_distance_field_text_ || use_distance_field_text; |
| 1140 // If the surface doesn't have the correct dff setting, recreate the surface |
| 1141 // within the resource. |
| 1142 if (!resource->sk_surface || |
| 1143 surface_uses_distance_field != |
| 1144 resource->sk_surface->props().isUseDistanceFieldFonts()) { |
| 1145 class GrContext* gr_context = resource_provider_->GrContext(); |
| 1146 // TODO(alokp): Implement TestContextProvider::GrContext(). |
| 1147 if (!gr_context) |
| 1148 return nullptr; |
| 1149 |
| 1150 GrBackendTextureDesc desc; |
| 1151 desc.fFlags = kRenderTarget_GrBackendTextureFlag; |
| 1152 desc.fWidth = resource->size.width(); |
| 1153 desc.fHeight = resource->size.height(); |
| 1154 desc.fConfig = ToGrPixelConfig(resource->format); |
| 1155 desc.fOrigin = kTopLeft_GrSurfaceOrigin; |
| 1156 desc.fTextureHandle = resource->gl_id; |
| 1157 skia::RefPtr<GrTexture> gr_texture = |
| 1158 skia::AdoptRef(gr_context->wrapBackendTexture(desc)); |
| 1159 SkSurface::TextRenderMode text_render_mode = |
| 1160 use_distance_field_text ? SkSurface::kDistanceField_TextRenderMode |
| 1161 : SkSurface::kStandard_TextRenderMode; |
| 1162 resource->sk_surface = skia::AdoptRef(SkSurface::NewRenderTargetDirect( |
| 1163 gr_texture->asRenderTarget(), text_render_mode)); |
| 1164 return resource->sk_surface.get(); |
| 1165 } |
| 1166 return nullptr; |
| 1167 } |
| 1168 |
1154 ResourceProvider::ResourceProvider( | 1169 ResourceProvider::ResourceProvider( |
1155 OutputSurface* output_surface, | 1170 OutputSurface* output_surface, |
1156 SharedBitmapManager* shared_bitmap_manager, | 1171 SharedBitmapManager* shared_bitmap_manager, |
1157 GpuMemoryBufferManager* gpu_memory_buffer_manager, | 1172 GpuMemoryBufferManager* gpu_memory_buffer_manager, |
1158 BlockingTaskRunner* blocking_main_thread_task_runner, | 1173 BlockingTaskRunner* blocking_main_thread_task_runner, |
1159 int highp_threshold_min, | 1174 int highp_threshold_min, |
1160 bool use_rgba_4444_texture_format, | 1175 bool use_rgba_4444_texture_format, |
1161 size_t id_allocation_chunk_size, | 1176 size_t id_allocation_chunk_size, |
1162 bool use_distance_field_text) | 1177 bool use_distance_field_text) |
1163 : output_surface_(output_surface), | 1178 : output_surface_(output_surface), |
(...skipping 927 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2091 ContextProvider* context_provider = output_surface_->context_provider(); | 2106 ContextProvider* context_provider = output_surface_->context_provider(); |
2092 return context_provider ? context_provider->ContextGL() : NULL; | 2107 return context_provider ? context_provider->ContextGL() : NULL; |
2093 } | 2108 } |
2094 | 2109 |
2095 class GrContext* ResourceProvider::GrContext() const { | 2110 class GrContext* ResourceProvider::GrContext() const { |
2096 ContextProvider* context_provider = output_surface_->context_provider(); | 2111 ContextProvider* context_provider = output_surface_->context_provider(); |
2097 return context_provider ? context_provider->GrContext() : NULL; | 2112 return context_provider ? context_provider->GrContext() : NULL; |
2098 } | 2113 } |
2099 | 2114 |
2100 } // namespace cc | 2115 } // namespace cc |
OLD | NEW |