| Index: content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.cc
|
| diff --git a/content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.cc b/content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ee2f11114b66bb5749192c7c58ac43fb09233877
|
| --- /dev/null
|
| +++ b/content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.cc
|
| @@ -0,0 +1,105 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h"
|
| +
|
| +#include "base/debug/trace_event.h"
|
| +#include "base/logging.h"
|
| +#include "content/common/android/surface_texture_lookup.h"
|
| +#include "ui/gl/gl_bindings.h"
|
| +
|
| +namespace content {
|
| +
|
| +// static
|
| +bool GpuMemoryBufferImplSurfaceTexture::IsFormatSupported(
|
| + unsigned internalformat) {
|
| + switch (internalformat) {
|
| + case GL_RGBA8_OES:
|
| + return true;
|
| + default:
|
| + return false;
|
| + }
|
| +}
|
| +
|
| +// static
|
| +int GpuMemoryBufferImplSurfaceTexture::WindowFormat(unsigned internalformat) {
|
| + switch (internalformat) {
|
| + case GL_RGBA8_OES:
|
| + return WINDOW_FORMAT_RGBA_8888;
|
| + default:
|
| + NOTREACHED();
|
| + return 0;
|
| + }
|
| +}
|
| +
|
| +GpuMemoryBufferImplSurfaceTexture::GpuMemoryBufferImplSurfaceTexture(
|
| + gfx::Size size,
|
| + unsigned internalformat)
|
| + : GpuMemoryBufferImpl(size, internalformat),
|
| + native_window_(NULL),
|
| + stride_(0u) {}
|
| +
|
| +GpuMemoryBufferImplSurfaceTexture::~GpuMemoryBufferImplSurfaceTexture() {
|
| + if (native_window_)
|
| + ANativeWindow_release(native_window_);
|
| +}
|
| +
|
| +bool GpuMemoryBufferImplSurfaceTexture::Initialize(
|
| + gfx::GpuMemoryBufferHandle handle) {
|
| + TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::Initialize");
|
| +
|
| + DCHECK(!native_window_);
|
| + native_window_ = SurfaceTextureLookup::GetInstance()->AcquireNativeWidget(
|
| + handle.surface_texture_id.primary_id,
|
| + handle.surface_texture_id.secondary_id);
|
| + if (!native_window_)
|
| + return false;
|
| +
|
| + ANativeWindow_setBuffersGeometry(native_window_,
|
| + size_.width(),
|
| + size_.height(),
|
| + WindowFormat(internalformat_));
|
| +
|
| + surface_texture_id_ = handle.surface_texture_id;
|
| + return true;
|
| +}
|
| +
|
| +void GpuMemoryBufferImplSurfaceTexture::Map(AccessMode mode, void** vaddr) {
|
| + TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::Map");
|
| +
|
| + DCHECK(!mapped_);
|
| + DCHECK(native_window_);
|
| + ANativeWindow_Buffer buffer;
|
| + int status = ANativeWindow_lock(native_window_, &buffer, NULL);
|
| + if (status) {
|
| + VLOG(1) << "ANativeWindow_lock failed with error code: " << status;
|
| + *vaddr = NULL;
|
| + return;
|
| + }
|
| +
|
| + DCHECK_LE(size_.width(), buffer.stride);
|
| + *vaddr = buffer.bits;
|
| + stride_ = buffer.stride * BytesPerPixel(internalformat_);
|
| + mapped_ = true;
|
| +}
|
| +
|
| +void GpuMemoryBufferImplSurfaceTexture::Unmap() {
|
| + TRACE_EVENT0("gpu", "GpuMemoryBufferImplSurfaceTexture::Unmap");
|
| +
|
| + DCHECK(mapped_);
|
| + ANativeWindow_unlockAndPost(native_window_);
|
| + mapped_ = false;
|
| +}
|
| +
|
| +uint32 GpuMemoryBufferImplSurfaceTexture::GetStride() const { return stride_; }
|
| +
|
| +gfx::GpuMemoryBufferHandle GpuMemoryBufferImplSurfaceTexture::GetHandle()
|
| + const {
|
| + gfx::GpuMemoryBufferHandle handle;
|
| + handle.type = gfx::SURFACE_TEXTURE_BUFFER;
|
| + handle.surface_texture_id = surface_texture_id_;
|
| + return handle;
|
| +}
|
| +
|
| +} // namespace content
|
|
|