summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJulien Isorce <julien.isorce@collabora.co.uk>2014-06-24 19:35:01 +0100
committerJulien Isorce <julien.isorce@collabora.co.uk>2014-06-25 06:56:33 +0100
commitf63c91ab714ec145e43fb1ddb76368a7d2fff5db (patch)
tree8cbc62fcc5e468085437bea846f26412ffcfd6fd
parent045aa4ee7ec58450db4b0cfd8153fafcc4d456d3 (diff)
downloadgstreamer-plugins-bad-f63c91ab714ec145e43fb1ddb76368a7d2fff5db.tar.gz
glfilter: handle NULL decide_query which means passthrough
See https://bugzilla.gnome.org/show_bug.cgi?id=732178
-rw-r--r--gst-libs/gst/gl/gstglfilter.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/gst-libs/gst/gl/gstglfilter.c b/gst-libs/gst/gl/gstglfilter.c
index c0c79f3b1..2523bfe9e 100644
--- a/gst-libs/gst/gl/gstglfilter.c
+++ b/gst-libs/gst/gl/gstglfilter.c
@@ -873,19 +873,23 @@ gst_gl_filter_propose_allocation (GstBaseTransform * trans,
if (pool == NULL && need_pool) {
GstVideoInfo info;
- GstBufferPool *decide_pool;
+ GstBufferPool *decide_pool = NULL;
if (!gst_video_info_from_caps (&info, caps))
goto invalid_caps;
- gst_query_parse_allocation (decide_query, &decide_caps, NULL);
- decide_pool = gst_base_transform_get_buffer_pool (trans);
- if (GST_IS_GL_BUFFER_POOL (decide_pool)
+ if (decide_query) {
+ gst_query_parse_allocation (decide_query, &decide_caps, NULL);
+ decide_pool = gst_base_transform_get_buffer_pool (trans);
+ }
+
+ if (decide_pool && GST_IS_GL_BUFFER_POOL (decide_pool)
&& gst_caps_is_equal_fixed (decide_caps, caps)) {
pool = decide_pool;
} else {
GST_DEBUG_OBJECT (filter, "create new pool");
- gst_object_unref (decide_pool);
+ if (decide_pool)
+ gst_object_unref (decide_pool);
pool = gst_gl_buffer_pool_new (filter->context);
/* the normal size of a frame */