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

Side by Side Diff: content/common/gpu/client/gpu_memory_buffer_impl_android.cc

Issue 290573011: Delay the response to ChildProcessHostMsg_SyncAllocateGpuMemoryBuffer via a callback to allow for b… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nits 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "content/common/gpu/client/gpu_memory_buffer_impl.h" 5 #include "content/common/gpu/client/gpu_memory_buffer_impl.h"
6 6
7 #include "content/common/gpu/client/gpu_memory_buffer_impl_shm.h" 7 #include "content/common/gpu/client/gpu_memory_buffer_impl_shm.h"
8 #include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h" 8 #include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h"
9 9
10 namespace content { 10 namespace content {
(...skipping 15 matching lines...) Expand all
26 26
27 return scoped_ptr<GpuMemoryBufferImpl>(); 27 return scoped_ptr<GpuMemoryBufferImpl>();
28 } 28 }
29 29
30 // static 30 // static
31 void GpuMemoryBufferImpl::AllocateForChildProcess( 31 void GpuMemoryBufferImpl::AllocateForChildProcess(
32 const gfx::Size& size, 32 const gfx::Size& size,
33 unsigned internalformat, 33 unsigned internalformat,
34 unsigned usage, 34 unsigned usage,
35 base::ProcessHandle child_process, 35 base::ProcessHandle child_process,
36 gfx::GpuMemoryBufferHandle* handle) { 36 const AllocationCallback& callback) {
37 if (GpuMemoryBufferImplShm::IsConfigurationSupported( 37 if (GpuMemoryBufferImplShm::IsConfigurationSupported(
38 size, internalformat, usage)) { 38 size, internalformat, usage)) {
39 GpuMemoryBufferImplShm::AllocateSharedMemoryForChildProcess( 39 GpuMemoryBufferImplShm::AllocateSharedMemoryForChildProcess(
40 size, internalformat, child_process, handle); 40 size, internalformat, child_process, callback);
41 return; 41 return;
42 } 42 }
43 43
44 handle->type = gfx::EMPTY_BUFFER; 44 callback.Run(gfx::GpuMemoryBufferHandle());
45 } 45 }
46 46
47 // static 47 // static
48 scoped_ptr<GpuMemoryBufferImpl> GpuMemoryBufferImpl::CreateFromHandle( 48 scoped_ptr<GpuMemoryBufferImpl> GpuMemoryBufferImpl::CreateFromHandle(
49 gfx::GpuMemoryBufferHandle handle, 49 gfx::GpuMemoryBufferHandle handle,
50 const gfx::Size& size, 50 const gfx::Size& size,
51 unsigned internalformat) { 51 unsigned internalformat) {
52 switch (handle.type) { 52 switch (handle.type) {
53 case gfx::SHARED_MEMORY_BUFFER: { 53 case gfx::SHARED_MEMORY_BUFFER: {
54 scoped_ptr<GpuMemoryBufferImplShm> buffer( 54 scoped_ptr<GpuMemoryBufferImplShm> buffer(
(...skipping 10 matching lines...) Expand all
65 return scoped_ptr<GpuMemoryBufferImpl>(); 65 return scoped_ptr<GpuMemoryBufferImpl>();
66 66
67 return buffer.PassAs<GpuMemoryBufferImpl>(); 67 return buffer.PassAs<GpuMemoryBufferImpl>();
68 } 68 }
69 default: 69 default:
70 return scoped_ptr<GpuMemoryBufferImpl>(); 70 return scoped_ptr<GpuMemoryBufferImpl>();
71 } 71 }
72 } 72 }
73 73
74 } // namespace content 74 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698