2010-01-25 16:15:01 +00:00
|
|
|
/*
|
2010-03-16 09:18:57 +00:00
|
|
|
* gstvaapiutils.c - VA-API utilities
|
2010-01-25 16:15:01 +00:00
|
|
|
*
|
2012-01-16 09:41:10 +00:00
|
|
|
* Copyright (C) 2010-2011 Splitted-Desktop Systems
|
2013-11-22 04:57:18 +00:00
|
|
|
* Author: Gwenole Beauchesne <gwenole.beauchesne@splitted-desktop.com>
|
2013-01-29 13:14:45 +00:00
|
|
|
* Copyright (C) 2011-2013 Intel Corporation
|
2013-11-22 04:57:18 +00:00
|
|
|
* Author: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
|
2010-01-25 16:15:01 +00:00
|
|
|
*
|
2011-06-14 11:51:41 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2.1
|
|
|
|
* of the License, or (at your option) any later version.
|
2010-01-25 16:15:01 +00:00
|
|
|
*
|
2011-06-14 11:51:41 +00:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
2010-01-25 16:15:01 +00:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2011-06-14 11:51:41 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2010-01-25 16:15:01 +00:00
|
|
|
*
|
2011-06-14 11:51:41 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free
|
|
|
|
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301 USA
|
2010-01-25 16:15:01 +00:00
|
|
|
*/
|
|
|
|
|
2012-01-30 17:12:59 +00:00
|
|
|
#include "sysdeps.h"
|
2010-03-24 16:17:49 +00:00
|
|
|
#include "gstvaapicompat.h"
|
2010-03-16 09:15:48 +00:00
|
|
|
#include "gstvaapiutils.h"
|
2010-03-21 08:38:17 +00:00
|
|
|
#include "gstvaapisurface.h"
|
2013-01-04 08:41:25 +00:00
|
|
|
#include "gstvaapisubpicture.h"
|
2013-07-29 01:23:50 +00:00
|
|
|
#include "gstvaapifilter.h"
|
2010-01-25 16:15:01 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
2013-07-29 01:23:50 +00:00
|
|
|
#if USE_VA_VPP
|
|
|
|
# include <va/va_vpp.h>
|
|
|
|
#endif
|
|
|
|
|
2010-03-30 12:55:27 +00:00
|
|
|
#define DEBUG 1
|
|
|
|
#include "gstvaapidebug.h"
|
2010-01-25 16:15:01 +00:00
|
|
|
|
2012-01-13 11:09:07 +00:00
|
|
|
#define CONCAT(a, b) CONCAT_(a, b)
|
|
|
|
#define CONCAT_(a, b) a##b
|
|
|
|
#define STRINGIFY(x) STRINGIFY_(x)
|
|
|
|
#define STRINGIFY_(x) #x
|
|
|
|
#define STRCASEP(p, x) STRCASE(CONCAT(p, x))
|
|
|
|
#define STRCASE(x) case x: return STRINGIFY(x)
|
|
|
|
|
2010-01-25 16:15:01 +00:00
|
|
|
/* Check VA status for success or print out an error */
|
2010-03-30 12:55:27 +00:00
|
|
|
gboolean
|
|
|
|
vaapi_check_status(VAStatus status, const char *msg)
|
2010-01-25 16:15:01 +00:00
|
|
|
{
|
|
|
|
if (status != VA_STATUS_SUCCESS) {
|
2010-03-30 12:55:27 +00:00
|
|
|
GST_DEBUG("%s: %s", msg, vaErrorStr(status));
|
|
|
|
return FALSE;
|
2010-01-25 16:15:01 +00:00
|
|
|
}
|
2010-03-30 12:55:27 +00:00
|
|
|
return TRUE;
|
2010-01-25 16:15:01 +00:00
|
|
|
}
|
|
|
|
|
2011-08-04 15:29:41 +00:00
|
|
|
/* Maps VA buffer */
|
|
|
|
void *
|
|
|
|
vaapi_map_buffer(VADisplay dpy, VABufferID buf_id)
|
|
|
|
{
|
|
|
|
VAStatus status;
|
|
|
|
void *data = NULL;
|
|
|
|
|
|
|
|
status = vaMapBuffer(dpy, buf_id, &data);
|
|
|
|
if (!vaapi_check_status(status, "vaMapBuffer()"))
|
|
|
|
return NULL;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Unmaps VA buffer */
|
|
|
|
void
|
|
|
|
vaapi_unmap_buffer(VADisplay dpy, VABufferID buf_id, void **pbuf)
|
|
|
|
{
|
|
|
|
VAStatus status;
|
|
|
|
|
|
|
|
if (pbuf)
|
|
|
|
*pbuf = NULL;
|
|
|
|
|
|
|
|
status = vaUnmapBuffer(dpy, buf_id);
|
|
|
|
if (!vaapi_check_status(status, "vaUnmapBuffer()"))
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Creates and maps VA buffer */
|
2012-01-30 09:15:32 +00:00
|
|
|
gboolean
|
2011-08-04 15:29:41 +00:00
|
|
|
vaapi_create_buffer(
|
2012-01-30 09:15:32 +00:00
|
|
|
VADisplay dpy,
|
|
|
|
VAContextID ctx,
|
|
|
|
int type,
|
|
|
|
unsigned int size,
|
|
|
|
gconstpointer buf,
|
|
|
|
VABufferID *buf_id_ptr,
|
|
|
|
gpointer *mapped_data
|
2011-08-04 15:29:41 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
VABufferID buf_id;
|
|
|
|
VAStatus status;
|
2012-01-30 09:15:32 +00:00
|
|
|
gpointer data = (gpointer)buf;
|
2011-08-04 15:29:41 +00:00
|
|
|
|
2012-01-30 09:15:32 +00:00
|
|
|
status = vaCreateBuffer(dpy, ctx, type, size, 1, data, &buf_id);
|
2011-08-04 15:29:41 +00:00
|
|
|
if (!vaapi_check_status(status, "vaCreateBuffer()"))
|
2012-01-30 09:15:32 +00:00
|
|
|
return FALSE;
|
2011-08-04 15:29:41 +00:00
|
|
|
|
2012-01-30 09:15:32 +00:00
|
|
|
if (mapped_data) {
|
|
|
|
data = vaapi_map_buffer(dpy, buf_id);
|
|
|
|
if (!data)
|
|
|
|
goto error;
|
|
|
|
*mapped_data = data;
|
|
|
|
}
|
2011-08-04 15:29:41 +00:00
|
|
|
|
|
|
|
*buf_id_ptr = buf_id;
|
2012-01-30 09:15:32 +00:00
|
|
|
return TRUE;
|
2011-08-04 15:29:41 +00:00
|
|
|
|
|
|
|
error:
|
|
|
|
vaapi_destroy_buffer(dpy, &buf_id);
|
2012-01-30 09:15:32 +00:00
|
|
|
return FALSE;
|
2011-08-04 15:29:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Destroy VA buffer */
|
|
|
|
void
|
|
|
|
vaapi_destroy_buffer(VADisplay dpy, VABufferID *buf_id_ptr)
|
|
|
|
{
|
|
|
|
if (!buf_id_ptr || *buf_id_ptr == VA_INVALID_ID)
|
|
|
|
return;
|
|
|
|
|
|
|
|
vaDestroyBuffer(dpy, *buf_id_ptr);
|
|
|
|
*buf_id_ptr = VA_INVALID_ID;
|
|
|
|
}
|
|
|
|
|
2010-01-25 16:15:01 +00:00
|
|
|
/* Return a string representation of a VAProfile */
|
|
|
|
const char *string_of_VAProfile(VAProfile profile)
|
|
|
|
{
|
|
|
|
switch (profile) {
|
2012-01-13 11:09:07 +00:00
|
|
|
#define MAP(profile) \
|
|
|
|
STRCASEP(VAProfile, profile)
|
|
|
|
MAP(MPEG2Simple);
|
|
|
|
MAP(MPEG2Main);
|
|
|
|
MAP(MPEG4Simple);
|
|
|
|
MAP(MPEG4AdvancedSimple);
|
|
|
|
MAP(MPEG4Main);
|
2012-01-06 16:51:59 +00:00
|
|
|
#if VA_CHECK_VERSION(0,32,0)
|
2012-01-13 11:09:07 +00:00
|
|
|
MAP(JPEGBaseline);
|
|
|
|
MAP(H263Baseline);
|
|
|
|
MAP(H264ConstrainedBaseline);
|
2012-01-06 16:51:59 +00:00
|
|
|
#endif
|
2012-01-13 11:09:07 +00:00
|
|
|
MAP(H264Baseline);
|
|
|
|
MAP(H264Main);
|
|
|
|
MAP(H264High);
|
|
|
|
MAP(VC1Simple);
|
|
|
|
MAP(VC1Main);
|
|
|
|
MAP(VC1Advanced);
|
|
|
|
#undef MAP
|
2010-01-25 16:15:01 +00:00
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
return "<unknown>";
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Return a string representation of a VAEntrypoint */
|
|
|
|
const char *string_of_VAEntrypoint(VAEntrypoint entrypoint)
|
|
|
|
{
|
|
|
|
switch (entrypoint) {
|
2012-01-13 11:09:07 +00:00
|
|
|
#define MAP(entrypoint) \
|
|
|
|
STRCASEP(VAEntrypoint, entrypoint)
|
|
|
|
MAP(VLD);
|
|
|
|
MAP(IZZ);
|
|
|
|
MAP(IDCT);
|
|
|
|
MAP(MoComp);
|
|
|
|
MAP(Deblocking);
|
|
|
|
#undef MAP
|
2010-01-25 16:15:01 +00:00
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
return "<unknown>";
|
|
|
|
}
|
2010-03-21 08:38:17 +00:00
|
|
|
|
2012-07-31 10:22:48 +00:00
|
|
|
/* Return a string representation of a VADisplayAttributeType */
|
|
|
|
const char *
|
|
|
|
string_of_VADisplayAttributeType(VADisplayAttribType attribute_type)
|
|
|
|
{
|
|
|
|
switch (attribute_type) {
|
|
|
|
#define MAP(attribute_type) \
|
|
|
|
STRCASEP(VADisplayAttrib, attribute_type)
|
|
|
|
MAP(Brightness);
|
|
|
|
MAP(Contrast);
|
|
|
|
MAP(Hue);
|
|
|
|
MAP(Saturation);
|
|
|
|
MAP(BackgroundColor);
|
|
|
|
#if !VA_CHECK_VERSION(0,34,0)
|
|
|
|
MAP(DirectSurface);
|
|
|
|
#endif
|
|
|
|
MAP(Rotation);
|
|
|
|
MAP(OutofLoopDeblock);
|
|
|
|
#if VA_CHECK_VERSION(0,31,1) && !VA_CHECK_VERSION(0,34,0)
|
|
|
|
MAP(BLEBlackMode);
|
|
|
|
MAP(BLEWhiteMode);
|
|
|
|
MAP(BlueStretch);
|
|
|
|
MAP(SkinColorCorrection);
|
|
|
|
#endif
|
|
|
|
MAP(CSCMatrix);
|
|
|
|
MAP(BlendColor);
|
|
|
|
MAP(OverlayAutoPaintColorKey);
|
|
|
|
MAP(OverlayColorKey);
|
|
|
|
MAP(RenderMode);
|
|
|
|
MAP(RenderDevice);
|
|
|
|
MAP(RenderRect);
|
|
|
|
#undef MAP
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
return "<unknown>";
|
|
|
|
}
|
|
|
|
|
2013-07-12 13:33:32 +00:00
|
|
|
const char *
|
|
|
|
string_of_VARateControl(guint rate_control)
|
|
|
|
{
|
|
|
|
switch (rate_control) {
|
|
|
|
case VA_RC_NONE: return "None";
|
|
|
|
case VA_RC_CQP: return "CQP";
|
|
|
|
case VA_RC_CBR: return "CBR";
|
|
|
|
case VA_RC_VCM: return "VCM";
|
|
|
|
case VA_RC_VBR: return "VBR";
|
|
|
|
case VA_RC_VBR_CONSTRAINED: return "VBR-Constrained";
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
return "<unknown>";
|
|
|
|
}
|
|
|
|
|
2013-07-09 17:13:39 +00:00
|
|
|
/**
|
|
|
|
* from_GstVaapiChromaType:
|
|
|
|
* @chroma_type: the #GstVaapiChromaType
|
|
|
|
*
|
|
|
|
* Converts #GstVaapiChromaType to a chroma format suitable for
|
|
|
|
* vaCreateSurfaces().
|
|
|
|
*/
|
|
|
|
guint
|
|
|
|
from_GstVaapiChromaType(guint chroma_type)
|
|
|
|
{
|
|
|
|
guint format;
|
|
|
|
|
|
|
|
switch (chroma_type) {
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_YUV420:
|
|
|
|
format = VA_RT_FORMAT_YUV420;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_YUV422:
|
|
|
|
format = VA_RT_FORMAT_YUV422;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_YUV444:
|
|
|
|
format = VA_RT_FORMAT_YUV444;
|
|
|
|
break;
|
|
|
|
#if VA_CHECK_VERSION(0,34,0)
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_YUV411:
|
|
|
|
format = VA_RT_FORMAT_YUV411;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_YUV400:
|
|
|
|
format = VA_RT_FORMAT_YUV400;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_RGB32:
|
|
|
|
format = VA_RT_FORMAT_RGB32;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_CHROMA_TYPE_RGB16:
|
|
|
|
format = VA_RT_FORMAT_RGB16;
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
default:
|
|
|
|
format = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return format;
|
|
|
|
}
|
|
|
|
|
2013-01-04 08:41:25 +00:00
|
|
|
/**
|
|
|
|
* from_GstVaapiSubpictureFlags:
|
|
|
|
* @flags: the #GstVaapiSubpictureFlags
|
|
|
|
*
|
|
|
|
* Converts #GstVaapiSubpictureFlags to flags suitable for
|
|
|
|
* vaAssociateSubpicture().
|
|
|
|
*/
|
|
|
|
guint
|
|
|
|
from_GstVaapiSubpictureFlags(guint flags)
|
|
|
|
{
|
|
|
|
guint va_flags = 0;
|
|
|
|
|
|
|
|
if (flags & GST_VAAPI_SUBPICTURE_FLAG_GLOBAL_ALPHA)
|
|
|
|
va_flags |= VA_SUBPICTURE_GLOBAL_ALPHA;
|
|
|
|
#ifdef VA_SUBPICTURE_PREMULTIPLIED_ALPHA
|
|
|
|
if (flags & GST_VAAPI_SUBPICTURE_FLAG_PREMULTIPLIED_ALPHA)
|
|
|
|
flags |= VA_SUBPICTURE_PREMULTIPLIED_ALPHA;
|
|
|
|
#endif
|
|
|
|
return va_flags;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* to_GstVaapiSubpictureFlags:
|
|
|
|
* @flags: the #GstVaapiSubpictureFlags flags to translate
|
|
|
|
*
|
|
|
|
* Converts vaQuerySubpictureFormats() @flags to #GstVaapiSubpictureFlags
|
|
|
|
* flags.
|
|
|
|
*
|
|
|
|
* Return value: the #GstVaapiSubpictureFlags flags
|
|
|
|
*/
|
|
|
|
guint
|
|
|
|
to_GstVaapiSubpictureFlags(guint va_flags)
|
|
|
|
{
|
|
|
|
guint flags = 0;
|
|
|
|
|
|
|
|
if (va_flags & VA_SUBPICTURE_GLOBAL_ALPHA)
|
|
|
|
flags |= GST_VAAPI_SUBPICTURE_FLAG_GLOBAL_ALPHA;
|
|
|
|
#ifdef VA_SUBPICTURE_PREMULTIPLIED_ALPHA
|
|
|
|
if (va_flags & VA_SUBPICTURE_PREMULTIPLIED_ALPHA)
|
|
|
|
flags |= GST_VAAPI_SUBPICTURE_FLAG_PREMULTIPLIED_ALPHA;
|
|
|
|
#endif
|
|
|
|
return flags;
|
|
|
|
}
|
|
|
|
|
2012-05-15 08:24:08 +00:00
|
|
|
/**
|
|
|
|
* from_GstVideoOverlayFormatFlags:
|
|
|
|
* @flags: the #GstVideoOverlayFormatFlags flags to translate
|
|
|
|
*
|
|
|
|
* Converts #GstVaapiSubpictureFlags to #GstVaapiSubpictureFlags.
|
|
|
|
*
|
|
|
|
* Return value: the #GstVaapiSubpictureFlags flags
|
|
|
|
*/
|
|
|
|
guint
|
|
|
|
from_GstVideoOverlayFormatFlags(guint ovl_flags)
|
|
|
|
{
|
|
|
|
guint flags = 0;
|
|
|
|
|
2012-07-20 10:36:33 +00:00
|
|
|
#ifdef HAVE_GST_VIDEO_OVERLAY_HWCAPS
|
2012-05-15 08:24:08 +00:00
|
|
|
if (ovl_flags & GST_VIDEO_OVERLAY_FORMAT_FLAG_PREMULTIPLIED_ALPHA)
|
|
|
|
flags |= GST_VAAPI_SUBPICTURE_FLAG_PREMULTIPLIED_ALPHA;
|
|
|
|
if (ovl_flags & GST_VIDEO_OVERLAY_FORMAT_FLAG_GLOBAL_ALPHA)
|
|
|
|
flags |= GST_VAAPI_SUBPICTURE_FLAG_GLOBAL_ALPHA;
|
2012-07-20 10:36:33 +00:00
|
|
|
#endif
|
2012-05-15 08:24:08 +00:00
|
|
|
return flags;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* to_GstVideoOverlayFormatFlags:
|
|
|
|
* @flags: the #GstVaapiSubpictureFlags flags to translate
|
|
|
|
*
|
|
|
|
* Converts #GstVaapiSubpictureFlags to #GstVideoOverlayFormatFlags.
|
|
|
|
*
|
|
|
|
* Return value: the #GstVideoOverlayFormatFlags flags
|
|
|
|
*/
|
|
|
|
guint
|
|
|
|
to_GstVideoOverlayFormatFlags(guint flags)
|
|
|
|
{
|
|
|
|
guint ovl_flags = 0;
|
|
|
|
|
2012-07-20 10:36:33 +00:00
|
|
|
#ifdef HAVE_GST_VIDEO_OVERLAY_HWCAPS
|
2012-05-15 08:24:08 +00:00
|
|
|
if (flags & GST_VAAPI_SUBPICTURE_FLAG_PREMULTIPLIED_ALPHA)
|
|
|
|
ovl_flags |= GST_VIDEO_OVERLAY_FORMAT_FLAG_PREMULTIPLIED_ALPHA;
|
|
|
|
if (flags & GST_VAAPI_SUBPICTURE_FLAG_GLOBAL_ALPHA)
|
|
|
|
ovl_flags |= GST_VIDEO_OVERLAY_FORMAT_FLAG_GLOBAL_ALPHA;
|
2012-07-20 10:36:33 +00:00
|
|
|
#endif
|
2012-05-15 08:24:08 +00:00
|
|
|
return ovl_flags;
|
|
|
|
}
|
|
|
|
|
2010-03-21 08:38:17 +00:00
|
|
|
/**
|
2010-03-30 08:13:34 +00:00
|
|
|
* from_GstVaapiSurfaceRenderFlags:
|
|
|
|
* @flags: the #GstVaapiSurfaceRenderFlags
|
2010-03-21 08:38:17 +00:00
|
|
|
*
|
|
|
|
* Converts #GstVaapiSurfaceRenderFlags to flags suitable for
|
|
|
|
* vaPutSurface().
|
|
|
|
*/
|
2010-03-30 12:55:27 +00:00
|
|
|
guint
|
|
|
|
from_GstVaapiSurfaceRenderFlags(guint flags)
|
2010-03-21 08:38:17 +00:00
|
|
|
{
|
2012-03-28 13:05:26 +00:00
|
|
|
guint va_fields, va_csc;
|
2010-03-21 08:38:17 +00:00
|
|
|
|
2012-03-28 13:05:26 +00:00
|
|
|
/* Picture structure */
|
|
|
|
switch (flags & GST_VAAPI_PICTURE_STRUCTURE_MASK) {
|
|
|
|
case GST_VAAPI_PICTURE_STRUCTURE_TOP_FIELD:
|
|
|
|
va_fields = VA_TOP_FIELD;
|
|
|
|
break;
|
|
|
|
case GST_VAAPI_PICTURE_STRUCTURE_BOTTOM_FIELD:
|
|
|
|
va_fields = VA_BOTTOM_FIELD;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
va_fields = VA_FRAME_PICTURE;
|
|
|
|
break;
|
|
|
|
}
|
2010-03-21 08:38:17 +00:00
|
|
|
|
2012-03-28 13:05:26 +00:00
|
|
|
/* Color standard */
|
|
|
|
switch (flags & GST_VAAPI_COLOR_STANDARD_MASK) {
|
2010-03-24 16:17:49 +00:00
|
|
|
#ifdef VA_SRC_BT601
|
2012-03-28 13:05:26 +00:00
|
|
|
case GST_VAAPI_COLOR_STANDARD_ITUR_BT_601:
|
2010-03-24 16:17:49 +00:00
|
|
|
va_csc = VA_SRC_BT601;
|
2012-03-28 13:05:26 +00:00
|
|
|
break;
|
2010-03-24 16:17:49 +00:00
|
|
|
#endif
|
|
|
|
#ifdef VA_SRC_BT709
|
2012-03-28 13:05:26 +00:00
|
|
|
case GST_VAAPI_COLOR_STANDARD_ITUR_BT_709:
|
2010-03-24 16:17:49 +00:00
|
|
|
va_csc = VA_SRC_BT709;
|
2012-03-28 13:05:26 +00:00
|
|
|
break;
|
2010-03-24 16:17:49 +00:00
|
|
|
#endif
|
2012-03-28 13:05:26 +00:00
|
|
|
#ifdef VA_SRC_SMPTE_240
|
|
|
|
case GST_VAAPI_COLOR_STANDARD_SMPTE_240M:
|
|
|
|
va_csc = VA_SRC_SMPTE_240;
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
default:
|
|
|
|
va_csc = 0;
|
|
|
|
break;
|
|
|
|
}
|
2010-03-24 16:17:49 +00:00
|
|
|
return va_fields|va_csc;
|
2010-03-21 08:38:17 +00:00
|
|
|
}
|
2010-03-30 08:11:50 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* to_GstVaapiSurfaceStatus:
|
|
|
|
* @flags: the #GstVaapiSurfaceStatus flags to translate
|
|
|
|
*
|
|
|
|
* Converts vaQuerySurfaceStatus() @flags to #GstVaapiSurfaceStatus
|
|
|
|
* flags.
|
|
|
|
*
|
|
|
|
* Return value: the #GstVaapiSurfaceStatus flags
|
|
|
|
*/
|
2010-03-30 12:55:27 +00:00
|
|
|
guint
|
|
|
|
to_GstVaapiSurfaceStatus(guint va_flags)
|
2010-03-30 08:11:50 +00:00
|
|
|
{
|
|
|
|
guint flags;
|
|
|
|
const guint va_flags_mask = (VASurfaceReady|
|
|
|
|
VASurfaceRendering|
|
|
|
|
VASurfaceDisplaying);
|
|
|
|
|
|
|
|
/* Check for core status */
|
|
|
|
switch (va_flags & va_flags_mask) {
|
|
|
|
case VASurfaceReady:
|
|
|
|
flags = GST_VAAPI_SURFACE_STATUS_IDLE;
|
|
|
|
break;
|
|
|
|
case VASurfaceRendering:
|
|
|
|
flags = GST_VAAPI_SURFACE_STATUS_RENDERING;
|
|
|
|
break;
|
|
|
|
case VASurfaceDisplaying:
|
|
|
|
flags = GST_VAAPI_SURFACE_STATUS_DISPLAYING;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
flags = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Check for encoder status */
|
2010-03-30 13:05:31 +00:00
|
|
|
#if VA_CHECK_VERSION(0,30,0)
|
2010-03-30 08:11:50 +00:00
|
|
|
if (va_flags & VASurfaceSkipped)
|
|
|
|
flags |= GST_VAAPI_SURFACE_STATUS_SKIPPED;
|
2010-03-30 13:05:31 +00:00
|
|
|
#endif
|
2010-03-30 08:11:50 +00:00
|
|
|
return flags;
|
|
|
|
}
|
2012-08-22 06:18:11 +00:00
|
|
|
|
|
|
|
/* Translate GstVaapiRotation value to VA-API rotation value */
|
|
|
|
guint
|
|
|
|
from_GstVaapiRotation(guint value)
|
|
|
|
{
|
|
|
|
switch (value) {
|
|
|
|
case GST_VAAPI_ROTATION_0: return VA_ROTATION_NONE;
|
|
|
|
case GST_VAAPI_ROTATION_90: return VA_ROTATION_90;
|
|
|
|
case GST_VAAPI_ROTATION_180: return VA_ROTATION_180;
|
|
|
|
case GST_VAAPI_ROTATION_270: return VA_ROTATION_270;
|
|
|
|
}
|
|
|
|
GST_ERROR("unsupported GstVaapiRotation value %d", value);
|
|
|
|
return VA_ROTATION_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Translate VA-API rotation value to GstVaapiRotation value */
|
|
|
|
guint
|
|
|
|
to_GstVaapiRotation(guint value)
|
|
|
|
{
|
|
|
|
switch (value) {
|
|
|
|
case VA_ROTATION_NONE: return GST_VAAPI_ROTATION_0;
|
|
|
|
case VA_ROTATION_90: return GST_VAAPI_ROTATION_90;
|
|
|
|
case VA_ROTATION_180: return GST_VAAPI_ROTATION_180;
|
|
|
|
case VA_ROTATION_270: return GST_VAAPI_ROTATION_270;
|
|
|
|
}
|
|
|
|
GST_ERROR("unsupported VA-API rotation value %d", value);
|
|
|
|
return GST_VAAPI_ROTATION_0;
|
|
|
|
}
|
2013-07-29 01:23:50 +00:00
|
|
|
|
2013-07-12 13:33:32 +00:00
|
|
|
guint
|
|
|
|
from_GstVaapiRateControl(guint value)
|
|
|
|
{
|
|
|
|
switch (value) {
|
|
|
|
case GST_VAAPI_RATECONTROL_NONE: return VA_RC_NONE;
|
|
|
|
case GST_VAAPI_RATECONTROL_CQP: return VA_RC_CQP;
|
|
|
|
case GST_VAAPI_RATECONTROL_CBR: return VA_RC_CBR;
|
|
|
|
case GST_VAAPI_RATECONTROL_VCM: return VA_RC_VCM;
|
|
|
|
case GST_VAAPI_RATECONTROL_VBR: return VA_RC_VBR;
|
|
|
|
case GST_VAAPI_RATECONTROL_VBR_CONSTRAINED: return VA_RC_VBR_CONSTRAINED;
|
|
|
|
}
|
|
|
|
GST_ERROR("unsupported GstVaapiRateControl value %u", value);
|
|
|
|
return VA_RC_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
guint
|
|
|
|
to_GstVaapiRateControl(guint value)
|
|
|
|
{
|
|
|
|
switch (value) {
|
|
|
|
case VA_RC_NONE: return GST_VAAPI_RATECONTROL_NONE;
|
|
|
|
case VA_RC_CQP: return GST_VAAPI_RATECONTROL_CQP;
|
|
|
|
case VA_RC_CBR: return GST_VAAPI_RATECONTROL_CBR;
|
|
|
|
case VA_RC_VCM: return GST_VAAPI_RATECONTROL_VCM;
|
|
|
|
case VA_RC_VBR: return GST_VAAPI_RATECONTROL_VBR;
|
|
|
|
case VA_RC_VBR_CONSTRAINED: return GST_VAAPI_RATECONTROL_VBR_CONSTRAINED;
|
|
|
|
}
|
|
|
|
GST_ERROR("unsupported VA-API Rate Control value %u", value);
|
|
|
|
return GST_VAAPI_RATECONTROL_NONE;
|
|
|
|
}
|
|
|
|
|
2013-07-29 01:23:50 +00:00
|
|
|
/* VPP: translate GstVaapiDeinterlaceMethod to VA deinterlacing algorithm */
|
|
|
|
guint
|
|
|
|
from_GstVaapiDeinterlaceMethod(guint value)
|
|
|
|
{
|
|
|
|
switch (value) {
|
|
|
|
case GST_VAAPI_DEINTERLACE_METHOD_NONE:
|
|
|
|
return 0;
|
|
|
|
#if USE_VA_VPP
|
|
|
|
case GST_VAAPI_DEINTERLACE_METHOD_BOB:
|
|
|
|
return VAProcDeinterlacingBob;
|
|
|
|
case GST_VAAPI_DEINTERLACE_METHOD_WEAVE:
|
|
|
|
return VAProcDeinterlacingWeave;
|
|
|
|
case GST_VAAPI_DEINTERLACE_METHOD_MOTION_ADAPTIVE:
|
|
|
|
return VAProcDeinterlacingMotionAdaptive;
|
|
|
|
case GST_VAAPI_DEINTERLACE_METHOD_MOTION_COMPENSATED:
|
|
|
|
return VAProcDeinterlacingMotionCompensated;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
GST_ERROR("unsupported GstVaapiDeinterlaceMethod value %d", value);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* VPP: translate GstVaapiDeinterlaceFlags into VA deinterlacing flags */
|
|
|
|
guint
|
|
|
|
from_GstVaapiDeinterlaceFlags(guint flags)
|
|
|
|
{
|
|
|
|
guint va_flags = 0;
|
|
|
|
|
|
|
|
#if USE_VA_VPP
|
|
|
|
if (!(flags & GST_VAAPI_DEINTERLACE_FLAG_TFF))
|
|
|
|
va_flags |= VA_DEINTERLACING_BOTTOM_FIELD_FIRST;
|
|
|
|
|
2013-11-21 17:44:46 +00:00
|
|
|
if (flags & GST_VAAPI_DEINTERLACE_FLAG_ONEFIELD)
|
2013-07-29 01:23:50 +00:00
|
|
|
va_flags |= VA_DEINTERLACING_ONE_FIELD;
|
2013-11-21 17:44:46 +00:00
|
|
|
|
|
|
|
if (!(flags & GST_VAAPI_DEINTERLACE_FLAG_TOPFIELD))
|
|
|
|
va_flags |= VA_DEINTERLACING_BOTTOM_FIELD;
|
2013-07-29 01:23:50 +00:00
|
|
|
#endif
|
|
|
|
return va_flags;
|
|
|
|
}
|