Index: content/common/gpu/media/vaapi_tfp_picture.cc |
diff --git a/content/common/gpu/media/vaapi_tfp_picture.cc b/content/common/gpu/media/vaapi_tfp_picture.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e914418ec74cef9bb9c52c4793f543a34142f888 |
--- /dev/null |
+++ b/content/common/gpu/media/vaapi_tfp_picture.cc |
@@ -0,0 +1,77 @@ |
+// 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/media/va_surface.h" |
+#include "content/common/gpu/media/vaapi_tfp_picture.h" |
+#include "content/common/gpu/media/vaapi_wrapper.h" |
+#include "ui/gfx/x/x11_types.h" |
+#include "ui/gl/gl_bindings.h" |
+#include "ui/gl/gl_image_glx.h" |
+#include "ui/gl/scoped_binders.h" |
+ |
+namespace content { |
+ |
+VaapiTFPPicture::VaapiTFPPicture( |
+ const scoped_refptr<VaapiWrapper>& vaapi_wrapper, |
+ const base::Callback<bool(void)> make_context_current, |
+ int32 picture_buffer_id, |
+ uint32 texture_id, |
+ const gfx::Size& size) |
+ : VaapiPicture(picture_buffer_id, texture_id, size), |
+ vaapi_wrapper_(vaapi_wrapper), |
+ make_context_current_(make_context_current), |
+ x_display_(gfx::GetXDisplay()), |
+ x_pixmap_(0) { |
+} |
+ |
+VaapiTFPPicture::~VaapiTFPPicture() { |
+ if (glx_image_.get() && make_context_current_.Run()) { |
+ glx_image_->ReleaseTexImage(GL_TEXTURE_2D); |
+ glx_image_->Destroy(true); |
+ DCHECK_EQ(glGetError(), static_cast<GLenum>(GL_NO_ERROR)); |
+ } |
+ |
+ if (x_pixmap_) |
+ XFreePixmap(x_display_, x_pixmap_); |
+} |
+ |
+bool VaapiTFPPicture::Initialize() { |
+ if (!make_context_current_.Run()) |
+ return false; |
+ |
+ XWindowAttributes win_attr; |
+ int screen = DefaultScreen(x_display_); |
+ XGetWindowAttributes(x_display_, RootWindow(x_display_, screen), &win_attr); |
+ // TODO(posciak): pass the depth required by libva, not the RootWindow's |
+ // depth |
+ x_pixmap_ = XCreatePixmap(x_display_, RootWindow(x_display_, screen), |
+ size().width(), size().height(), win_attr.depth); |
+ if (!x_pixmap_) { |
+ LOG(ERROR) << "Failed creating an X Pixmap for TFP"; |
+ return false; |
+ } |
+ |
+ glx_image_ = new gfx::GLImageGLX(size(), GL_RGB); |
+ if (!glx_image_->Initialize(x_pixmap_)) { |
+ // x_pixmap_ will be freed in the destructor. |
+ LOG(ERROR) << "Failed creating a GLX Pixmap for TFP"; |
+ return false; |
+ } |
+ |
+ gfx::ScopedTextureBinder texture_binder(GL_TEXTURE_2D, texture_id()); |
+ if (!glx_image_->BindTexImage(GL_TEXTURE_2D)) { |
+ LOG(ERROR) << "Failed to bind texture to glx image"; |
+ return false; |
+ } |
+ |
+ return true; |
+} |
+ |
+bool VaapiTFPPicture::DownloadFromSurface( |
+ const scoped_refptr<VASurface>& va_surface) { |
+ return vaapi_wrapper_->PutSurfaceIntoPixmap(va_surface->id(), x_pixmap_, |
+ va_surface->size()); |
+} |
+ |
+} // namespace content |