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

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

Issue 1157943004: cc: [WIP] Use worker context and OrderingBarrierCHROMIUM for one-copy. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: piman's comments. Created 5 years, 5 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
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 976 matching lines...) Expand 10 before | Expand all | Expand 10 after
987 resource_provider_->use_persistent_map_for_gpu_memory_buffers() 987 resource_provider_->use_persistent_map_for_gpu_memory_buffers()
988 ? gfx::GpuMemoryBuffer::PERSISTENT_MAP 988 ? gfx::GpuMemoryBuffer::PERSISTENT_MAP
989 : gfx::GpuMemoryBuffer::MAP; 989 : gfx::GpuMemoryBuffer::MAP;
990 scoped_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer = 990 scoped_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer =
991 gpu_memory_buffer_manager_->AllocateGpuMemoryBuffer( 991 gpu_memory_buffer_manager_->AllocateGpuMemoryBuffer(
992 size_, ToGpuMemoryBufferFormat(format_), usage); 992 size_, ToGpuMemoryBufferFormat(format_), usage);
993 gpu_memory_buffer_ = gpu_memory_buffer.release(); 993 gpu_memory_buffer_ = gpu_memory_buffer.release();
994 return gpu_memory_buffer_; 994 return gpu_memory_buffer_;
995 } 995 }
996 996
997 ResourceProvider::ScopedWriteLockGpuMemoryBufferForThread::
998 ScopedWriteLockGpuMemoryBufferForThread(ResourceProvider* resource_provider,
999 ResourceId resource_id)
1000 : resource_provider_(resource_provider),
1001 resource_(resource_provider_->GetResource(resource_id)),
1002 gpu_memory_buffer_manager_(resource_provider->gpu_memory_buffer_manager_),
1003 gpu_memory_buffer_(nullptr),
1004 size_(resource_->size),
1005 format_(resource_->format) {
1006 DCHECK_EQ(RESOURCE_TYPE_GL_TEXTURE, resource_->type);
1007 resource_provider_->LazyCreate(resource_);
1008 worker_context_ =
1009 resource_provider_->output_surface()->worker_context_provider();
1010 image_id_ = 0;
piman 2015/07/01 22:11:05 I think you want to initialize with resource_->ima
sohanjg 2015/07/02 14:40:28 Done.
1011 allocated_ = false;
1012 dirty_image_ = false;
1013 read_lock_fences_enabled_ = false;
piman 2015/07/01 22:11:05 Same here for all 3, you may need to get the value
sohanjg 2015/07/02 14:40:28 Done.
1014 internal_format_ = GLInternalFormat(resource_->format);
1015 std::swap(gpu_memory_buffer_, resource_->gpu_memory_buffer);
1016 }
1017
1018 ResourceProvider::ScopedWriteLockGpuMemoryBufferForThread::
1019 ~ScopedWriteLockGpuMemoryBufferForThread() {
1020 if (!gpu_memory_buffer_)
1021 return;
1022
1023 if (!resource_->image_id) {
piman 2015/07/01 22:11:05 you don't need / want this test any more if you in
sohanjg 2015/07/02 14:40:28 Done.
1024 resource_->image_id = image_id_;
1025 }
1026
1027 std::swap(resource_->gpu_memory_buffer, gpu_memory_buffer_);
1028 resource_->allocated = allocated_;
1029 resource_->dirty_image = dirty_image_;
1030 resource_->bound_image_id = bound_image_id_;
1031
1032 resource_->read_lock_fences_enabled = read_lock_fences_enabled_;
1033 }
1034
1035 gfx::GpuMemoryBuffer* ResourceProvider::
1036 ScopedWriteLockGpuMemoryBufferForThread::GetGpuMemoryBuffer() {
1037 if (gpu_memory_buffer_)
1038 return gpu_memory_buffer_;
1039 gfx::GpuMemoryBuffer::Usage usage =
1040 resource_provider_->use_persistent_map_for_gpu_memory_buffers()
piman 2015/07/01 22:11:05 If this is called on the worker thread, it's not s
sohanjg 2015/07/02 14:40:28 Done.
1041 ? gfx::GpuMemoryBuffer::PERSISTENT_MAP
1042 : gfx::GpuMemoryBuffer::MAP;
1043 scoped_ptr<gfx::GpuMemoryBuffer> gpu_memory_buffer =
1044 gpu_memory_buffer_manager_->AllocateGpuMemoryBuffer(
1045 size_, ToGpuMemoryBufferFormat(format_), usage);
1046 gpu_memory_buffer_ = gpu_memory_buffer.release();
1047 return gpu_memory_buffer_;
1048 }
1049
997 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr( 1050 ResourceProvider::ScopedWriteLockGr::ScopedWriteLockGr(
998 ResourceProvider* resource_provider, 1051 ResourceProvider* resource_provider,
999 ResourceId resource_id) 1052 ResourceId resource_id)
1000 : resource_provider_(resource_provider), 1053 : resource_provider_(resource_provider),
1001 resource_(resource_provider->LockForWrite(resource_id)) { 1054 resource_(resource_provider->LockForWrite(resource_id)) {
1002 DCHECK(thread_checker_.CalledOnValidThread()); 1055 DCHECK(thread_checker_.CalledOnValidThread());
1003 resource_provider_->LazyAllocate(resource_); 1056 resource_provider_->LazyAllocate(resource_);
1004 } 1057 }
1005 1058
1006 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() { 1059 ResourceProvider::ScopedWriteLockGr::~ScopedWriteLockGr() {
(...skipping 865 matching lines...) Expand 10 before | Expand all | Expand 10 after
1872 source_resource->gl_read_lock_query_id); 1925 source_resource->gl_read_lock_query_id);
1873 #else 1926 #else
1874 gl->BeginQueryEXT(GL_COMMANDS_COMPLETED_CHROMIUM, 1927 gl->BeginQueryEXT(GL_COMMANDS_COMPLETED_CHROMIUM,
1875 source_resource->gl_read_lock_query_id); 1928 source_resource->gl_read_lock_query_id);
1876 #endif 1929 #endif
1877 } 1930 }
1878 DCHECK(!dest_resource->image_id); 1931 DCHECK(!dest_resource->image_id);
1879 dest_resource->allocated = true; 1932 dest_resource->allocated = true;
1880 gl->CopySubTextureCHROMIUM(dest_resource->target, source_resource->gl_id, 1933 gl->CopySubTextureCHROMIUM(dest_resource->target, source_resource->gl_id,
1881 dest_resource->gl_id, rect.x(), rect.y(), rect.x(), 1934 dest_resource->gl_id, rect.x(), rect.y(), rect.x(),
1882 rect.y(), rect.width(), rect.height(), 1935 rect.y(), rect.width(), rect.height(), false,
1883 false, false, false); 1936 false, false);
1884 if (source_resource->gl_read_lock_query_id) { 1937 if (source_resource->gl_read_lock_query_id) {
1885 // End query and create a read lock fence that will prevent access to 1938 // End query and create a read lock fence that will prevent access to
1886 // source resource until CopySubTextureCHROMIUM command has completed. 1939 // source resource until CopySubTextureCHROMIUM command has completed.
1887 #if defined(OS_CHROMEOS) 1940 #if defined(OS_CHROMEOS)
1888 gl->EndQueryEXT(GL_COMMANDS_ISSUED_CHROMIUM); 1941 gl->EndQueryEXT(GL_COMMANDS_ISSUED_CHROMIUM);
1889 #else 1942 #else
1890 gl->EndQueryEXT(GL_COMMANDS_COMPLETED_CHROMIUM); 1943 gl->EndQueryEXT(GL_COMMANDS_COMPLETED_CHROMIUM);
1891 #endif 1944 #endif
1892 source_resource->read_lock_fence = make_scoped_refptr( 1945 source_resource->read_lock_fence = make_scoped_refptr(
1893 new CopyTextureFence(gl, source_resource->gl_read_lock_query_id)); 1946 new CopyTextureFence(gl, source_resource->gl_read_lock_query_id));
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
1945 } 1998 }
1946 1999
1947 class GrContext* ResourceProvider::GrContext(bool worker_context) const { 2000 class GrContext* ResourceProvider::GrContext(bool worker_context) const {
1948 ContextProvider* context_provider = 2001 ContextProvider* context_provider =
1949 worker_context ? output_surface_->worker_context_provider() 2002 worker_context ? output_surface_->worker_context_provider()
1950 : output_surface_->context_provider(); 2003 : output_surface_->context_provider();
1951 return context_provider ? context_provider->GrContext() : NULL; 2004 return context_provider ? context_provider->GrContext() : NULL;
1952 } 2005 }
1953 2006
1954 } // namespace cc 2007 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698