mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
v4l2bufferpool: Free orphaned allocator resources when buffers are released
Allocator resources cannot be freed when a buffer pool is orphaned while its buffers are in use. They should, however, be freed once those buffers are no longer needed. This patch disposes of any buffers belonging to an orphaned pool as they are released, and makes sure that the allocator is cleaned up when the last buffer is returned.
This commit is contained in:
parent
1b9a0f1c2d
commit
50dfbf1c0d
1 changed files with 27 additions and 11 deletions
|
@ -932,6 +932,22 @@ cannot_import:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_v4l2_buffer_pool_vallocator_stop (GstV4l2BufferPool * pool)
|
||||||
|
{
|
||||||
|
GstV4l2Return vret;
|
||||||
|
|
||||||
|
if (!pool->vallocator)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
vret = gst_v4l2_allocator_stop (pool->vallocator);
|
||||||
|
|
||||||
|
if (vret == GST_V4L2_BUSY)
|
||||||
|
GST_WARNING_OBJECT (pool, "some buffers are still outstanding");
|
||||||
|
|
||||||
|
return (vret == GST_V4L2_OK);
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_v4l2_buffer_pool_stop (GstBufferPool * bpool)
|
gst_v4l2_buffer_pool_stop (GstBufferPool * bpool)
|
||||||
{
|
{
|
||||||
|
@ -939,7 +955,7 @@ gst_v4l2_buffer_pool_stop (GstBufferPool * bpool)
|
||||||
gboolean ret;
|
gboolean ret;
|
||||||
|
|
||||||
if (pool->orphaned)
|
if (pool->orphaned)
|
||||||
return TRUE;
|
return gst_v4l2_buffer_pool_vallocator_stop (pool);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (pool, "stopping pool");
|
GST_DEBUG_OBJECT (pool, "stopping pool");
|
||||||
|
|
||||||
|
@ -959,16 +975,8 @@ gst_v4l2_buffer_pool_stop (GstBufferPool * bpool)
|
||||||
|
|
||||||
ret = GST_BUFFER_POOL_CLASS (parent_class)->stop (bpool);
|
ret = GST_BUFFER_POOL_CLASS (parent_class)->stop (bpool);
|
||||||
|
|
||||||
if (ret && pool->vallocator) {
|
if (ret)
|
||||||
GstV4l2Return vret;
|
ret = gst_v4l2_buffer_pool_vallocator_stop (pool);
|
||||||
|
|
||||||
vret = gst_v4l2_allocator_stop (pool->vallocator);
|
|
||||||
|
|
||||||
if (vret == GST_V4L2_BUSY)
|
|
||||||
GST_WARNING_OBJECT (pool, "some buffers are still outstanding");
|
|
||||||
|
|
||||||
ret = (vret == GST_V4L2_OK);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -1452,6 +1460,14 @@ gst_v4l2_buffer_pool_release_buffer (GstBufferPool * bpool, GstBuffer * buffer)
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (pool, "release buffer %p", buffer);
|
GST_DEBUG_OBJECT (pool, "release buffer %p", buffer);
|
||||||
|
|
||||||
|
/* If the buffer's pool has been orphaned, dispose of it so that
|
||||||
|
* the pool resources can be freed */
|
||||||
|
if (pool->orphaned) {
|
||||||
|
GST_BUFFER_FLAG_SET (buffer, GST_BUFFER_FLAG_TAG_MEMORY);
|
||||||
|
pclass->release_buffer (bpool, buffer);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
switch (obj->type) {
|
switch (obj->type) {
|
||||||
case V4L2_BUF_TYPE_VIDEO_CAPTURE:
|
case V4L2_BUF_TYPE_VIDEO_CAPTURE:
|
||||||
case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
|
case V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
|
||||||
|
|
Loading…
Reference in a new issue