| OLD | NEW |
| (Empty) |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h" | |
| 6 | |
| 7 #include "base/logging.h" | |
| 8 #include "base/trace_event/trace_event.h" | |
| 9 #include "gpu/ipc/common/android/surface_texture_manager.h" | |
| 10 #include "gpu/ipc/common/gpu_memory_buffer_support.h" | |
| 11 #include "ui/gfx/buffer_format_util.h" | |
| 12 #include "ui/gl/android/surface_texture.h" | |
| 13 #include "ui/gl/gl_bindings.h" | |
| 14 | |
| 15 namespace content { | |
| 16 namespace { | |
| 17 | |
| 18 int WindowFormat(gfx::BufferFormat format) { | |
| 19 switch (format) { | |
| 20 case gfx::BufferFormat::RGBA_8888: | |
| 21 return WINDOW_FORMAT_RGBA_8888; | |
| 22 case gfx::BufferFormat::ATC: | |
| 23 case gfx::BufferFormat::ATCIA: | |
| 24 case gfx::BufferFormat::DXT1: | |
| 25 case gfx::BufferFormat::DXT5: | |
| 26 case gfx::BufferFormat::ETC1: | |
| 27 case gfx::BufferFormat::R_8: | |
| 28 case gfx::BufferFormat::RGBA_4444: | |
| 29 case gfx::BufferFormat::RGBX_8888: | |
| 30 case gfx::BufferFormat::BGRX_8888: | |
| 31 case gfx::BufferFormat::BGRA_8888: | |
| 32 case gfx::BufferFormat::YUV_420: | |
| 33 case gfx::BufferFormat::YUV_420_BIPLANAR: | |
| 34 case gfx::BufferFormat::UYVY_422: | |
| 35 NOTREACHED(); | |
| 36 return 0; | |
| 37 } | |
| 38 | |
| 39 NOTREACHED(); | |
| 40 return 0; | |
| 41 } | |
| 42 | |
| 43 void FreeSurfaceTextureForTesting( | |
| 44 scoped_refptr<gfx::SurfaceTexture> surface_texture, | |
| 45 gfx::GpuMemoryBufferId id) { | |
| 46 gpu::SurfaceTextureManager::GetInstance()->UnregisterSurfaceTexture(id.id, 0); | |
| 47 } | |
| 48 | |
| 49 } // namespace | |
| 50 | |
| 51 GpuMemoryBufferImplSurfaceTexture::GpuMemoryBufferImplSurfaceTexture( | |
| 52 gfx::GpuMemoryBufferId id, | |
| 53 const gfx::Size& size, | |
| 54 gfx::BufferFormat format, | |
| 55 const DestructionCallback& callback, | |
| 56 ANativeWindow* native_window) | |
| 57 : GpuMemoryBufferImpl(id, size, format, callback), | |
| 58 native_window_(native_window) {} | |
| 59 | |
| 60 GpuMemoryBufferImplSurfaceTexture::~GpuMemoryBufferImplSurfaceTexture() { | |
| 61 ANativeWindow_release(native_window_); | |
| 62 } | |
| 63 | |
| 64 // static | |
| 65 scoped_ptr<GpuMemoryBufferImplSurfaceTexture> | |
| 66 GpuMemoryBufferImplSurfaceTexture::CreateFromHandle( | |
| 67 const gfx::GpuMemoryBufferHandle& handle, | |
| 68 const gfx::Size& size, | |
| 69 gfx::BufferFormat format, | |
| 70 gfx::BufferUsage usage, | |
| 71 const DestructionCallback& callback) { | |
| 72 ANativeWindow* native_window = | |
| 73 gpu::SurfaceTextureManager::GetInstance() | |
| 74 ->AcquireNativeWidgetForSurfaceTexture(handle.id.id); | |
| 75 if (!native_window) | |
| 76 return nullptr; | |
| 77 | |
| 78 ANativeWindow_setBuffersGeometry( | |
| 79 native_window, size.width(), size.height(), WindowFormat(format)); | |
| 80 | |
| 81 return make_scoped_ptr(new GpuMemoryBufferImplSurfaceTexture( | |
| 82 handle.id, size, format, callback, native_window)); | |
| 83 } | |
| 84 | |
| 85 // static | |
| 86 bool GpuMemoryBufferImplSurfaceTexture::IsConfigurationSupported( | |
| 87 gfx::BufferFormat format, | |
| 88 gfx::BufferUsage usage) { | |
| 89 return gpu::IsNativeGpuMemoryBufferConfigurationSupported(format, usage); | |
| 90 } | |
| 91 | |
| 92 // static | |
| 93 base::Closure GpuMemoryBufferImplSurfaceTexture::AllocateForTesting( | |
| 94 const gfx::Size& size, | |
| 95 gfx::BufferFormat format, | |
| 96 gfx::BufferUsage usage, | |
| 97 gfx::GpuMemoryBufferHandle* handle) { | |
| 98 scoped_refptr<gfx::SurfaceTexture> surface_texture = | |
| 99 gfx::SurfaceTexture::Create(0); | |
| 100 DCHECK(surface_texture); | |
| 101 const gfx::GpuMemoryBufferId kBufferId(1); | |
| 102 gpu::SurfaceTextureManager::GetInstance()->RegisterSurfaceTexture( | |
| 103 kBufferId.id, 0, surface_texture.get()); | |
| 104 handle->type = gfx::SURFACE_TEXTURE_BUFFER; | |
| 105 handle->id = kBufferId; | |
| 106 return base::Bind(&FreeSurfaceTextureForTesting, surface_texture, kBufferId); | |
| 107 } | |
| 108 | |
| 109 bool GpuMemoryBufferImplSurfaceTexture::Map() { | |
| 110 TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::Map"); | |
| 111 DCHECK(!mapped_); | |
| 112 DCHECK(native_window_); | |
| 113 if (ANativeWindow_lock(native_window_, &buffer_, NULL)) { | |
| 114 DPLOG(ERROR) << "ANativeWindow_lock failed"; | |
| 115 return false; | |
| 116 } | |
| 117 DCHECK_LE(size_.width(), buffer_.stride); | |
| 118 mapped_ = true; | |
| 119 return true; | |
| 120 } | |
| 121 | |
| 122 void* GpuMemoryBufferImplSurfaceTexture::memory(size_t plane) { | |
| 123 TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::memory"); | |
| 124 DCHECK(mapped_); | |
| 125 DCHECK_EQ(0u, plane); | |
| 126 return buffer_.bits; | |
| 127 } | |
| 128 | |
| 129 void GpuMemoryBufferImplSurfaceTexture::Unmap() { | |
| 130 TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::Unmap"); | |
| 131 DCHECK(mapped_); | |
| 132 ANativeWindow_unlockAndPost(native_window_); | |
| 133 mapped_ = false; | |
| 134 } | |
| 135 | |
| 136 int GpuMemoryBufferImplSurfaceTexture::stride(size_t plane) const { | |
| 137 DCHECK(mapped_); | |
| 138 DCHECK_EQ(0u, plane); | |
| 139 return gfx::RowSizeForBufferFormat(buffer_.stride, format_, 0); | |
| 140 } | |
| 141 | |
| 142 gfx::GpuMemoryBufferHandle | |
| 143 GpuMemoryBufferImplSurfaceTexture::GetHandle() const { | |
| 144 gfx::GpuMemoryBufferHandle handle; | |
| 145 handle.type = gfx::SURFACE_TEXTURE_BUFFER; | |
| 146 handle.id = id_; | |
| 147 return handle; | |
| 148 } | |
| 149 | |
| 150 } // namespace content | |
| OLD | NEW |