mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-15 12:56:33 +00:00
9d867356df
Fixes a potential GPU stall if an immediately freed texture/buffer is attempted to be reused immediately by the CPU, e.g. when uploading. Problematic scenario is this: 1. element does GPU processing reading from texture 2. frees the buffer back to the pool 3. pool acquire returns the just released buffer 4. GPU processing then has to wait for the previous GPU operation to complete causing a stall If there was a reliable way to know whether a buffer had been finished with across all GPU drivers, we would use it. However as that does not exist, this workaround is to keep the released buffer unusable until the next released buffer. This is the same approach as is used in the qml (Qt5) elements. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5144>
88 lines
2.7 KiB
C
88 lines
2.7 KiB
C
/*
|
|
* GStreamer
|
|
* Copyright (C) 2012 Matthew Waters <ystreet00@gmail.com>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Library General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library General Public
|
|
* License along with this library; if not, write to the
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
* Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef _GST_GL_BUFFER_POOL_H_
|
|
#define _GST_GL_BUFFER_POOL_H_
|
|
|
|
#include <gst/video/gstvideometa.h>
|
|
#include <gst/video/gstvideopool.h>
|
|
|
|
#include <gst/gl/gstglbasememory.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
/* buffer pool functions */
|
|
GST_GL_API
|
|
GType gst_gl_buffer_pool_get_type (void);
|
|
#define GST_TYPE_GL_BUFFER_POOL (gst_gl_buffer_pool_get_type())
|
|
#define GST_IS_GL_BUFFER_POOL(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_GL_BUFFER_POOL))
|
|
#define GST_GL_BUFFER_POOL(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_GL_BUFFER_POOL, GstGLBufferPool))
|
|
#define GST_GL_BUFFER_POOL_CAST(obj) ((GstGLBufferPool*)(obj))
|
|
|
|
/**
|
|
* GstGLBufferPool:
|
|
*
|
|
* Opaque GstGLBufferPool struct
|
|
*/
|
|
struct _GstGLBufferPool
|
|
{
|
|
GstBufferPool bufferpool;
|
|
|
|
GstGLContext *context;
|
|
|
|
/*< private >*/
|
|
GstGLBufferPoolPrivate *priv;
|
|
|
|
gpointer _padding[GST_PADDING];
|
|
};
|
|
|
|
/**
|
|
* GstGLBufferPoolClass:
|
|
*
|
|
* The #GstGLBufferPoolClass structure contains only private data
|
|
*/
|
|
struct _GstGLBufferPoolClass
|
|
{
|
|
GstBufferPoolClass parent_class;
|
|
|
|
/*< private >*/
|
|
gpointer _padding[GST_PADDING];
|
|
};
|
|
|
|
GST_GL_API
|
|
GstBufferPool *gst_gl_buffer_pool_new (GstGLContext * context);
|
|
|
|
GST_GL_API
|
|
GstGLAllocationParams * gst_gl_buffer_pool_get_gl_allocation_params (GstGLBufferPool * pool);
|
|
|
|
GST_GL_API
|
|
GstGLAllocationParams * gst_buffer_pool_config_get_gl_allocation_params (GstStructure * config);
|
|
GST_GL_API
|
|
void gst_buffer_pool_config_set_gl_allocation_params (GstStructure * config,
|
|
const GstGLAllocationParams * params);
|
|
GST_GL_API
|
|
guint gst_buffer_pool_config_get_gl_min_free_queue_size (GstStructure * config);
|
|
GST_GL_API
|
|
void gst_buffer_pool_config_set_gl_min_free_queue_size (GstStructure * config,
|
|
guint queue_size);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* _GST_GL_BUFFER_POOL_H_ */
|