Chromium Code Reviews| 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 976 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |