2012-11-08 14:41:22 +00:00
|
|
|
/*
|
|
|
|
* gstvaapivideomemory.h - Gstreamer/VA video memory
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 Intel Corporation
|
2013-11-22 04:57:18 +00:00
|
|
|
* Author: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
|
2012-11-08 14:41:22 +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.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GST_VAAPI_VIDEO_MEMORY_H
|
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_H
|
|
|
|
|
|
|
|
#include <gst/gstallocator.h>
|
|
|
|
#include <gst/video/video-info.h>
|
|
|
|
#include <gst/vaapi/gstvaapidisplay.h>
|
2014-07-24 04:46:22 +00:00
|
|
|
#include <gst/vaapi/gstvaapivideopool.h>
|
2012-11-08 14:41:22 +00:00
|
|
|
#include "gstvaapivideometa.h"
|
2015-01-26 17:30:47 +00:00
|
|
|
#include <gst/allocators/allocators.h>
|
2012-11-08 14:41:22 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2014-08-21 08:45:31 +00:00
|
|
|
typedef struct _GstVaapiVideoMemory GstVaapiVideoMemory;
|
|
|
|
typedef struct _GstVaapiVideoAllocator GstVaapiVideoAllocator;
|
|
|
|
typedef struct _GstVaapiVideoAllocatorClass GstVaapiVideoAllocatorClass;
|
2012-11-08 14:41:22 +00:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
/* --- GstVaapiVideoMemory --- */
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_CAST(mem) \
|
2014-08-21 08:45:31 +00:00
|
|
|
((GstVaapiVideoMemory *) (mem))
|
2012-11-08 14:41:22 +00:00
|
|
|
|
2014-11-21 14:23:13 +00:00
|
|
|
#define GST_VAAPI_IS_VIDEO_MEMORY(mem) \
|
|
|
|
((mem) && (mem)->allocator && GST_VAAPI_IS_VIDEO_ALLOCATOR((mem)->allocator))
|
|
|
|
|
2012-11-08 14:41:22 +00:00
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_NAME "GstVaapiVideoMemory"
|
|
|
|
|
2013-07-04 08:03:52 +00:00
|
|
|
#define GST_CAPS_FEATURE_MEMORY_VAAPI_SURFACE "memory:VASurface"
|
|
|
|
|
2014-11-21 14:23:13 +00:00
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_FLAG_IS_SET(mem, flag) \
|
|
|
|
GST_MEMORY_FLAG_IS_SET (mem, flag)
|
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_FLAG_SET(mem, flag) \
|
|
|
|
GST_MINI_OBJECT_FLAG_SET (mem, flag)
|
|
|
|
#define GST_VAAPI_VIDEO_MEMORY_FLAG_UNSET(mem, flag) \
|
|
|
|
GST_MEMORY_FLAG_UNSET (mem, flag)
|
|
|
|
|
2013-06-05 09:01:51 +00:00
|
|
|
/**
|
|
|
|
* GstVaapiVideoMemoryMapType:
|
|
|
|
* @GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_SURFACE: map with gst_buffer_map()
|
2014-07-23 16:54:13 +00:00
|
|
|
* and flags = 0x00 to return a #GstVaapiSurfaceProxy
|
2013-06-05 09:01:51 +00:00
|
|
|
* @GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_PLANAR: map individual plane with
|
|
|
|
* gst_video_frame_map()
|
2014-07-23 16:54:13 +00:00
|
|
|
* @GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_LINEAR: map with gst_buffer_map()
|
|
|
|
* and flags = GST_MAP_READ to return the raw pixels of the whole image
|
2013-06-05 09:01:51 +00:00
|
|
|
*
|
|
|
|
* The set of all #GstVaapiVideoMemory map types.
|
|
|
|
*/
|
2014-08-21 08:45:31 +00:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_SURFACE = 1,
|
|
|
|
GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_PLANAR,
|
|
|
|
GST_VAAPI_VIDEO_MEMORY_MAP_TYPE_LINEAR
|
2013-06-05 09:01:51 +00:00
|
|
|
} GstVaapiVideoMemoryMapType;
|
|
|
|
|
2014-11-21 14:23:13 +00:00
|
|
|
/**
|
|
|
|
* GstVaapiVideoMemoryFlags:
|
|
|
|
* @GST_VAAPI_VIDEO_MEMORY_FLAG_SURFACE_IS_CURRENT: The embedded
|
|
|
|
* #GstVaapiSurface has the up-to-date video frame contents.
|
|
|
|
* @GST_VAAPI_VIDEO_MEMORY_FLAG_IMAGE_IS_CURRENT: The embedded
|
|
|
|
* #GstVaapiImage has the up-to-date video frame contents.
|
|
|
|
*
|
|
|
|
* The set of extended #GstMemory flags.
|
|
|
|
*/
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
GST_VAAPI_VIDEO_MEMORY_FLAG_SURFACE_IS_CURRENT = GST_MEMORY_FLAG_LAST << 0,
|
|
|
|
GST_VAAPI_VIDEO_MEMORY_FLAG_IMAGE_IS_CURRENT = GST_MEMORY_FLAG_LAST << 1,
|
|
|
|
} GstVaapiVideoMemoryFlags;
|
|
|
|
|
2016-10-20 14:49:22 +00:00
|
|
|
/**
|
|
|
|
* GstVaapiImageUsageFlags:
|
|
|
|
* @GST_VAAPI_IMAGE_USAGE_FLAG_NATIVE_FORMATS: will use vaCreateImage +
|
|
|
|
* va{Put,Get}Image when writing or reading onto the system memory.
|
2016-10-20 15:02:49 +00:00
|
|
|
* @GST_VAAPI_IMAGE_USAGE_FLAG_DIRECT_UPLOAD: will try to use
|
|
|
|
* vaDeriveImage when writing data from the system memory.
|
2016-10-20 14:49:22 +00:00
|
|
|
* @GST_VAAPI_IMAGE_USAGE_FLAG_DIRECT_RENDER: will try to use
|
|
|
|
* vaDeriveImage with reading data onto the system memory.
|
|
|
|
*
|
|
|
|
* Set the usage of GstVaapiImage in GstVaapiVideoMemory.
|
|
|
|
**/
|
|
|
|
typedef enum {
|
|
|
|
GST_VAAPI_IMAGE_USAGE_FLAG_NATIVE_FORMATS,
|
2016-10-20 15:02:49 +00:00
|
|
|
GST_VAAPI_IMAGE_USAGE_FLAG_DIRECT_UPLOAD,
|
2016-10-20 14:49:22 +00:00
|
|
|
GST_VAAPI_IMAGE_USAGE_FLAG_DIRECT_RENDER,
|
|
|
|
} GstVaapiImageUsageFlags;
|
|
|
|
|
2012-11-08 14:41:22 +00:00
|
|
|
/**
|
|
|
|
* GstVaapiVideoMemory:
|
|
|
|
*
|
|
|
|
* A VA video memory object holder, including VA surfaces, images and
|
|
|
|
* proxies.
|
|
|
|
*/
|
2014-08-21 08:45:31 +00:00
|
|
|
struct _GstVaapiVideoMemory
|
|
|
|
{
|
|
|
|
GstMemory parent_instance;
|
|
|
|
|
|
|
|
/*< private >*/
|
|
|
|
GstVaapiSurfaceProxy *proxy;
|
|
|
|
const GstVideoInfo *surface_info;
|
|
|
|
GstVaapiSurface *surface;
|
|
|
|
const GstVideoInfo *image_info;
|
|
|
|
GstVaapiImage *image;
|
|
|
|
GstVaapiVideoMeta *meta;
|
|
|
|
guint map_type;
|
|
|
|
gint map_count;
|
2016-10-20 14:49:22 +00:00
|
|
|
GstVaapiImageUsageFlags usage_flag;
|
2012-11-08 14:41:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
GstMemory *
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_vaapi_video_memory_new (GstAllocator * allocator, GstVaapiVideoMeta * meta);
|
2012-11-08 14:41:22 +00:00
|
|
|
|
2013-04-09 14:02:06 +00:00
|
|
|
G_GNUC_INTERNAL
|
|
|
|
gboolean
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_video_meta_map_vaapi_memory (GstVideoMeta * meta, guint plane,
|
|
|
|
GstMapInfo * info, gpointer * data, gint * stride, GstMapFlags flags);
|
2013-04-09 14:02:06 +00:00
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
gboolean
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_video_meta_unmap_vaapi_memory (GstVideoMeta * meta, guint plane,
|
|
|
|
GstMapInfo * info);
|
2013-04-09 14:02:06 +00:00
|
|
|
|
2013-10-09 07:47:18 +00:00
|
|
|
G_GNUC_INTERNAL
|
|
|
|
void
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_vaapi_video_memory_reset_surface (GstVaapiVideoMemory * mem);
|
2013-10-09 07:47:18 +00:00
|
|
|
|
2014-11-21 14:23:13 +00:00
|
|
|
G_GNUC_INTERNAL
|
|
|
|
gboolean
|
|
|
|
gst_vaapi_video_memory_sync (GstVaapiVideoMemory * mem);
|
|
|
|
|
2012-11-08 14:41:22 +00:00
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
/* --- GstVaapiVideoAllocator --- */
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
#define GST_VAAPI_VIDEO_ALLOCATOR_CAST(allocator) \
|
2014-08-21 08:45:31 +00:00
|
|
|
((GstVaapiVideoAllocator *) (allocator))
|
2012-11-08 14:41:22 +00:00
|
|
|
|
|
|
|
#define GST_VAAPI_TYPE_VIDEO_ALLOCATOR \
|
2014-08-21 08:45:31 +00:00
|
|
|
(gst_vaapi_video_allocator_get_type ())
|
|
|
|
#define GST_VAAPI_VIDEO_ALLOCATOR(obj) \
|
|
|
|
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_VAAPI_TYPE_VIDEO_ALLOCATOR, \
|
|
|
|
GstVaapiVideoAllocator))
|
2012-11-08 14:41:22 +00:00
|
|
|
#define GST_VAAPI_IS_VIDEO_ALLOCATOR(obj) \
|
2014-08-21 08:45:31 +00:00
|
|
|
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_VAAPI_TYPE_VIDEO_ALLOCATOR))
|
2012-11-08 14:41:22 +00:00
|
|
|
|
|
|
|
#define GST_VAAPI_VIDEO_ALLOCATOR_NAME "GstVaapiVideoAllocator"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GstVaapiVideoAllocator:
|
|
|
|
*
|
|
|
|
* A VA video memory allocator object.
|
|
|
|
*/
|
2014-08-21 08:45:31 +00:00
|
|
|
struct _GstVaapiVideoAllocator
|
|
|
|
{
|
|
|
|
GstAllocator parent_instance;
|
|
|
|
|
|
|
|
/*< private >*/
|
|
|
|
GstVideoInfo video_info;
|
|
|
|
GstVideoInfo surface_info;
|
|
|
|
GstVaapiVideoPool *surface_pool;
|
|
|
|
GstVideoInfo image_info;
|
|
|
|
GstVaapiVideoPool *image_pool;
|
2016-10-20 14:49:22 +00:00
|
|
|
GstVaapiImageUsageFlags usage_flag;
|
2012-11-08 14:41:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GstVaapiVideoAllocatorClass:
|
|
|
|
*
|
|
|
|
* A VA video memory allocator class.
|
|
|
|
*/
|
2014-08-21 08:45:31 +00:00
|
|
|
struct _GstVaapiVideoAllocatorClass
|
|
|
|
{
|
|
|
|
GstAllocatorClass parent_class;
|
2012-11-08 14:41:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
GType
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_vaapi_video_allocator_get_type (void) G_GNUC_CONST;
|
2012-11-08 14:41:22 +00:00
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
GstAllocator *
|
2014-08-21 08:45:31 +00:00
|
|
|
gst_vaapi_video_allocator_new (GstVaapiDisplay * display,
|
2016-10-20 14:49:22 +00:00
|
|
|
const GstVideoInfo * vip, guint surface_alloc_flags,
|
|
|
|
GstVaapiImageUsageFlags req_usage_flag);
|
2012-11-08 14:41:22 +00:00
|
|
|
|
2015-01-26 17:30:47 +00:00
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
/* --- GstVaapiDmaBufMemory --- */
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
GstMemory *
|
|
|
|
gst_vaapi_dmabuf_memory_new (GstAllocator * allocator,
|
|
|
|
GstVaapiVideoMeta * meta);
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
/* --- GstVaapiDmaBufAllocator --- */
|
|
|
|
/* ------------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
G_GNUC_INTERNAL
|
|
|
|
GstAllocator *
|
|
|
|
gst_vaapi_dmabuf_allocator_new (GstVaapiDisplay * display,
|
|
|
|
const GstVideoInfo * vip, guint flags);
|
|
|
|
|
2016-06-08 16:42:43 +00:00
|
|
|
G_GNUC_INTERNAL
|
2015-01-26 17:30:47 +00:00
|
|
|
const GstVideoInfo *
|
|
|
|
gst_allocator_get_vaapi_video_info (GstAllocator * allocator,
|
|
|
|
guint * out_flags_ptr);
|
|
|
|
|
2016-06-08 16:42:43 +00:00
|
|
|
G_GNUC_INTERNAL
|
2015-01-26 17:30:47 +00:00
|
|
|
gboolean
|
|
|
|
gst_allocator_set_vaapi_video_info (GstAllocator * allocator,
|
|
|
|
const GstVideoInfo * vip, guint flags);
|
|
|
|
|
2016-07-29 13:13:29 +00:00
|
|
|
G_GNUC_INTERNAL
|
|
|
|
gboolean
|
|
|
|
gst_allocator_get_vaapi_image_size (GstAllocator * allocator, guint * size);
|
|
|
|
|
2016-06-08 16:42:43 +00:00
|
|
|
G_GNUC_INTERNAL
|
2016-05-20 16:46:14 +00:00
|
|
|
gboolean
|
|
|
|
gst_vaapi_is_dmabuf_allocator (GstAllocator * allocator);
|
|
|
|
|
2012-11-08 14:41:22 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* GST_VAAPI_VIDEO_MEMORY_H */
|