Index: content/common/gpu/client/gpu_memory_buffer_impl_linux.cc |
diff --git a/content/common/gpu/client/gpu_memory_buffer_impl_linux.cc b/content/common/gpu/client/gpu_memory_buffer_impl_linux.cc |
index 5c04cd8d9b18f94824c27e0eff5e3d2246866439..8e818b9c6400a3b363dbd12aa5ac33e603a98410 100644 |
--- a/content/common/gpu/client/gpu_memory_buffer_impl_linux.cc |
+++ b/content/common/gpu/client/gpu_memory_buffer_impl_linux.cc |
@@ -9,21 +9,21 @@ |
namespace content { |
// static |
-scoped_ptr<GpuMemoryBufferImpl> GpuMemoryBufferImpl::Create( |
- const gfx::Size& size, |
- unsigned internalformat, |
- unsigned usage) { |
+void GpuMemoryBufferImpl::Create(const gfx::Size& size, |
+ unsigned internalformat, |
+ unsigned usage, |
+ const CreationCallback& callback) { |
if (GpuMemoryBufferImplSharedMemory::IsConfigurationSupported( |
size, internalformat, usage)) { |
scoped_ptr<GpuMemoryBufferImplSharedMemory> buffer( |
new GpuMemoryBufferImplSharedMemory(size, internalformat)); |
- if (!buffer->Initialize()) |
- return scoped_ptr<GpuMemoryBufferImpl>(); |
- |
- return buffer.PassAs<GpuMemoryBufferImpl>(); |
+ if (buffer->Initialize()) { |
+ callback.Run(buffer.PassAs<GpuMemoryBufferImpl>()); |
+ return; |
+ } |
} |
- return scoped_ptr<GpuMemoryBufferImpl>(); |
+ callback.Run(scoped_ptr<GpuMemoryBufferImpl>()); |
} |
// static |