| 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;
 | 
|  }
 | 
| 
 |