mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-02 21:48:55 +00:00
va: Move the vautils into the gst va lib.
The context query and handle are common logic for all va related elements. So we move it from va plugins to the common gst va lib. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1256>
This commit is contained in:
parent
74233cfd67
commit
d5c535744b
8 changed files with 116 additions and 23 deletions
|
@ -44,8 +44,6 @@ _init_context_debug (void)
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_va_display_found (GstElement * element, GstVaDisplay * display)
|
gst_va_display_found (GstElement * element, GstVaDisplay * display)
|
||||||
{
|
{
|
||||||
_init_context_debug ();
|
|
||||||
|
|
||||||
if (display) {
|
if (display) {
|
||||||
GST_CAT_LOG_OBJECT (GST_CAT_CONTEXT, element, "already have a display (%p)",
|
GST_CAT_LOG_OBJECT (GST_CAT_CONTEXT, element, "already have a display (%p)",
|
||||||
display);
|
display);
|
||||||
|
@ -62,8 +60,6 @@ pad_query (const GValue * item, GValue * value, gpointer user_data)
|
||||||
GstQuery *query = user_data;
|
GstQuery *query = user_data;
|
||||||
gboolean res;
|
gboolean res;
|
||||||
|
|
||||||
_init_context_debug ();
|
|
||||||
|
|
||||||
res = gst_pad_peer_query (pad, query);
|
res = gst_pad_peer_query (pad, query);
|
||||||
|
|
||||||
if (res) {
|
if (res) {
|
||||||
|
@ -99,8 +95,17 @@ _gst_va_run_query (GstElement * element, GstQuery * query,
|
||||||
return g_value_get_boolean (&res);
|
return g_value_get_boolean (&res);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
/**
|
||||||
_gst_context_query (GstElement * element, const gchar * context_type)
|
* gst_va_context_query:
|
||||||
|
* @element: a #GstElement
|
||||||
|
* @context_type: the #gchar string specify the context type name
|
||||||
|
*
|
||||||
|
* Query the specified context type name.
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
|
void
|
||||||
|
gst_va_context_query (GstElement * element, const gchar * context_type)
|
||||||
{
|
{
|
||||||
GstQuery *query;
|
GstQuery *query;
|
||||||
GstContext *ctxt = NULL;
|
GstContext *ctxt = NULL;
|
||||||
|
@ -147,9 +152,15 @@ _gst_context_query (GstElement * element, const gchar * context_type)
|
||||||
gst_query_unref (query);
|
gst_query_unref (query);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 4) Create a context by itself and post a GST_MESSAGE_HAVE_CONTEXT
|
/**
|
||||||
* message.
|
* gst_va_element_propagate_display_context:
|
||||||
*/
|
* @element: a #GstElement
|
||||||
|
* @display: the #GstVaDisplay to propagate
|
||||||
|
*
|
||||||
|
* Propagate @display by posting it as #GstContext in the pipeline's bus.
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
void
|
void
|
||||||
gst_va_element_propagate_display_context (GstElement * element,
|
gst_va_element_propagate_display_context (GstElement * element,
|
||||||
GstVaDisplay * display)
|
GstVaDisplay * display)
|
||||||
|
@ -157,13 +168,16 @@ gst_va_element_propagate_display_context (GstElement * element,
|
||||||
GstContext *ctxt;
|
GstContext *ctxt;
|
||||||
GstMessage *msg;
|
GstMessage *msg;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
if (!display) {
|
if (!display) {
|
||||||
GST_ERROR_OBJECT (element, "Could not get VA display connection");
|
GST_ERROR_OBJECT (element, "Could not get VA display connection");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
_init_context_debug ();
|
/* 4) Create a context by itself and post a GST_MESSAGE_HAVE_CONTEXT
|
||||||
|
* message.
|
||||||
|
*/
|
||||||
ctxt = gst_context_new (GST_VA_DISPLAY_HANDLE_CONTEXT_TYPE_STR, TRUE);
|
ctxt = gst_context_new (GST_VA_DISPLAY_HANDLE_CONTEXT_TYPE_STR, TRUE);
|
||||||
gst_context_set_va_display (ctxt, display);
|
gst_context_set_va_display (ctxt, display);
|
||||||
|
|
||||||
|
@ -173,12 +187,26 @@ gst_va_element_propagate_display_context (GstElement * element,
|
||||||
gst_element_post_message (element, msg);
|
gst_element_post_message (element, msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_va_ensure_element_data:
|
||||||
|
* @element: a #GstElement
|
||||||
|
* @render_device_path: the #gchar string of render device path
|
||||||
|
* @display_ptr: (out) (transfer full): The #GstVaDisplay to ensure
|
||||||
|
*
|
||||||
|
* Called by the va element to ensure a valid #GstVaDisplay.
|
||||||
|
*
|
||||||
|
* Returns: whether a #GstVaDisplay exists in @display_ptr
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
gboolean
|
gboolean
|
||||||
gst_va_ensure_element_data (gpointer element, const gchar * render_device_path,
|
gst_va_ensure_element_data (gpointer element, const gchar * render_device_path,
|
||||||
GstVaDisplay ** display_ptr)
|
GstVaDisplay ** display_ptr)
|
||||||
{
|
{
|
||||||
GstVaDisplay *display;
|
GstVaDisplay *display;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
g_return_val_if_fail (element, FALSE);
|
g_return_val_if_fail (element, FALSE);
|
||||||
g_return_val_if_fail (render_device_path, FALSE);
|
g_return_val_if_fail (render_device_path, FALSE);
|
||||||
g_return_val_if_fail (display_ptr, FALSE);
|
g_return_val_if_fail (display_ptr, FALSE);
|
||||||
|
@ -189,13 +217,13 @@ gst_va_ensure_element_data (gpointer element, const gchar * render_device_path,
|
||||||
if (gst_va_display_found (element, g_atomic_pointer_get (display_ptr)))
|
if (gst_va_display_found (element, g_atomic_pointer_get (display_ptr)))
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
_gst_context_query (element, GST_VA_DISPLAY_HANDLE_CONTEXT_TYPE_STR);
|
gst_va_context_query (element, GST_VA_DISPLAY_HANDLE_CONTEXT_TYPE_STR);
|
||||||
|
|
||||||
/* Neighbour found and it updated the display */
|
/* Neighbour found and it updated the display. */
|
||||||
if (gst_va_display_found (element, g_atomic_pointer_get (display_ptr)))
|
if (gst_va_display_found (element, g_atomic_pointer_get (display_ptr)))
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
/* If no neighbor, or application not interested, use drm */
|
/* If no neighbor, or application not interested, use drm. */
|
||||||
display = gst_va_display_drm_new_from_path (render_device_path);
|
display = gst_va_display_drm_new_from_path (render_device_path);
|
||||||
|
|
||||||
gst_object_replace ((GstObject **) display_ptr, (GstObject *) display);
|
gst_object_replace ((GstObject **) display_ptr, (GstObject *) display);
|
||||||
|
@ -208,6 +236,21 @@ done:
|
||||||
return g_atomic_pointer_get (display_ptr) != NULL;
|
return g_atomic_pointer_get (display_ptr) != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_va_handle_set_context:
|
||||||
|
* @element: a #GstElement
|
||||||
|
* @context: a #GstContext may contain the display
|
||||||
|
* @render_device_path: the #gchar string of render device path
|
||||||
|
* @display_ptr: (out) (transfer full): The #GstVaDisplay to set
|
||||||
|
*
|
||||||
|
* Called by elements in their GstElement::set_context() vmehtods.
|
||||||
|
* It gets a valid #GstVaDisplay if @context has it.
|
||||||
|
*
|
||||||
|
* Returns: whether the @display_ptr could be successfully set to
|
||||||
|
* a valid #GstVaDisplay in the @context
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
gboolean
|
gboolean
|
||||||
gst_va_handle_set_context (GstElement * element, GstContext * context,
|
gst_va_handle_set_context (GstElement * element, GstContext * context,
|
||||||
const gchar * render_device_path, GstVaDisplay ** display_ptr)
|
const gchar * render_device_path, GstVaDisplay ** display_ptr)
|
||||||
|
@ -215,6 +258,8 @@ gst_va_handle_set_context (GstElement * element, GstContext * context,
|
||||||
GstVaDisplay *display_replacement = NULL;
|
GstVaDisplay *display_replacement = NULL;
|
||||||
const gchar *context_type, *type_name;
|
const gchar *context_type, *type_name;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
g_return_val_if_fail (display_ptr, FALSE);
|
g_return_val_if_fail (display_ptr, FALSE);
|
||||||
|
|
||||||
if (!context)
|
if (!context)
|
||||||
|
@ -241,6 +286,19 @@ gst_va_handle_set_context (GstElement * element, GstContext * context,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_va_handle_context_query:
|
||||||
|
* @element: a #GstElement
|
||||||
|
* @query: a #GstQuery to query the context
|
||||||
|
* @display: a #GstVaDisplay to answer the query
|
||||||
|
*
|
||||||
|
* Used by elements when processing their pad's queries, propagating
|
||||||
|
* element's #GstVaDisplay if the processed query requests it.
|
||||||
|
*
|
||||||
|
* Returns: whether we can handle the context query successfully
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
gboolean
|
gboolean
|
||||||
gst_va_handle_context_query (GstElement * element, GstQuery * query,
|
gst_va_handle_context_query (GstElement * element, GstQuery * query,
|
||||||
GstVaDisplay * display)
|
GstVaDisplay * display)
|
||||||
|
@ -248,12 +306,12 @@ gst_va_handle_context_query (GstElement * element, GstQuery * query,
|
||||||
const gchar *context_type;
|
const gchar *context_type;
|
||||||
GstContext *ctxt, *old_ctxt;
|
GstContext *ctxt, *old_ctxt;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
g_return_val_if_fail (GST_IS_ELEMENT (element), FALSE);
|
g_return_val_if_fail (GST_IS_ELEMENT (element), FALSE);
|
||||||
g_return_val_if_fail (GST_IS_QUERY (query), FALSE);
|
g_return_val_if_fail (GST_IS_QUERY (query), FALSE);
|
||||||
g_return_val_if_fail (!display || GST_IS_VA_DISPLAY (display), FALSE);
|
g_return_val_if_fail (!display || GST_IS_VA_DISPLAY (display), FALSE);
|
||||||
|
|
||||||
_init_context_debug ();
|
|
||||||
|
|
||||||
GST_CAT_LOG_OBJECT (GST_CAT_CONTEXT, element,
|
GST_CAT_LOG_OBJECT (GST_CAT_CONTEXT, element,
|
||||||
"handle context query %" GST_PTR_FORMAT, query);
|
"handle context query %" GST_PTR_FORMAT, query);
|
||||||
gst_query_parse_context_type (query, &context_type);
|
gst_query_parse_context_type (query, &context_type);
|
||||||
|
@ -273,11 +331,22 @@ gst_va_handle_context_query (GstElement * element, GstQuery * query,
|
||||||
gst_query_set_context (query, ctxt);
|
gst_query_set_context (query, ctxt);
|
||||||
gst_context_unref (ctxt);
|
gst_context_unref (ctxt);
|
||||||
GST_CAT_DEBUG_OBJECT (GST_CAT_CONTEXT, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_CONTEXT, element,
|
||||||
"successuflly %" GST_PTR_FORMAT " on %" GST_PTR_FORMAT, display, query);
|
"successfully %" GST_PTR_FORMAT " on %" GST_PTR_FORMAT, display, query);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_context_get_va_display:
|
||||||
|
* @context: a #GstContext may contain the display
|
||||||
|
* @type_name: a #gchar string of the element type
|
||||||
|
* @render_device_path: the #gchar string of render device path
|
||||||
|
* @display_ptr: (out) (transfer full): the #GstVaDisplay we get
|
||||||
|
*
|
||||||
|
* Returns: whether we find a valid @display in the @context
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
**/
|
||||||
gboolean
|
gboolean
|
||||||
gst_context_get_va_display (GstContext * context, const gchar * type_name,
|
gst_context_get_va_display (GstContext * context, const gchar * type_name,
|
||||||
const gchar * render_device_path, GstVaDisplay ** display_ptr)
|
const gchar * render_device_path, GstVaDisplay ** display_ptr)
|
||||||
|
@ -287,6 +356,8 @@ gst_context_get_va_display (GstContext * context, const gchar * type_name,
|
||||||
gpointer dpy;
|
gpointer dpy;
|
||||||
gboolean is_devnode;
|
gboolean is_devnode;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
g_return_val_if_fail (display_ptr, FALSE);
|
g_return_val_if_fail (display_ptr, FALSE);
|
||||||
g_return_val_if_fail (context, FALSE);
|
g_return_val_if_fail (context, FALSE);
|
||||||
|
|
||||||
|
@ -333,11 +404,22 @@ accept:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_context_set_va_display:
|
||||||
|
* @context: a #GstContext
|
||||||
|
* @display: the #GstVaDisplay we want to set
|
||||||
|
*
|
||||||
|
* Set the @display in the @context
|
||||||
|
*
|
||||||
|
* Since: 1.22
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
gst_context_set_va_display (GstContext * context, GstVaDisplay * display)
|
gst_context_set_va_display (GstContext * context, GstVaDisplay * display)
|
||||||
{
|
{
|
||||||
GstStructure *s;
|
GstStructure *s;
|
||||||
|
|
||||||
|
_init_context_debug ();
|
||||||
|
|
||||||
g_return_if_fail (context != NULL);
|
g_return_if_fail (context != NULL);
|
||||||
|
|
||||||
if (display) {
|
if (display) {
|
|
@ -24,23 +24,31 @@
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
GST_VA_API
|
||||||
gboolean gst_va_ensure_element_data (gpointer element,
|
gboolean gst_va_ensure_element_data (gpointer element,
|
||||||
const gchar *render_device_path,
|
const gchar *render_device_path,
|
||||||
GstVaDisplay ** display_ptr);
|
GstVaDisplay ** display_ptr);
|
||||||
|
GST_VA_API
|
||||||
|
void gst_va_context_query (GstElement * element,
|
||||||
|
const gchar * context_type);
|
||||||
|
GST_VA_API
|
||||||
gboolean gst_va_handle_set_context (GstElement * element,
|
gboolean gst_va_handle_set_context (GstElement * element,
|
||||||
GstContext * context,
|
GstContext * context,
|
||||||
const gchar *render_device_path,
|
const gchar *render_device_path,
|
||||||
GstVaDisplay ** display_ptr);
|
GstVaDisplay ** display_ptr);
|
||||||
|
GST_VA_API
|
||||||
gboolean gst_va_handle_context_query (GstElement * element,
|
gboolean gst_va_handle_context_query (GstElement * element,
|
||||||
GstQuery * query,
|
GstQuery * query,
|
||||||
GstVaDisplay * display);
|
GstVaDisplay * display);
|
||||||
|
GST_VA_API
|
||||||
void gst_va_element_propagate_display_context (GstElement * element,
|
void gst_va_element_propagate_display_context (GstElement * element,
|
||||||
GstVaDisplay * display);
|
GstVaDisplay * display);
|
||||||
|
GST_VA_API
|
||||||
gboolean gst_context_get_va_display (GstContext * context,
|
gboolean gst_context_get_va_display (GstContext * context,
|
||||||
const gchar * type_name,
|
const gchar * type_name,
|
||||||
const gchar * render_device_path,
|
const gchar * render_device_path,
|
||||||
GstVaDisplay ** display_ptr);
|
GstVaDisplay ** display_ptr);
|
||||||
|
GST_VA_API
|
||||||
void gst_context_set_va_display (GstContext * context,
|
void gst_context_set_va_display (GstContext * context,
|
||||||
GstVaDisplay * display);
|
GstVaDisplay * display);
|
||||||
|
|
|
@ -2,12 +2,14 @@ va_sources = [
|
||||||
'gstvadisplay.c',
|
'gstvadisplay.c',
|
||||||
'gstvadisplay_drm.c',
|
'gstvadisplay_drm.c',
|
||||||
'gstvadisplay_wrapped.c',
|
'gstvadisplay_wrapped.c',
|
||||||
|
'gstvautils.c',
|
||||||
]
|
]
|
||||||
|
|
||||||
va_headers = [
|
va_headers = [
|
||||||
'gstvadisplay.h',
|
'gstvadisplay.h',
|
||||||
'gstvadisplay_drm.h',
|
'gstvadisplay_drm.h',
|
||||||
'gstvadisplay_wrapped.h',
|
'gstvadisplay_wrapped.h',
|
||||||
|
'gstvautils.h',
|
||||||
'va_fwd.h',
|
'va_fwd.h',
|
||||||
'va-prelude.h',
|
'va-prelude.h',
|
||||||
]
|
]
|
||||||
|
|
|
@ -18,12 +18,13 @@
|
||||||
* Boston, MA 02110-1301, USA.
|
* Boston, MA 02110-1301, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <gst/va/gstvautils.h>
|
||||||
|
|
||||||
#include "gstvabasedec.h"
|
#include "gstvabasedec.h"
|
||||||
|
|
||||||
#include "gstvaallocator.h"
|
#include "gstvaallocator.h"
|
||||||
#include "gstvacaps.h"
|
#include "gstvacaps.h"
|
||||||
#include "gstvapool.h"
|
#include "gstvapool.h"
|
||||||
#include "gstvautils.h"
|
|
||||||
#include "gstvavideoformat.h"
|
#include "gstvavideoformat.h"
|
||||||
|
|
||||||
#define GST_CAT_DEFAULT (base->debug_category)
|
#define GST_CAT_DEFAULT (base->debug_category)
|
||||||
|
|
|
@ -22,12 +22,13 @@
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <gst/va/gstvautils.h>
|
||||||
|
|
||||||
#include "gstvabasetransform.h"
|
#include "gstvabasetransform.h"
|
||||||
|
|
||||||
#include "gstvaallocator.h"
|
#include "gstvaallocator.h"
|
||||||
#include "gstvacaps.h"
|
#include "gstvacaps.h"
|
||||||
#include "gstvapool.h"
|
#include "gstvapool.h"
|
||||||
#include "gstvautils.h"
|
|
||||||
|
|
||||||
#define GST_CAT_DEFAULT gst_va_base_transform_debug
|
#define GST_CAT_DEFAULT gst_va_base_transform_debug
|
||||||
GST_DEBUG_CATEGORY_STATIC (GST_CAT_DEFAULT);
|
GST_DEBUG_CATEGORY_STATIC (GST_CAT_DEFAULT);
|
||||||
|
|
|
@ -54,6 +54,7 @@
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
|
|
||||||
#include <va/va_drmcommon.h>
|
#include <va/va_drmcommon.h>
|
||||||
|
#include <gst/va/gstvautils.h>
|
||||||
|
|
||||||
#include "gstvaallocator.h"
|
#include "gstvaallocator.h"
|
||||||
#include "gstvabasetransform.h"
|
#include "gstvabasetransform.h"
|
||||||
|
@ -61,7 +62,6 @@
|
||||||
#include "gstvadisplay_priv.h"
|
#include "gstvadisplay_priv.h"
|
||||||
#include "gstvafilter.h"
|
#include "gstvafilter.h"
|
||||||
#include "gstvapool.h"
|
#include "gstvapool.h"
|
||||||
#include "gstvautils.h"
|
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (gst_va_deinterlace_debug);
|
GST_DEBUG_CATEGORY_STATIC (gst_va_deinterlace_debug);
|
||||||
#define GST_CAT_DEFAULT gst_va_deinterlace_debug
|
#define GST_CAT_DEFAULT gst_va_deinterlace_debug
|
||||||
|
|
|
@ -68,6 +68,7 @@
|
||||||
#include "gstvavpp.h"
|
#include "gstvavpp.h"
|
||||||
|
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
|
#include <gst/va/gstvautils.h>
|
||||||
|
|
||||||
#include <va/va_drmcommon.h>
|
#include <va/va_drmcommon.h>
|
||||||
|
|
||||||
|
@ -77,7 +78,6 @@
|
||||||
#include "gstvadisplay_priv.h"
|
#include "gstvadisplay_priv.h"
|
||||||
#include "gstvafilter.h"
|
#include "gstvafilter.h"
|
||||||
#include "gstvapool.h"
|
#include "gstvapool.h"
|
||||||
#include "gstvautils.h"
|
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (gst_va_vpp_debug);
|
GST_DEBUG_CATEGORY_STATIC (gst_va_vpp_debug);
|
||||||
#define GST_CAT_DEFAULT gst_va_vpp_debug
|
#define GST_CAT_DEFAULT gst_va_vpp_debug
|
||||||
|
|
|
@ -14,7 +14,6 @@ va_sources = [
|
||||||
'gstvapool.c',
|
'gstvapool.c',
|
||||||
'gstvaprofile.c',
|
'gstvaprofile.c',
|
||||||
'gstvasurfacecopy.c',
|
'gstvasurfacecopy.c',
|
||||||
'gstvautils.c',
|
|
||||||
'gstvavideoformat.c',
|
'gstvavideoformat.c',
|
||||||
'gstvavp8dec.c',
|
'gstvavp8dec.c',
|
||||||
'gstvavp9dec.c',
|
'gstvavp9dec.c',
|
||||||
|
|
Loading…
Reference in a new issue