mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
gltestsrc: remove usage of gldownload library object
This commit is contained in:
parent
cebdf84c81
commit
5495397c81
2 changed files with 82 additions and 89 deletions
|
@ -3,6 +3,7 @@
|
||||||
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
|
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
|
||||||
* Copyright (C) 2002,2007 David A. Schleef <ds@schleef.org>
|
* Copyright (C) 2002,2007 David A. Schleef <ds@schleef.org>
|
||||||
* Copyright (C) 2008 Julien Isorce <julien.isorce@gmail.com>
|
* Copyright (C) 2008 Julien Isorce <julien.isorce@gmail.com>
|
||||||
|
* Copyright (C) 2015 Matthew Waters <matthew@centricular.com>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -47,10 +48,6 @@
|
||||||
#include "gltestsrc.h"
|
#include "gltestsrc.h"
|
||||||
#include <gst/gst-i18n-plugin.h>
|
#include <gst/gst-i18n-plugin.h>
|
||||||
|
|
||||||
#if GST_GL_HAVE_PLATFORM_EGL
|
|
||||||
#include <gst/gl/egl/gsteglimagememory.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define USE_PEER_BUFFERALLOC
|
#define USE_PEER_BUFFERALLOC
|
||||||
#define SUPPORTED_GL_APIS GST_GL_API_OPENGL
|
#define SUPPORTED_GL_APIS GST_GL_API_OPENGL
|
||||||
|
|
||||||
|
@ -71,10 +68,7 @@ static GstStaticPadTemplate src_factory = GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS (GST_VIDEO_CAPS_MAKE_WITH_FEATURES
|
GST_STATIC_CAPS (GST_VIDEO_CAPS_MAKE_WITH_FEATURES
|
||||||
(GST_CAPS_FEATURE_MEMORY_GL_MEMORY,
|
(GST_CAPS_FEATURE_MEMORY_GL_MEMORY,
|
||||||
"RGBA") "; "
|
"RGBA"))
|
||||||
GST_VIDEO_CAPS_MAKE_WITH_FEATURES
|
|
||||||
(GST_CAPS_FEATURE_META_GST_VIDEO_GL_TEXTURE_UPLOAD_META,
|
|
||||||
"RGBA") "; " GST_VIDEO_CAPS_MAKE (GST_GL_COLOR_CONVERT_FORMATS))
|
|
||||||
);
|
);
|
||||||
|
|
||||||
#define gst_gl_test_src_parent_class parent_class
|
#define gst_gl_test_src_parent_class parent_class
|
||||||
|
@ -468,36 +462,13 @@ wrong_caps:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstCaps *
|
|
||||||
gst_gl_test_src_set_caps_features (const GstCaps * caps,
|
|
||||||
const gchar * feature_name)
|
|
||||||
{
|
|
||||||
GstCaps *ret = gst_gl_caps_replace_all_caps_features (caps, feature_name);
|
|
||||||
gst_caps_set_simple (ret, "format", G_TYPE_STRING, "RGBA", NULL);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static GstCaps *
|
static GstCaps *
|
||||||
gst_gl_test_src_getcaps (GstBaseSrc * bsrc, GstCaps * filter)
|
gst_gl_test_src_getcaps (GstBaseSrc * bsrc, GstCaps * filter)
|
||||||
{
|
{
|
||||||
GstGLTestSrc *src = GST_GL_TEST_SRC (bsrc);
|
GstCaps *tmp = NULL;
|
||||||
GstCaps *tmp;
|
GstCaps *result =
|
||||||
GstCaps *result = NULL;
|
|
||||||
GstCaps *gl_caps;
|
|
||||||
GstCaps *caps =
|
|
||||||
gst_caps_from_string ("video/x-raw(memory:GLMemory),format=RGBA");
|
gst_caps_from_string ("video/x-raw(memory:GLMemory),format=RGBA");
|
||||||
|
|
||||||
gl_caps =
|
|
||||||
gst_caps_merge (gst_gl_test_src_set_caps_features (caps,
|
|
||||||
GST_CAPS_FEATURE_MEMORY_GL_MEMORY),
|
|
||||||
gst_gl_test_src_set_caps_features (caps,
|
|
||||||
GST_CAPS_FEATURE_META_GST_VIDEO_GL_TEXTURE_UPLOAD_META));
|
|
||||||
result =
|
|
||||||
gst_gl_download_transform_caps (src->context, GST_PAD_SINK, caps, NULL);
|
|
||||||
result = gst_caps_merge (gl_caps, result);
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (bsrc, "transfer returned caps %" GST_PTR_FORMAT, result);
|
|
||||||
|
|
||||||
if (filter) {
|
if (filter) {
|
||||||
tmp = gst_caps_intersect_full (filter, result, GST_CAPS_INTERSECT_FIRST);
|
tmp = gst_caps_intersect_full (filter, result, GST_CAPS_INTERSECT_FIRST);
|
||||||
gst_caps_unref (result);
|
gst_caps_unref (result);
|
||||||
|
@ -532,10 +503,39 @@ gst_gl_test_src_query (GstBaseSrc * bsrc, GstQuery * query)
|
||||||
switch (GST_QUERY_TYPE (query)) {
|
switch (GST_QUERY_TYPE (query)) {
|
||||||
case GST_QUERY_CONTEXT:
|
case GST_QUERY_CONTEXT:
|
||||||
{
|
{
|
||||||
|
const gchar *context_type;
|
||||||
|
GstContext *context, *old_context;
|
||||||
|
|
||||||
res = gst_gl_handle_context_query ((GstElement *) src, query,
|
res = gst_gl_handle_context_query ((GstElement *) src, query,
|
||||||
&src->display, &src->other_context);
|
&src->display, &src->other_context);
|
||||||
if (src->display)
|
if (src->display)
|
||||||
gst_gl_display_filter_gl_api (src->display, SUPPORTED_GL_APIS);
|
gst_gl_display_filter_gl_api (src->display, SUPPORTED_GL_APIS);
|
||||||
|
|
||||||
|
gst_query_parse_context_type (query, &context_type);
|
||||||
|
|
||||||
|
if (g_strcmp0 (context_type, "gst.gl.local_context") == 0) {
|
||||||
|
GstStructure *s;
|
||||||
|
|
||||||
|
gst_query_parse_context (query, &old_context);
|
||||||
|
|
||||||
|
if (old_context)
|
||||||
|
context = gst_context_copy (old_context);
|
||||||
|
else
|
||||||
|
context = gst_context_new ("gst.gl.local_context", FALSE);
|
||||||
|
|
||||||
|
s = gst_context_writable_structure (context);
|
||||||
|
gst_structure_set (s, "context", GST_GL_TYPE_CONTEXT, src->context,
|
||||||
|
NULL);
|
||||||
|
gst_query_set_context (query, context);
|
||||||
|
gst_context_unref (context);
|
||||||
|
|
||||||
|
res = src->context != NULL;
|
||||||
|
}
|
||||||
|
GST_LOG_OBJECT (src, "context query of type %s %i", context_type, res);
|
||||||
|
|
||||||
|
if (res)
|
||||||
|
return res;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GST_QUERY_CONVERT:
|
case GST_QUERY_CONVERT:
|
||||||
|
@ -548,13 +548,14 @@ gst_gl_test_src_query (GstBaseSrc * bsrc, GstQuery * query)
|
||||||
gst_video_info_convert (&src->out_info, src_fmt, src_val, dest_fmt,
|
gst_video_info_convert (&src->out_info, src_fmt, src_val, dest_fmt,
|
||||||
&dest_val);
|
&dest_val);
|
||||||
gst_query_set_convert (query, src_fmt, src_val, dest_fmt, dest_val);
|
gst_query_set_convert (query, src_fmt, src_val, dest_fmt, dest_val);
|
||||||
break;
|
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
res = GST_BASE_SRC_CLASS (parent_class)->query (bsrc, query);
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return GST_BASE_SRC_CLASS (parent_class)->query (bsrc, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -638,16 +639,7 @@ gst_gl_test_src_fill (GstPushSrc * psrc, GstBuffer * buffer)
|
||||||
gint width, height;
|
gint width, height;
|
||||||
GstVideoFrame out_frame;
|
GstVideoFrame out_frame;
|
||||||
GstGLSyncMeta *sync_meta;
|
GstGLSyncMeta *sync_meta;
|
||||||
guint out_tex, out_tex_target;
|
guint out_tex;
|
||||||
gboolean to_download =
|
|
||||||
gst_caps_features_is_equal (GST_CAPS_FEATURES_MEMORY_SYSTEM_MEMORY,
|
|
||||||
gst_caps_get_features (src->out_caps, 0));
|
|
||||||
GstMapFlags out_map_flags = GST_MAP_WRITE;
|
|
||||||
|
|
||||||
to_download |= !gst_is_gl_memory (gst_buffer_peek_memory (buffer, 0));
|
|
||||||
|
|
||||||
if (!to_download)
|
|
||||||
out_map_flags |= GST_MAP_GL;
|
|
||||||
|
|
||||||
if (G_UNLIKELY (!src->negotiated || !src->context))
|
if (G_UNLIKELY (!src->negotiated || !src->context))
|
||||||
goto not_negotiated;
|
goto not_negotiated;
|
||||||
|
@ -667,49 +659,21 @@ gst_gl_test_src_fill (GstPushSrc * psrc, GstBuffer * buffer)
|
||||||
src->make_image = gst_gl_test_src_black;
|
src->make_image = gst_gl_test_src_black;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!gst_video_frame_map (&out_frame, &src->out_info, buffer, out_map_flags)) {
|
if (!gst_video_frame_map (&out_frame, &src->out_info, buffer,
|
||||||
|
GST_MAP_WRITE | GST_MAP_GL)) {
|
||||||
return GST_FLOW_NOT_NEGOTIATED;
|
return GST_FLOW_NOT_NEGOTIATED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!to_download) {
|
out_tex = *(guint *) out_frame.data[0];
|
||||||
out_tex = *(guint *) out_frame.data[0];
|
|
||||||
out_tex_target =
|
|
||||||
((GstGLMemory *) gst_buffer_peek_memory (buffer, 0))->tex_target;
|
|
||||||
} else {
|
|
||||||
GST_INFO ("Output Buffer does not contain correct meta, "
|
|
||||||
"attempting to wrap for download");
|
|
||||||
|
|
||||||
if (!src->download)
|
|
||||||
src->download = gst_gl_download_new (src->context);
|
|
||||||
|
|
||||||
gst_gl_download_set_format (src->download, &out_frame.info);
|
|
||||||
|
|
||||||
if (!src->out_tex_id) {
|
|
||||||
gst_gl_context_gen_texture (src->context, &src->out_tex_id,
|
|
||||||
GST_VIDEO_FORMAT_RGBA, GST_VIDEO_FRAME_WIDTH (&out_frame),
|
|
||||||
GST_VIDEO_FRAME_HEIGHT (&out_frame));
|
|
||||||
}
|
|
||||||
out_tex = src->out_tex_id;
|
|
||||||
out_tex_target = GL_TEXTURE_2D;
|
|
||||||
}
|
|
||||||
|
|
||||||
gst_buffer_replace (&src->buffer, buffer);
|
gst_buffer_replace (&src->buffer, buffer);
|
||||||
|
|
||||||
//blocking call, generate a FBO
|
|
||||||
if (!gst_gl_context_use_fbo_v2 (src->context, width, height, src->fbo,
|
if (!gst_gl_context_use_fbo_v2 (src->context, width, height, src->fbo,
|
||||||
src->depthbuffer, out_tex, gst_gl_test_src_callback,
|
src->depthbuffer, out_tex, gst_gl_test_src_callback,
|
||||||
(gpointer) src)) {
|
(gpointer) src)) {
|
||||||
goto not_negotiated;
|
goto not_negotiated;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (to_download) {
|
|
||||||
if (!gst_gl_download_perform_with_data (src->download,
|
|
||||||
out_tex, out_tex_target, out_frame.data)) {
|
|
||||||
GST_ELEMENT_ERROR (src, RESOURCE, NOT_FOUND, ("%s",
|
|
||||||
"Failed to init upload format"), (NULL));
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
gst_video_frame_unmap (&out_frame);
|
gst_video_frame_unmap (&out_frame);
|
||||||
|
|
||||||
sync_meta = gst_buffer_get_gl_sync_meta (buffer);
|
sync_meta = gst_buffer_get_gl_sync_meta (buffer);
|
||||||
|
@ -776,15 +740,6 @@ gst_gl_test_src_stop (GstBaseSrc * basesrc)
|
||||||
gst_object_unref (src->shader);
|
gst_object_unref (src->shader);
|
||||||
src->shader = NULL;
|
src->shader = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (src->out_tex_id) {
|
|
||||||
gst_gl_context_del_texture (src->context, &src->out_tex_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (src->download) {
|
|
||||||
gst_object_unref (src->download);
|
|
||||||
src->download = NULL;
|
|
||||||
}
|
|
||||||
//blocking call, delete the FBO
|
//blocking call, delete the FBO
|
||||||
gst_gl_context_del_fbo (src->context, src->fbo, src->depthbuffer);
|
gst_gl_context_del_fbo (src->context, src->fbo, src->depthbuffer);
|
||||||
gst_object_unref (src->context);
|
gst_object_unref (src->context);
|
||||||
|
@ -799,6 +754,45 @@ gst_gl_test_src_stop (GstBaseSrc * basesrc)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_find_local_gl_context (GstGLTestSrc * src)
|
||||||
|
{
|
||||||
|
GstQuery *query;
|
||||||
|
GstContext *context;
|
||||||
|
const GstStructure *s;
|
||||||
|
|
||||||
|
if (src->context)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
query = gst_query_new_context ("gst.gl.local_context");
|
||||||
|
if (!src->context && gst_gl_run_query (GST_ELEMENT (src), query, GST_PAD_SRC)) {
|
||||||
|
gst_query_parse_context (query, &context);
|
||||||
|
if (context) {
|
||||||
|
s = gst_context_get_structure (context);
|
||||||
|
gst_structure_get (s, "context", GST_GL_TYPE_CONTEXT, &src->context,
|
||||||
|
NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!src->context
|
||||||
|
&& gst_gl_run_query (GST_ELEMENT (src), query, GST_PAD_SINK)) {
|
||||||
|
gst_query_parse_context (query, &context);
|
||||||
|
if (context) {
|
||||||
|
s = gst_context_get_structure (context);
|
||||||
|
gst_structure_get (s, "context", GST_GL_TYPE_CONTEXT, &src->context,
|
||||||
|
NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (src, "found local context %p", src->context);
|
||||||
|
|
||||||
|
gst_query_unref (query);
|
||||||
|
|
||||||
|
if (src->context)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_gl_test_src_decide_allocation (GstBaseSrc * basesrc, GstQuery * query)
|
gst_gl_test_src_decide_allocation (GstBaseSrc * basesrc, GstQuery * query)
|
||||||
{
|
{
|
||||||
|
@ -819,6 +813,8 @@ gst_gl_test_src_decide_allocation (GstBaseSrc * basesrc, GstQuery * query)
|
||||||
|
|
||||||
gst_gl_display_filter_gl_api (src->display, SUPPORTED_GL_APIS);
|
gst_gl_display_filter_gl_api (src->display, SUPPORTED_GL_APIS);
|
||||||
|
|
||||||
|
_find_local_gl_context (src);
|
||||||
|
|
||||||
if (gst_query_find_allocation_meta (query,
|
if (gst_query_find_allocation_meta (query,
|
||||||
GST_VIDEO_GL_TEXTURE_UPLOAD_META_API_TYPE, &idx)) {
|
GST_VIDEO_GL_TEXTURE_UPLOAD_META_API_TYPE, &idx)) {
|
||||||
GstGLContext *context;
|
GstGLContext *context;
|
||||||
|
|
|
@ -104,9 +104,6 @@ struct _GstGLTestSrc {
|
||||||
GstBuffer* buffer;
|
GstBuffer* buffer;
|
||||||
GstBufferPool *pool;
|
GstBufferPool *pool;
|
||||||
|
|
||||||
guint out_tex_id;
|
|
||||||
GstGLDownload *download;
|
|
||||||
|
|
||||||
GstGLDisplay *display;
|
GstGLDisplay *display;
|
||||||
GstGLContext *context, *other_context;
|
GstGLContext *context, *other_context;
|
||||||
gint64 timestamp_offset; /* base offset */
|
gint64 timestamp_offset; /* base offset */
|
||||||
|
|
Loading…
Reference in a new issue