| Index: gpu/command_buffer/service/image_manager.cc
|
| diff --git a/gpu/command_buffer/service/image_manager.cc b/gpu/command_buffer/service/image_manager.cc
|
| index 6be4e6677215830c704754e43ad182ad590632e1..a09af1586b0b9baf0e9266a9e292f8d38502d582 100644
|
| --- a/gpu/command_buffer/service/image_manager.cc
|
| +++ b/gpu/command_buffer/service/image_manager.cc
|
| @@ -15,6 +15,36 @@ ImageManager::ImageManager() {
|
| ImageManager::~ImageManager() {
|
| }
|
|
|
| +bool ImageManager::RegisterGpuMemoryBuffer(int32 id,
|
| + gfx::GpuMemoryBufferHandle buffer,
|
| + size_t width,
|
| + size_t height,
|
| + unsigned internalformat) {
|
| + if (id <= 0) {
|
| + DVLOG(0) << "Cannot register GPU memory buffer with non-positive ID.";
|
| + return false;
|
| + }
|
| +
|
| + if (LookupImage(id)) {
|
| + DVLOG(0) << "GPU memory buffer ID already in use.";
|
| + return false;
|
| + }
|
| +
|
| + scoped_refptr<gfx::GLImage> gl_image =
|
| + gfx::GLImage::CreateGLImageForGpuMemoryBuffer(buffer,
|
| + gfx::Size(width, height),
|
| + internalformat);
|
| + if (!gl_image)
|
| + return false;
|
| +
|
| + AddImage(gl_image.get(), id);
|
| + return true;
|
| +}
|
| +
|
| +void ImageManager::DestroyGpuMemoryBuffer(int32 id) {
|
| + RemoveImage(id);
|
| +}
|
| +
|
| void ImageManager::AddImage(gfx::GLImage* image, int32 service_id) {
|
| gl_images_[service_id] = image;
|
| }
|
|
|