diff options
author | Philipp Zabel <p.zabel@pengutronix.de> | 2016-11-24 14:41:52 +0100 |
---|---|---|
committer | Nicolas Dufresne <nicolas.dufresne@collabora.com> | 2016-11-24 11:47:07 -0500 |
commit | 65826f819ad96b997847f2b87c4bc52b16e02e34 (patch) | |
tree | f58bf7b65b7049a728c6de01af93adacadd6dfb4 | |
parent | 34db78b645a57709f2084d1ff42a45da9880d113 (diff) |
v4l2src: release buffer if create fails
gst_base_src_get_range does not expect a buffer to be returned in
the error case, so we are leaking a reference here if create fails.
https://bugzilla.gnome.org/show_bug.cgi?id=775014
-rw-r--r-- | sys/v4l2/gstv4l2src.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/sys/v4l2/gstv4l2src.c b/sys/v4l2/gstv4l2src.c index 3b722b28d..0149814f2 100644 --- a/sys/v4l2/gstv4l2src.c +++ b/sys/v4l2/gstv4l2src.c @@ -873,6 +873,7 @@ alloc_failed: } error: { + gst_buffer_replace (buf, NULL); if (ret == GST_V4L2_FLOW_LAST_BUFFER) { GST_ELEMENT_ERROR (src, RESOURCE, FAILED, ("Driver returned a buffer with no payload, this most likely " |